Используя Express, когда мы используем app.listen(port), местоположение приложения - localhost:port/.
На локальном компьютере я полностью понимаю, как мы можем получить доступ к этому адресу, поскольку мы используем локальный браузер, работающий на том же компьютере. Даже другие клиенты, работающие в той же сети, могут получить доступ к серверу.
Насколько мне известно, к IP-адресу localhost или 127.0.0.1 можно получить доступ на той же или других машинах в той же сети.
Но если мы выполняем развертывание в облаке, например Heroku, без добавления параметра IP, такого как app.listen(port, IP_ADDRESS), вместо этого мы используем app.listen(port), единственное, что меняется, - это номер ПОРТА (process.env.PORT), но IP по-прежнему остается localhost. Итак, как клиенты из других сетей могут получить доступ к серверу?



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


Вы можете использовать переадресацию портов на своем маршрутизаторе, чтобы перенаправить router_ip:port на local_ip:port, что позволит вам получить к нему доступ извне.
Тот факт, что вы подключаетесь к своему локальному экземпляру через localhost, не означает, что он также не доступен через IP. Localhost в основном говорит, что не разрешайте IP-адреса, просто вернитесь к этому компьютеру, но ваш сервер узла все равно будет развернут на фактический IP-адрес. Попробуйте найти IP-адрес своего компьютера и подключиться к серверу узла через него, а не через localhost, и вы обнаружите, что все еще можете связываться с сервером.
При развертывании в облачной службе или любой другой службе хостинга вам будет предоставлен IP-адрес, связанный с этим экземпляром, который будет использоваться для разрешения. В частности, Heroku внесет в черный ящик большую часть процессов доменного пространства и переадресации портов.