Я использую сервер веб-приложений rails, связанный с 0.0.0.0
в порту 80
вот так:
sudo rails s --port=80 --bind=0.0.0.0
Я могу получить к нему доступ по моему личному адресу http://192.168.0.13/
, обычно я могу получить доступ по адресу обратной связи http://127.0.0.1
/ http://localhost
. Однако по какой-то причине адрес обратной связи не указывает на этот частный адрес. Я думаю, что эта проблема связана с виртуальной машиной, настроенной на моем компьютере, поскольку эта проблема началась после того, как я настроил виртуальную машину.
Настройка бродячей виртуальной машины (которую я не настраивал) запускает второй сервер веб-приложений, который я жестяная банка доступ в http://127.0.0.1
. Однако даже когда я выключаю эту бродячую виртуальную машину, я все еще не могу получить доступ к упомянутому выше серверу веб-приложений rails по адресу обратной связи.
Что делает бродячая виртуальная машина, чтобы настроить саму себя?
Как я могу настроить частный адрес, на который указывает адрес обратной связи?
Вот мой ifconfig
если это поможет:
lo0: flags=8049<UP,LOOPBACK,RUNNING,MULTICAST> mtu 16384
options=3<RXCSUM,TXCSUM>
inet6 ::1 prefixlen 128
inet 127.0.0.1 netmask 0xff000000
inet6 fe80::1%lo0 prefixlen 64 scopeid 0x1
nd6 options=1<PERFORMNUD>
gif0: flags=8010<POINTOPOINT,MULTICAST> mtu 1280
stf0: flags=0<> mtu 1280
en1: flags=8863<UP,BROADCAST,SMART,RUNNING,SIMPLEX,MULTICAST> mtu 1500
ether 4c:8d:79:d7:a9:e4
inet6 fe80::4e8d:79ff:fed7:a9e4%en1 prefixlen 64 scopeid 0x4
inet 192.168.0.13 netmask 0xffffff00 broadcast 192.168.0.255
nd6 options=1<PERFORMNUD>
media: autoselect
status: active
en0: flags=8863<UP,BROADCAST,SMART,RUNNING,SIMPLEX,MULTICAST> mtu 1500
options=10b<RXCSUM,TXCSUM,VLAN_HWTAGGING,AV>
ether a8:20:66:5a:9b:c7
nd6 options=1<PERFORMNUD>
media: autoselect (none)
status: inactive
fw0: flags=8863<UP,BROADCAST,SMART,RUNNING,SIMPLEX,MULTICAST> mtu 4078
lladdr 10:dd:b1:ff:fe:4f:ee:4c
nd6 options=1<PERFORMNUD>
media: autoselect <full-duplex>
status: inactive
en2: flags=963<UP,BROADCAST,SMART,RUNNING,PROMISC,SIMPLEX> mtu 1500
options=60<TSO4,TSO6>
ether d2:00:14:fe:e4:c0
media: autoselect <full-duplex>
status: inactive
p2p0: flags=8843<UP,BROADCAST,RUNNING,SIMPLEX,MULTICAST> mtu 2304
ether 0e:8d:79:d7:a9:e4
media: autoselect
status: inactive
awdl0: flags=8943<UP,BROADCAST,RUNNING,PROMISC,SIMPLEX,MULTICAST> mtu 1484
ether de:fa:c4:c2:1b:f7
inet6 fe80::dcfa:c4ff:fec2:1bf7%awdl0 prefixlen 64 scopeid 0x9
nd6 options=1<PERFORMNUD>
media: autoselect
status: active
bridge0: flags=8863<UP,BROADCAST,SMART,RUNNING,SIMPLEX,MULTICAST> mtu 1500
options=63<RXCSUM,TXCSUM,TSO4,TSO6>
ether 4e:8d:79:7d:7e:00
Configuration:
id 0:0:0:0:0:0 priority 0 hellotime 0 fwddelay 0
maxage 0 holdcnt 0 proto stp maxaddr 100 timeout 1200
root id 0:0:0:0:0:0 priority 0 ifcost 0 port 0
ipfilter disabled flags 0x2
member: en2 flags=3<LEARNING,DISCOVER>
ifmaxaddr 0 port 7 priority 0 path cost 0
nd6 options=1<PERFORMNUD>
media: <unknown type>
status: inactive
vboxnet0: flags=8843<UP,BROADCAST,RUNNING,SIMPLEX,MULTICAST> mtu 1500
ether 0a:00:27:00:00:00
inet 172.28.128.1 netmask 0xffffff00 broadcast 172.28.128.255
в Vagrantfile
Я вижу, что он настроил переадресацию портов:
system('sudo pfctl -E')
system('echo "
rdr pass on lo0 inet proto tcp from any to 127.0.0.1 port 80 -> 127.0.0.1 port 9080
rdr pass on lo0 inet proto tcp from any to 127.0.0.1 port 443 -> 127.0.0.1 port 9443
" | sudo pfctl -f - > /dev/null 2>&1; echo "==> Fowarding Ports: 80 -> 9080, 443 -> 9443"')
127.0.0.1
это ваша петля. Он всегда локален для машины, на которой вы находитесь. Создание виртуальной машины означает, что это новая машина, и у нее есть собственный внутренний 127.0.0.1
. Вы можете создать 50 виртуальных машин, и у каждой из них будет свой внутренний 127.0.0.1
и компьютер не может узнать, какой из них вы хотите. Таким образом, вы должны иметь доступ к веб-страницам на виртуальной машине только с их маршрутизируемого IP-адреса, а не 127.0.0.1
.