Независимо от того, что вы делаете (например, из Ubuntu или из Windows), не удаляйте раздел восстановления, который, скорее всего, появился на вашем компьютере.
Я мог бы решить свою проблему с помощью решения Christian Long. Я добавил 2 адаптера:
Адаптер 1 - NAT
Адаптер 2 - только хост, vboxnet0
Единственное отличие было в файле интерфейсов VM:
sudoedit /etc/network/interfaces
# The loopback network interface
auto lo
iface lo inet loopback
# NAT
auto eth0
iface eth0 inet dhcp
# Host only
auto eth1
iface eth1 inet dhcp
В конфигурации VirtualBox Network я остановил DHCP.
После перезагрузки виртуальной машины все работает нормально.
Существует еще один простой способ создания нового адаптера NAT
. На хост-машине добавьте следующие правила iptables. Это приведет к пересылке пакетов через хост и в Интернет:sudo iptables -A FORWARD -o eth0 -i vboxnet0 -s 192.168.56.0/24 -m conntrack --ctstate NEW -j ACCEPT
sudo iptables -A FORWARD -m conntrack --ctstate ESTABLISHED,RELATED -j ACCEPT
sudo iptables -A POSTROUTING -t nat -j MASQUERADE
Вам также необходимо включить переадресацию IP на хосте, выпустив следующую команду: sudo sysctl -w net.ipv4.ip_forward=1
Конфигурация сети изменилась в Ubuntu 17.10.1. Теперь вы используете конфигурацию netplan.
Я следил за этим руководством здесь
Как переход от ответа Кристиана, сделайте следующее:
Создайте новый файл конфигурации внутри из файла / etc / netplan, чтобы сохранить конфигурацию адаптера только для хоста.
, например sudo nano /etc/netplan/02-netcfg.yaml
Введите следующую конфигурацию для статического IP-адреса 192.168.56.12, где enp0s3 имя вашего адаптера только для хоста.
network:
version: 2
renderer: networkd
ethernets:
enp0s3:
addresses:
- 192.168.56.12/24
dhcp4: no
Затем выполните следующие две команды:
sudo netplan generate
sudo netplan apply
NAT должен работать без конфигурации, запустите ifconfig, чтобы увидеть результат:
enp0s3: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 192.168.56.12 netmask 255.255.255.0 broadcast 192.168.56.255
inet6 fe80::a00:27ff:fe06:6cdd prefixlen 64 scopeid 0x20<link>
ether 08:00:27:06:6c:dd txqueuelen 1000 (Ethernet)
RX packets 252 bytes 23076 (23.0 KB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 208 bytes 30015 (30.0 KB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
enp0s8: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 10.0.3.15 netmask 255.255.255.0 broadcast 10.0.3.255
inet6 fe80::a00:27ff:fe4d:a6b8 prefixlen 64 scopeid 0x20<link>
ether 08:00:27:4d:a6:b8 txqueuelen 1000 (Ethernet)
RX packets 95 bytes 94894 (94.8 KB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 85 bytes 7436 (7.4 KB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
Я добавил 2 адаптера:
Только адаптер 1, vboxnet0
Adapter2 NAT
И он отлично работает, я могу получить доступ к виртуальной машине из хост, и у меня есть интернет на vm.
Да, у меня была эта проблема, это была полная боль! Но я решил это, просто установив прокси-сервер Squid Cache на свой физический компьютер, и таким образом - мои виртуальные виртуальные компьютеры, доступные только для хостинга, могут подключаться к Интернету!
Я сделал быстрый 3-минутный путеводитель здесь - для любой, кто хочет, как это работает! http://b0zmeister.wordpress.com/allowing-host-only-virtualbox-guest-to-connect-to-the-internet/