Доступ к виртуальной машине извне: Пробрасываем порты в VirtualBox за 5 минут

Доступ к виртуальной машине извне: Пробрасываем порты в VirtualBox за 5 минут

Запустили веб-сервер на виртуальной машине, но не можете к нему подключиться с основного компьютера? Знакомая проблема? Виртуальные машины в VirtualBox по умолчанию изолированы от вашей сети. Это надежно, но не всегда удобно.

Хотите получить доступ к сайту, SSH-серверу или любой другой службе, работающей внутри гостевой ОС? Есть решение! И не одно. Мы покажем вам два рабочих способа, как пробить этот барьер. Вы сможете заставить ваши системы общаться друг с другом, как старые друзья.

Первый способ — это проброс конкретных портов. Быстро, точечно и без лишних сложностей. Идеально, если вам нужен доступ только к одному-двум сервисам. Мы разберем, как это делается через графический интерфейс и одной командой в терминале.

Второй способ мощнее. Он дает виртуальной машине собственный IP-адрес в вашей локальной сети. Теперь она становится полноценным участником сети, доступным с любого устройства. Открывайте любые порты и используйте любые сетевые возможности без ограничений.

Готовы наконец-то подружить вашу основную систему с виртуальной? В статье ждут пошаговые инструкции с картинками, которые решат вашу проблему раз и навсегда. Читайте и внедряйте!


VirtualBox - одна из самых популярных сред виртуализации, которые используются для запуска различных операционных систем. И довольно часто случается ситуация, что вам необходимо получить доступ к какому-либо сервису гостевой системы из основной, например, веб-серверу или ssh. Но по умолчанию сетевые интерфейсы изолированы и такой возможности нет.

Для решения этой задачи можно пойти двумя путями. Мы можем пробросить необходимый порт виртуальной машины в основную систему или же выдать виртуальной машине отдельный IP адрес, что позволит обращаться к любым ее портам и использовать любые сетевые возможности. В этой небольшой статье мы рассмотрим проброс портов virtualbox двумя способами. Начнем с более простого.


Содержание статьи

Проброс портов в VirtualBox

По умолчанию для настройки сети для виртуальной машины используется технология NAT. С помощью нее вы можете просматривать интернет-сайты и выполнять различные действия в сети, но вы не будете видеть ваш основной компьютер. Для виртуальной машины создается виртуальная сеть, в которой есть только она одна, а ваша домашняя сеть и ваш компьютер ей не виден.

Но если вам нужно получить доступ к какому-либо сервису гостевой машины, то можно пробросить порт этого сервиса в основную систему. Так работают порты VirtualBox. Для этого откройте контекстное меню для машины и нажмите "Настройки":

Доступ к виртуальной машине извне: Пробрасываем порты в VirtualBox за 5 минут

Затем перейдите на вкладку "Сеть", а потом разверните строчку "Дополнительно":

Доступ к виртуальной машине извне: Пробрасываем порты в VirtualBox за 5 минут

Тут вам нужно нажать кнопку "Проброс портов":

Доступ к виртуальной машине извне: Пробрасываем порты в VirtualBox за 5 минут

Дальше нажмите кнопку с зеленым значком "+". Тут нужно заполнить несколько полей:

  • Имя - любое имя, по которому вы сможете понять с чем имеете дело;
  • Протокол - протокол, по которому работает сервис, например, tcp;
  • Адрес хоста - адрес на основной машине, подключения к которому будут направляться на виртуальную машину, можно написать 127.0.0.1 или ip в локальной сети;
  • Порт хоста - порт, подключения к которому нужно перенаправлять на гостя;
  • Адрес гостя - на который нужно направлять подключения, оставьте пустым;
  • Порт гостя - порт, на который будут перенаправлены подключения с этого порта.

Адрес хоста в локальной сети можно узнать так:

ifconfig

 

Еще один важный момент, что порт с которого вы перенаправляете и на который перенаправляете не должны совпадать. Странное дело, но если перенаправлять с порта 80 на 80, то работать все это не будет. Нужно использовать 8080 на 80. Тогда все в порядке. Если вы не любитель много кликать, что можно воспользоваться командной терминала:

VBoxManage modifyvm "Имя машины" --natpf1 "rulename,tcp,127.0.0.1,8080,,80"

В этом примере взяты данные из рассмотренного выше примера. Теперь на хосте и виртуальной машине откроется одна и та же страница.

Доступ к виртуальной машине извне: Пробрасываем порты в VirtualBox за 5 минут

Проброс портов virtualbox nat работает.

Виртуальный адаптер хоста VirtualBox

Еще один способ получить доступ к виртуальной машине извне - использовать виртуальный адаптер хоста. Тут вы можете настроить все более подробно, а также получить отдельный ip для машины, что дает больше возможностей. Сначала нужно создать виртуальный адаптер. Для этого откройте меню "Файл", затем "Настройки":

Доступ к виртуальной машине извне: Пробрасываем порты в VirtualBox за 5 минут

Тут нужно перейти на вкладку "Сеть", затем "Виртуальные адаптеры":

Доступ к виртуальной машине извне: Пробрасываем порты в VirtualBox за 5 минут

Дальше нажмите кнопку "+", чтобы в списке появился пункт vboxnet0. Тут готово, нажмите несколько раз "Ok" чтобы закрыть это окно. Дальше откройте контекстное меню вашей виртуальной машины, потом "Настроить", а затем "Сеть":

 

Тут вам нужно в выпадающем списке заменить "NAT" на "Виртуальный адаптер хоста". В поле имя, выберите "vboxnet0":

Доступ к виртуальной машине извне: Пробрасываем порты в VirtualBox за 5 минут

Теперь можете запускать виртуальную машину и смотреть ее ip адрес:

Доступ к виртуальной машине извне: Пробрасываем порты в VirtualBox за 5 минут

 

По нему гостевая система будет доступной из внешней. Внешняя система теперь тоже полностью доступна из гостевой по адресу 192.168.56.1:

Доступ к виртуальной машине извне: Пробрасываем порты в VirtualBox за 5 минутДоступ к виртуальной машине извне: Пробрасываем порты в VirtualBox за 5 минут

Выводы

В этой небольшой статье мы рассмотрели как выполняется проброс портов VirtualBox, это может быть очень полезным, если вы часто работаете с виртуальными машинами. Если у вас остались вопросы, спрашивайте в комментариях!

Оставить комментарий


Кликните на изображение чтобы обновить код, если он неразборчив