Виртуальная машина. Как установить и настроить Oracle VM VirtualBox? Настройка сети на платформе виртуализации Oracle VM VirtualBox

Новости 18.08.2019
Новости

Сегодня я расскажу о своем опыте установки , настройки и конфигурировании VirtualBox в Windows. Также, расскажу почему я выбрал именно платформу виртуализации VirtualBox , зачем вообще это мне нужно и т.д. Чтобы сэкономить Ваше время, предлагаю Вам посмотреть видео по теме:


Почему VirtualBox?

Прежде чем я расскажу о тех причинах, по которым я выбрал именно VirtualBox, я бы хотел немного затронуть тему виртуализации и эмуляции вцелом. Что такое эмуляция?
Эмуляция — это способность программы или устройства имитировать работу другой программы или другого устройства.
Кто и для чего применяет эмуляторы?
Программные эмуляторы в первую очередь предназначены для развертывания на одном компьютере нескольких ОС, не затрагивая при этом основную операционную систему. Эмуляторы или системы виртуализации доступны широкому кругу людей: от простых пользователей до администраторов и программистов.
Эмуляторы для пользователей — это, в первую очередь, возможность запуска приложений под другие ОС без перезагрузки основной, тестирования нового ПО и различных экспериментов с настройками.
Эмуляторы для администраторов — это полигон для экспериментов! Теперь обучение администрированию стало гораздо проще, любой желающий может создавать виртуальные сети из десятков гостевых ОС, настраивать их, получая практические навыки.
Эмуляторы для программистов — это те помощник, без которых уже сложно обходится. Они ускоряют отладку и тестирования программ буквально в разы. А если говорить о разработчиках сетевых приложений или низко-уровневом программировании, то эмуляторам просто нет цены!
Эмуляторы для хакеров — ну тут все ясно, проверка эксплоитов, тестирование вирусов, отладка и изучение чужих программ…
Поэтому значение эмуляции сложно переоценить. Вопрос только в том, какой эмулятор выбрать ?

Выбор виртуальной машины зависит от ряда причин, которые для себя определяет сам пользователь. Я исходил из следующих требований к виртуальной машине:

  1. Должна работать на платформе Windows
  2. Должна поддерживать работу всех самых распространенных операционных систем в гостевом режиме

Этим двум, я бы сказал, жестким требованиям соответствует далеко не все виртуальные машины. Мной рассматривались VirtualPC (не подошла, потому что реализована поддержка только Windows-гостевых систем) и VMWare (не подошла, потому что это платное ПО, цена на которое очень высока, а пользоваться взломанными версиями я не хочу).

Возможности VirtualBox

  • Кроссплатформенность
  • Модульность
  • Живая миграция
  • Поддержка USB 2.0, когда устройства хост-машины становятся доступными для гостевых ОС (только в проприетарной версии)
  • Поддержка 64-битных гостевых систем (начиная с версии 2.0), даже на 32-битных хост-системах (начиная с версии 2.1, для этого обязательна поддержка технологии виртуализации процессором)
  • Поддержка SMP на стороне гостевой системы (начиная с версии 3.0, для этого обязательна поддержка технологии виртуализации процессором)
  • Встроенный RDP-сервер, а также поддержка клиентских USB-устройств поверх протокола RDP (только в проприетарной версии)
  • Экспериментальная поддержка аппаратного 3D-ускорения (OpenGL, DirectX 8/9 (с использованием кода wine) (только в 32-битных Windows XP и Vista)), для гостевых DOS / Windows 3.x / 95 / 98 / ME поддержка аппаратного 3D-ускорения не предусмотрена
  • Поддержка образов жёстких дисков VMDK (VMware) и VHD (Microsoft Virtual PC), включая snapshots (начиная с версии 2.1)
  • Поддержка iSCSI (только в проприетарной версии)
  • Поддержка виртуализации аудиоустройств (эмуляция AC97 или SoundBlaster 16 на выбор)
  • Поддержка различных видов сетевого взаимодействия (NAT, Host Networking via Bridged, Internal)
  • Поддержка цепочки сохраненных состояний виртуальной машины (snapshots), к которым может быть произведён откат из любого состояния гостевой системы
  • Поддержка Shared Folders для простого обмена файлами между хостовой и гостевой системами (для гостевых систем Windows 2000 и новее, Linux и Solaris)
  • Поддержка интеграции рабочих столов (seamless mode) хостовой и гостевой ОС
  • Есть возможность выбора языка интерфейса (поддерживается и русскоязычный интерфейс)

Список внушительный, к тому же, недавно вышла версия 3.2.12 было исправлено большое количество ошибок, с ними можно ознакомиться на сайте разработчика VirtualBox .

Надеюсь что покупка Sun компанией Oracle не повлияет на развитие этого великолепного проекта, а то они любят все монетизировать.

Установка VirtualBox

В качестве хост-системы используется Windows Vista Ultimate SP2 . Сам процесс установки VirtualBox довольно тривиальный, все понятно и без комментариев.

Далее нужно следовать инструкциям установщика. На одном из этапов, при установке сетевых адаптеров, текущее подключение к локальной сети может прерваться. После установки можно приступить к добавлению гостевой ОС. После установки VirtualBox, советую изменить некоторые настройки программы, в частности указать пути по умолчанию для файлов новых виртуальных ОС и т.п. Это можно сделать в окне вызываемом командой Файл -> Настройки .

Настройка VirtualBox

Создание новой гостевой ОС

Для создания Вашей первой виртуальной ОС щелкните кнопку «Создать». Запустить мастер создания новой виртуальной машины. Следуя его инструкциям нужно будет выбрать семейство будущей виртуальной операционной системы и ее версию, а также, ввести ее имя.

512 Мб для большинства ОС уже достаточно, но я выделил 1 Гб.
Далее нужно будет создать новый жесткий диск, это довольно простая процедура, нужно просто следовать инструкциям мастера создания новых жестких дисков. В итоге у Вас должно получится что-то подобное:

Завершающий этап создания гостевой ОС в VirtualBox

Настройка оборудования гостевой ОС в VirtualBox

Определить аппаратную часть созданной гостевой системы можно в ее «Свойствах». Для этого, выбрав нужную гостевую ОС, вызываем команду Свойства командной панели. После этого появляется окно свойств. Слева в этом окне будут указаны разделы настроек, а в центре окна их установки. Все настройки интуитивно понятны и имеют подсказки.

Вкладка Общие — Дополнительно

  • Папка для снимков — путь к папке, где будут хранится образы дисков гостевой ОС. Для снимка требуется большой объем дискового пространства, поэтому здесь лучше указать на диск, где достаточно для этого места
  • Общий буфер обмена — настройка использования буфера обмена между host-системой и гостевой ОС
  • Мини тулбар — консоль для управления виртуальной машиной

Вкладка Система — Материнская плата

  • Порядок загрузки — определяет порядок загрузки гостевой ОС. Советую после установки изменять этот порядок и поставить жесткий диск на первое место (если конечно загрузка с других носителей не так важна для Вас)
  • Выключить IO APIC — расширенный контроллер прерываний используемый в процессорах от Intel . Полностью поддерживается ОС Windows .
  • Включить EFI EFI определяет «загрузочные сервисы», которые включают поддержку текстовой и графической консоли на различных устройствах, шин, блоков и файловых сервисов, и runtime-сервисы, например дата, время и энергонезависимая память. Используется рядом ОС для загрузки.

Вкладка Система — Процессор

  • Процессор(ы) — настроить количество процессоров используемых виртуальной машиной. «Обратите внимание, что это опция будет доступна только при условии поддержки аппаратной виртуализации AMD-V или VT-x вкладка Система — Ускорение , а также включенной опции OI APIC на вкладке Система — Материнская плата .
  • Включить PAE/NX — режим работы встроенного блока управления памятью x86-совместимых процессоров, в котором используются 64-битные элементы таблиц страниц (из которых для адресации используются только 36 бит), c помощью которых процессор может адресовать 64 ГБ физической памяти (вместо 4 ГБ, адресуемых при использовании 32-разрядных таблиц).

Вкладка Система — Ускорение

  • Включить VTx/AMD-V — использование аппаратной виртуализации основного процессора (Ваш процессор должен поддерживать эти режимы или их нужно включить в BIOS )
  • Включить Nested Paging Nested Paging обеспечивает транслирование физических адресов памяти гостевой ОС в физические адреса памяти основной ОС

Вкладка Носители

  • В данной вкладке можно настроить использование внешних носителей и CD/DVD-дисков. Замечу, что Вы можете использовать виртуальные диски при установке гостевой ОС. Это очень удобно. Добавить их можно через Менеджер виртуальных носителей в котором можно хранить большое количество разных образов и переключаться между ними во время сеанса работы в гостевой системе. Вызвать этот менеджер можно следующим образом:

Менеджер виртуальных дисков в VirtualBox

Вкладка Сеть

  • Настройки сети будут рассмотрены в отдельной статье; В Windows XP существуют драйверы только для Pcnet-Fast III (Am79C973) , поэтому его и нужно выбрать.

Вкладка COM-порты

  • На этой вкладке можно насторить использование COM-портов. Сейчас они редко используются, поэтому вряд ли кому-то нужно будет их настраивать

Вкладка USB

  • Здесь нужно добавить в список те USB -контроллеры, которые будут использоваться виртуальными системами. Будьте осторожны, при запуске виртуальной системы, указанные USB -устройства перестают работать в основной (по крайней мере у меня так было)

Вкладка Общие папки

  • Общие папки предназначены для обмена файлами между основной и гостевой ОС

Настройка установленной гостевой ОС Windows XP в VirtualBox

Нам нужно установить драйверы для всех виртуальных аппаратных компонентов нашего виртуального ПК. Это можно сделать установив дополнения:

Запустится мастер установки дополнений, если Вы включили поддержку 3D , то нужно указать это поставив флажок. На все предупреждение системы отвечайте утвердительно. После установки дополнений в виртуально ОС должен заработать Интернет.

Режим интеграции дисплеев

Очень полезный режим, позволяет управлять виртуальной системой прямо в основной, без переключения в окно виртуальной машины. Поистине невероятный функционал! Попробуйте и Вы все поймете. Для переключения в этот режим используется сочетания клавиш HOST + L , где «HOST» — это host-клавиша (по умолчанию правый «Ctrl»).

Использованные понятия и определения

Виртуальная машина (ВМ, от англ. virtual machine) — программная и/или аппаратная система, эмулирующая аппаратное обеспечение некоторой платформы и исполняющая программы для этой платформы (target - целевая или гостевая платформа) на другой платформе (host - хост-платформа, платформа-хозяин)

Эмуляция (англ. emulation) - воспроизведение программными или аппаратными средствами либо их комбинацией работы других программ или устройств.

Гипервизор (или Монитор виртуальных машин ) - в компьютерах программа или аппаратная схема, обеспечивающая или позволяющая одновременное, параллельное выполнение нескольких или даже многих операционных систем на одном и том же хост-компьютере. Гипервизор также обеспечивает изоляцию операционных систем друг от друга, защиту и безопасность, разделение ресурсов между различными запущенными ОС и управление ресурсами.

Гостевая ОС — операционная система установленная на виртуальную машину.

Host-система — операционная систем в которой работает виртуальная машина.

Источники информации

  1. VirtualBox.org — официальная страница виртуальной машины VirtualBox
  2. Категория:Виртуализация на ru.wikipedia.org
  3. Установка и настройка платформы виртуализации Oracle VM VirtualBox — статья Виктора Краснухина на сайте OSzone.net

Цель: Создать виртуальную машину, выделить ресурсы, подключить диски и подготовить к установке операционной системы

В мы установили виртуальную машину на Windows 7. Сейчас подготовим нашу машину к установке ОС Windows XP SP3. Подключим виртуальный жесткий диск, выделим оперативную память, видеопамять, создадим привод оптических дисков.

Итак, запускаем Oracle VM VirualBox.

Мы видим окно приветствия с подсказкой для дальнейших действий.

Жмем кнопку «Создать»

В появившемся окне указываем следующее:

Имя: WinXP SP3 (т.к. мы будем устанавливать ОС Windows XP SP 3)

Тип : Microsoft Windows

Версия : Windows XP

Жмем «Next»


Теперь выделим объем оперативной памяти для работы машины. Внимание!!! Это важный параметр влияющий на работу виртуальной машины, а так же на работу всего ПК. Если выделить мало памяти, то возможно запуск системы на виртуальной машине не произойдет, завершится ошибкой. Так же, следует иметь ввиду, что при запуске машины у системы резервируется весь объем выделенной памяти т.е. если у Вас на ПК установлено 4Гб ОЗУ, виртуальной машине выделено 2ГБ, то при запуске последней, будет занято сразу 2ГБ, а основной системе остается только 2Гб.

Для работы с ОС Windows XP SP3 нам вполне достаточно 1Гб, максимум 1,5Гб (в игры на ней не стоит играть:)). С помощью ползунка указываем 1024мб (или вводим с клавиатуры в выделенное окошко. Жмем «Next»

На данном этапе нам предлагается создать виртуальный жесткий диск т.е. полнофункциональный HDD на который будет установлена ОС. Не бойтесь! В основной системе ничего не изменится, просто появится файл с указанным нами размером. Т.к. у нас нет созданных ранее дисков, то оставляем переключатель в положении «Создать новый виртуальный жесткий диск» и жмем «Создать».

Следующее окно нам предлагает выбор типа создаваемого жесткого диска. Т.к. мы планируем в дальнейшем работать только в VM VirtualBox, то оставляем тип по умолчанию «VDI (VirtualBox Disk Image)». Жмем «Next»

На данном этапе укажем, что виртуальный жесткий диск у нас будет фиксированного размера, это значит что будет создан файл указанного нами размера. Если указать «динамический», то в этом случае будем задавать пределы минимального и максимального размера. Файл будет «раздуваться по мере работы с виртуальной машиной». Рекомендую указать фиксированный размер во избежание проблем в дальнейшем.

И заключительный этап, выбираем диск и каталог для сохранения файла нашего виртуального жесткого диска, указываем размер. Для WinXP SP3 вполне хватит 10Гб, Вы можете указать больше. Жмем «Создать» . Через некоторое время виртуальный диск будет создан.

Если все прошло успешно, то результат должен выглядеть как на скриншоте. На этом пока все.

В следующих статьях мы продолжим настройку виртуальной машины и затем перейдем к установке Windows XP.

Что такое Виртуальная машина и зачем она нужна?

Виртуальная машина - программная среда, которая на вашем компьютере создает другой «реальный компьютер» (с другой операционной системой). На виртуальную машину, так же как и на реальный компьютер, устанавливается операционная система (может быть установлена любая ОС – Win, Linux и др. подходящая под разрядность машины), у виртуальной машины также есть BIOS, жесткий (-е) диски (HDD диски виртуальны т.е. весь диск выглядит одним файлом на физическом HDD), оперативная память, могут эмулироваться периферийные устройства. На одном компьютере может быть создано несколько виртуальных машин одновременно, кол-во зависит от физических ресурсов реального ПК.

Зачем нужна виртуальная машина? Где ее применять?

  • Для защиты информации и ограничения возможностей процессов т.е. можно запустить зараженный файл и будет повреждена только виртуальная машина, основная ОС будет цела и невредима;
  • Для изучения ПО и его настройки;
  • Для эмуляции различных архитектур (например, эмулятор игровой приставки);
  • Для моделирования информационных систем с клиент-серверной архитектурой на одном ПК (создание компьютерной сети с помощью нескольких виртуальных машин);
  • Для упрощения управления кластерами - виртуальные машины могут просто мигрировать с одной физической машины на другую во время работы;
  • Для тестирования своих приложений на различных ОС (например, тестирование на Windows XP, Windows Vista, Windows 7, 8 и т.д.)
  • Если Вы или кто-то из пользователей ПК «заговоренные» т.е. при выходе в инет обязательно поймаете «трояна» или «блокиратор» , то тоже как вариант можно использовать виртуальную машину:)

Здесь описаны некоторые стороны применения, список можно продолжать и дальше. Достаточно болтовни, приступим к делу…

Шаг 1. Подготовка

Программ, создающих виртуальные машины, очень много. Я же остановил свой выбор на Oracle VM VirtualBox. Для реализации моих целей эта машина меня полностью устраивает и главное преимущество – она бесплатна . Установочный дистрибутив программы Вы можете взять с официального сайта дистрибутив на примере которого создан этот и последующие уроки. После того как Вы скачали дистрибутив переходим к шагу 2.

Шаг 2. Запуск дистрибутива VirtualBox

Запускаем скаченный файл установки VirtualBox-4.х.х-Win.exe и жмем Next>

В следующем окне оставляем все по умолчанию. Если Вы хотите установить VirtualBox в другую папку, то нажмите кнопку “Browse ” и укажите свой каталог, но рекомендуется оставить по умолчанию. Жмем Next>

В следующем окне предлогают выбор, где создавать ярлыки на запуск VirtualBox.

  1. “Create a shortcut on the desktop” – создать ярлык на рабочем столе
  2. “Create a shortcut in the Quick Launch Bar” – создать ярлык в панели быстрого запуска

Включаем или отключаем создание ярлыков и жмем Next>

Следующее пугающее окно предупреждает нас о том что, при установке Oracle VM VirtualBox будут сброшены все сетевые подключения. Причина, будет производится установка виртуального сетевого оборудования для связи нашей машины с сетью. Соглашаемся нажав «Yes»


И еще одно окно в котором просят подтверждения на уставноку. Жмем «Install»


Дожидаемся окончания установки. При установке VirtualBox на Windows 7 должны появляться окна «Безопасность Windows» . На всех жмем «Установить» . Что бы сообщения не «замучили» можно поставить галочку «Всегда доверять программному обеспечению Oracle… »

И в конце установки будет выдано сообщение об успешном завершении установки. Галочка «Start Oracle VM Virtualbox v.4.2.10 after installation» означает, что при завершении установки будет произведен запуск приложения.

Жмем «Finish»

На этом установка Oracle VM VirtualBox завершена. По настройке и подготовке к установке ОС будет рассказано в следующих статьях.


Автор: Robin Catling
Дата публикации: май 2012 г.
Перевод: Семененко В.
Дата перевода: 5 октября 2012 г.

Все началось с того, что однажды мне потребовалось запустить экземпляр CMS Wordpress в песочнице. Начало было простым. Достаточно было создать виртуальный сервер Ubuntu 11.10 в качестве гостевой операционной системы на VirtualBox. Но затем я обнаружил, что я знаю гораздо меньше о сетях и их настройке, чем я думал до этого. В частности, о пакетах, коммутаторах и маршрутизаторах. Еще меньше я знал о настройке сетей в VirtualBox, где все аппаратное обеспечение представлено в программном виде. Несколько попыток и неудачных настроек сети, достигнутая цель - и как результат, представляю вам эту статью. Целью ее является сберечь ваши нервы на основе моих собственных проб и ошибок.

Сетевые настройки VirtualBox

Для начала установите любую версию виртуальной машины VirtualBox, начиная с 3.0. И вы найдете в ней примерно одинаковые возможности по сравнению с теми, что описываются в данной статье.

После установки программы перейдите в меню "Настройки - Сеть". Вид открываемой вкладки соответствует настройкам по умолчанию. Любая из виртуальных машин может быть настроена на использование четырех сетевых адаптеров - в зависимости от того, какой вам необходим в конкретном случае. Но чаще всего на практике требуется только один из них. Как правило, при установке виртуальной машины, по умолчанию создается простой сетевой адаптер. Этого достаточно для выхода в Интернет.

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

Для моего web-сервера с запущенным на нем CMS Wordpress дела обстоят несколько сложнее, поэтому идем дальше... Вкладка "Тип адаптера" отвечает за настройку виртуального аппаратного обеспечения. VirtualBox прекрасно справляется с ролью связующего звена между программной сетевой платой и тем физическим интерфейсом, который установлен на реальной машине (хосте). Откройте ссылку "Дополнительно" и вам будут доступны расширенные возможности сетевого адаптера. В этой статье я детально опишу все настройки в порядке их следования, начиная с установки типа адаптера.

Тип адаптера (Adapter Type)

Виртуальная машина VirtualBox имеет встроенную программную эмуляцию большинства наиболее распространенных типов сетевых карт, под которые созданы драйвера и протоколы. Карта PCnet-FAST III является выбором по умолчанию, однако в своей практике я часто выбираю Intel PRO/1000MT. Я поступаю так, если мне необходима наилучшая совместимость с "железом" от Intel, которое установлено на моем компьютере. Если у вас возникнут проблемы в настройке сетевого соединения, можно попробовать изменить тип адаптера, выбрав другой. Для наиболее древнего оборудования подойдет сетевая карта PCnet-FAST II.

Режим (Mode)

Довольно странно звучащий "Неразборчивый режим" (Promiscuous Mode) обычно применяется для работы VM в качестве виртуального маршрутизатора в локальных сетях; как сетевой мост или же хост. В этом режиме порт виртуальной машины способен принимать любые пакеты, отправляемые для других операционных систем; и даже для хоста. То есть, принимаются сетевые пакеты, предназначенные не только для этого адаптера, но и для других сетевых устройств. В 99% случаев обычным пользователям "Неразборчивый режим" не нужен. Он используется сетевыми администраторами для диагностики проблем, возникающих в сети.

MAC адрес (MAC Address)

MAC-адрес (MAC - аббревиатура от Media Access Control) является уникальным "именем" устройства в сети, однозначно идентифицирующим и отличающим его от остальных адаптеров и узлов. Этот адрес прописывается для каждого сетевого устройства на физическом уровне в памяти самого интерфейса. При создании виртуального сетевого адаптера VirtualBox автоматически генерирует для него MAC-адрес.
Если необходимо изменить уже имеющийся MAC-адрес, то для этого служит небольшая кнопка справа, которая генерирует новое значение. В случае клонирования существующей виртуальной машины, для нее необходимо создать свой собственный уникальный MAC-адрес, который будет отличаться от адреса оригинальной машины.

Галочка напротив надписи "Кабель подключен" выполняет ту же роль, что и подключение или отключение физического кабеля в реальности. Эта настройка отвечает за подключение виртуального сетевого адаптера к сети. Не стоит путать ее с другой более важной настройкой "Включить сетевой адаптер", которая включает или выключает сам адаптер на виртуальной машине.

Кнопка "Проброс портов" открывает диалоговое окно, в котором производится настройка правил поведения трафика на конкретном адаптере; каким образом будет перемещаться трафик определенного типа между хостом и гостевой виртуальной машиной. Эти правила применяются к сетевым моделям, которые будут рассмотрены немного позже. Сами сетевые модели определяются на вкладке "Тип подключения". Эта настройка является наиболее сложным моментом в установке соединений в VirtualBox. Она доставила мне наибольшие проблемы в экспериментах.

"Подводные камни"

Существуют четыре типа сетевых моделей подключения и большое количество возможных комбинаций настроек этих подключений. В этом плане создание сети в VirtualBox похоже на средневековую алхимию - настолько здесь все запутано и нелогично. Казалось бы, если следовать правильным настройкам, то вы достаточно просто получите нужный результат. Однако, имеется несколько решений одной задачи, которые изначально все будут правильными. Но в конечном итоге приведут к тому, что вы не достигнете поставленной цели. Поверьте мне, уж я знаю...

Типы подключения к сети

В VirtualBox имеются четыре готовые модели для подключения к сети:

  • Трансляция сетевых адресов (NAT), которая является настройкой по умолчанию
  • Сетевой мост (Bridged)
  • Виртуальный адаптер хоста (Host Only)

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

Трансляция сетевых адресов (NAT)

Протокол NAT позволяет гостевой операционной системе выходить в Интернет, используя при этом частный IP, который не доступен со стороны внешней сети или же для всех машин локальной физической сети. Такая сетевая настройка позволяет посещать web-страницы, скачивать файлы, просматривать электронную почту. И все это, используя гостевую операционную систему. Однако извне невозможно напрямую соединиться с такой системой, если она использует NAT.

Принцип трансляции сетевых адресов заключается в следующем. Когда гостевая ОС отправляет пакеты на конкретный адрес удаленной машины в сети, сервис NAT, работающий под VirtualBox, перехватывает эти пакеты, извлекает из них сегменты, содержащие в себе адрес пункта отправки (IP-адрес гостевой операционной системы) и производит их замену на IP-адрес машины-хоста. Затем заново упаковывает их и отправляет по указанному адресу.

Например, в вашей домашней локальной сети хост и другие физические сетевые устройства имеют адреса в диапазоне, начинающемся с 192.168.х.х. В VirtualBox адаптеры, работающие по протоколу NAT, имеют IP-адреса в диапазоне, начинающемся с 10.0.2.1 и заканчивающемся 10.0.2.24. Такой диапазон называется под-сетью. Как правило, этот диапазон не используется для присвоения адресов устройствам в основной сети, поэтому такая система недоступна извне, со стороны хоста. Гостевая ОС может выполнять обновление программного обеспечения и web-серфинг, но остается невидимой для остальных "участников".

В руководстве VirtualBox этот момент описан более подробно:

"В режиме NAT гостевому сетевому интерфейсу присваивается по умолчанию IPv4 адрес из диапазона 10.0.х.0/24, где х обозначает конкретный адрес NAT-интерфейса, определяемый по формуле +2. Таким образом, х будет равен 2, если имеется только один активный NAT-интерфейс. В этом случае, гостевая операционная система получает IP-адрес 10.0.2.15, сетевому шлюзу назначается адрес 10.0.2.2, серверу имен (DNS) назначается адрес 10.0.2.3." (Oracle Corporation, 2012, Глава 9).

Протокол NAT полезен в том случае, когда нет разницы в том, какие IP-адреса будут использовать гостевые ОС на виртуальной машине, поскольку все они будут уникальными. Однако, если потребуется настроить перенаправление сетевого трафика, или же расширить функциональность гостевой ОС, развернув на ней web-сервер (к примеру), то необходимы дополнительные настройки. В режиме NAT также недоступны такие возможности, как предоставление общего доступа к папкам и файлам.

Сетевой мост (Bridged)

В соединении типа "Сетевой мост" виртуальная машина работает также, как и все остальные компьютеры в сети. В этом случае адаптер выступает в роли моста между виртуальной и физической сетями. Со стороны внешней сети имеется возможность напрямую соединяться с гостевой операционной системой.

Адаптер в режиме "Сетевой мост" подключается, минуя хост, к устройству, которое распределяет IP-адреса внутри локальной сети для всех физических сетевых карт. VirtualBox соединяется с одной из установленных сетевых карт и передает пакеты через нее напрямую; получается работа моста, по которому передаются данные. Как правило, адаптер в модели "Сетевой мост" получает стандартный адрес из диапазона 192.168.х.х от роутера. Поэтому виртуальная машина в сети выглядит так, как будто это обычное физическое устройство, неотличимое от остальных.

На хосте могут быть активными одновременно несколько сетевых устройств; например, на моем ноутбуке имеется проводное подключение (называемое eth0) и беспроводное подключение (называемое wlan0). Поле "Имя" позволяет выбрать, какой из сетевых интерфейсов вы бы хотели использовать в качестве моста на VirtualBox.

В моем случае, я использую беспроводной адаптер wlan0 , так как он подключен к маршрутизатору. В то время как проводной интерфейс eth0 не имеет даже кабеля.

Поэтому моему хосту назначен роутером IP-адрес 192.168.0.2. Виртуальной машине в режиме "Сетевой мост" присвоен адрес 192.168.2.6. При этом не имеет значения тот факт, что VirtualBox передает и получает трафик как бы "сквозь" хост, минуя его. В результате получается, что виртуальная машина становится просто еще одним компьютером в локальной сети. Если я пересчитаю свой компьютер и три виртуальные машины (VM), работающие в режиме "Сетевой мост", то у меня получиться четыре компьютера в физической локальной сети.

Дальше - больше...

Протокол NAT полезен, потому что он защищает гостевые операционные системы со стороны Интернет. Но для того, чтобы получить доступ к ним извне (а на некоторых ОС у меня имеются установленные web-сервера), потребуется дополнительная настройка для перенаправления трафика. Тип подключения "Сетевой мост" позволяет получить доступ к ним, но системы в этом случае становятся незащищенными.

Если ваше сетевое устройство доступа (это может быть маршрутизатор, сетевой коммутатор или же настройки, предоставленные Интернет-провайдером) позволяет предоставлять только один IP-адрес для сетевого интерфейса, возможно, вам не удастся настроить "Сетевой мост".

Виртуальный адаптер хоста (Host-only)

При подключении типа "Виртуальный адаптер хоста" гостевые ОС могут взаимодействовать между собой, а также с хостом. Но все это только внутри самой виртуальной машины VirtualBox. В этом режиме адаптер хоста использует свое собственное, специально для этого предназначенное устройство, которое называется vboxnet0 . Также им создается под-сеть и назначаются IP-адреса сетевым картам гостевых операционных систем. Гостевые ОС не могут взаимодействовать с устройствами, находящимися во внешней сети, так как они не подключены к ней через физический интерфейс. Режим "Виртуальный адаптер хоста" предоставляет ограниченный набор служб, полезных для создания частных сетей под VirtualBox для ее гостевых ОС.

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

Как правило, хост имеет свой собственный сетевой адрес, который используется для выхода в Интернет. Обычно это 192.168.0.101. В режиме "Виртуальный адаптер хоста" машина-хост также выступает в роли роутера VirtualBox и обладает IP-адресом по умолчанию 192.168.56.1. Создается внутренняя локальная сеть, обслуживающая все гостевые операционные системы, настроенные для режима "Виртуальный адаптер хоста" и видимые для остальной части физической сети. Адаптер vboxnet0 использует адреса из диапазона, начинающегося с 192.168.56.101. Но при желании можно изменить адрес по умолчанию.

Подобно адаптеру в режиме "Сетевой мост", в режиме "Виртуальный адаптер хоста" используются разные диапазоны адресов. Можно легко настроить гостевые системы для получения IP-адресов, используя для этого встроенный DHCP-сервер виртуальной машины VirtualBox.

В дополнение нужно сказать, что в режиме "Виртуальный адаптер хоста" созданная им сеть не имеет внешнего шлюза для выхода в Интернет, как для хоста, так и для гостевых операционных систем. Он работает только как обычный сетевой коммутатор, соединяя между собой хост и гостевые системы. Поэтому адаптер в режиме "Виртуальный адаптер хоста" не предоставляет гостевым машинам выход в Интернет; vboxnet0 по умолчанию не имеет шлюза. Дополнительные возможности для этого адаптера значительно упрощают настройку сети между хостом и гостевыми ОС, однако все же отсутствует внешний доступ или перенаправление портов. Поэтому может потребоваться второй адаптер в режиме "Виртуальный адаптер хоста" или "Сетевой мост", который подключается к гостевой операционной системе для получения полного доступа к ней.

Внутренняя сеть (Internal Network)

Если на практике вам потребуется настроить взаимосвязь между несколькими гостевыми операционными системами, работающими на одном хосте и могущими сообщаться только между собой, тогда можно воспользоваться режимом "Внутренняя сеть". Конечно, для этой цели можно использовать режим "Сетевой мост", но режим "Внутренняя сеть" обладает большей безопасностью. В режиме "Сетевой мост" все пакеты отправляются и получаются через адаптер физической сети, установленный на машине-хосте. В этом случае весь трафик может быть перехвачен (например, путем установки сниффера пакетов на машине-хосте).

Внутренняя сеть, согласно руководству VirtualBox, является "программной сетью, которая может быть видима для выборочно установленных виртуальных машин, но не для приложений, работающих на хосте или на удаленных машинах, расположенных извне". Такая сеть представляет из себя набор из хоста и нескольких виртуальных машин. Но ни одно из вышеперечисленных устройств не имеет выхода через физический сетевой адаптер - он полностью программный, используемый VirtualBox в качестве сетевого маршрутизатора. В целом получается частная локальная сеть только для гостевых операционных систем без доступа в Интернет, что делает ее максимально безопасной. Возможное применение такой сети - сверхсекретный сервер с клиентами, предназначенный для разработки; тестирование систем на проникновение или какие-либо другие цели, преследующие создание внутренней сети для команд-разработчиков или организаций. Это идеальный способ для блокировки окружения от неавторизованной установки программного обеспечения, скачивания или закачивания файлов, посещения сервисов типа Facebook в рабочее время.

Итак, мы рассмотрели различные типы сетевых соединений. Каждый из них имеет свои собственные настройки и предназначен для определенных целей. Вернемся к тому моменту, откуда все началось - создание виртуального сервера для развертывания на нем CMS Wordpress и его тестирования.

Доступ к гостевой операционной системе

Во-первых, мне нужен доступ в Интернет из гостевой системы для установки обновлений, скачивания пакетов и других подобных задач. Мне также необходим доступ к Сети с машины-хоста. Но мне не нужно, чтобы сервер был доступен из внешней сети.

Выбираю необходимую виртуальную машину из менеджера VirtualBox и затем перехожу в меню "Настройки - Сеть".

Оставляю выбранным по умолчанию сетевой адаптер в режиме NAT. Это позволит гостевым системам выходить в Интернет через настроенное соединение хоста, на котором установлены эти машины. Гостевые системы не видны извне в локальной сети; я также не имею доступа к любой из гостевых систем со стороны хоста; аналогично, гостевые системы не могут взаимодействовать между собой.

Настройка виртуального адаптера хоста

Самый простой способ - это использовать адаптер в режиме "Виртуальный адаптер хоста", предоставляемый VirtualBox по умолчанию. Он имеет имя vboxnet0 . Можно добавить столько адаптеров подобного типа, сколько нужно (если есть необходимость в настройке нескольких отдельных сетей типа "Виртуальный адаптер хоста"). Открыв основное окно менеджера гостевых операционных систем VirtualBox, и выбрав в меню "Настройки - Сеть", вы можете конфигурировать существующий адаптер vboxnet0 или создать еще несколько подобных (vboxnet1 , vboxnet2).

Щелкните мышью на кнопке "Редактировать" - иконка с изображением отвертки (третья по счету сверху вниз). Щелчок на этой иконке откроет настройки по умолчанию. В них адрес 192.168.56.1 является тем адресом, по которому гостевые системы получают доступ к хосту. Я оставил его "как есть", не меняя.

По умолчанию, адаптер vboxnet0 динамически получает IP адрес во время сессии подключения от DHCP-сервера. Для моего виртуального web-сервера Wordpress необходимо, чтобы он имел статический IP-адрес. Поэтому на вкладке "DHCP сервер" я убрал галочку с надписи "Включить сервер". Таким образом, DHCP-сервер у меня отключен.

Добавление виртуального адаптера хоста

Я собираюсь добавить еще один сетевой адаптер (в режиме "Виртуальный адаптер хоста") к гостевой машине, что позволит создать самодостаточную частную виртуальную сеть. Эта сеть будет состоять только из хоста и любой гостевой операционной машины, настроенной в режиме "Виртуальный адаптер хоста".

Поэтому в настройках гостевой системы я открываю вкладку "Адаптер 2" и устанавливаю значение "Тип подключения" в положение "Виртуальный адаптер хоста". По умолчанию, вновь созданному адаптеру присваивается имя vboxnet0 . "Неразборчивый режим" для меня не имеет значения, поэтому оставляю его в значении "Запретить". Надпись "Кабель подключен" я также оставляю активной.

Настройка гостевой системы

Мне необходимо, чтобы гостевой виртуальный сервер имел статический IP-адрес в сети, работающей в режиме "Виртуальный адаптер хоста". Иначе адрес сервера будет меняться от сессии до сессии, каждый раз при подключении. Я буду вынужден снова и снова решать задачу настройки, чтобы соединиться с хостом. Поэтому захожу в гостевую систему, открываю в ней терминал и ввожу в нем две следующие команды:

Ifconfig eth1 192.168.56.101 netmask 255.255.255.0 up

Эти действия устанавливают указанный IP-адрес для адаптера, расположенного в гостевой системе и запускают этот сетевой интерфейс. В этом адресе используется сетевой префикс 192 для домашних сетей, затем следует.168 в качестве начального адреса хоста ID, .56 для установки диапазона адресов под-сети; и наконец, финальный идентификатор.1 (хост) для сети. Адаптер в режиме NAT имеет имя eth0 , поэтому логично предположить, что адаптер в режиме "Виртуальный адаптер хоста" имеет имя eth1 . Я могу использовать этот IP-адрес для тестирования гостевой системы из хоста через протокол SSH или браузер.

Однако, эти настройки являются временными. Если я произведу перезагрузку системы, все они бесследно пропадут. Для того, чтобы установить их постоянными, нужно добавить (используя учетную запись root) в файл /etc/network/interfaces следующие строки:

# The host-only network interface auto eth1 iface eth1 inet static address 192.168.56.101 netmask 255.255.255.0 network 192.168.56.0 broadcast 192.168.56.255

Теперь, при перезагрузке, этот сетевой интерфейс запустится автоматически. Для проверки - запустился ли он, я использую команду ifconfig , которую ввожу в терминале гостевой операционной системы.

Присвоение имен

Так как я не слишком "дружу" с числами и IP-адресами, то для себя я всегда использую имена для гостевых систем вместо присвоения им IP-адресов. Для этого я редактирую файл /etc/hosts на машине-хосте и добавляю туда ссылки. Таким образом, я могу просматривать запущенные гостевые системы по их именам.

В файл /etc/hosts я добавляю строку:

192.168.56.101 ocelotsvr

Если я добавляю еще несколько гостевых систем с сеть, то мне достаточно отредактировать этот файл и дописать нужное количество строк. Благодаря такому приему я легко могу обратиться к любой из этих систем.

Альтернативный маршрут

Эксперты сетевых технологий могут заметить, что в моей конфигурации существует альтернативный маршрут для доступа к виртуальному серверу.

Используя адаптер по умолчанию, работающий по протоколу NAT, можно запустить дополнительную конфигурацию, которая позволит мне получить доступ к виртуальному серверу с хоста, не используя при этом сетевую настройку "Виртуальный адаптер хоста".

Используя панель настроек "Сетевой адаптер" в гостевой операционной системе, можно настроить проброс портов в виртуальной машине VirtualBox. Для этого переходим к настройкам адаптера NAT (кнопка внизу окна) для настройки перенаправления портов. При нажатии на нее откроется диалоговое окно, в котором настраиваются правила проброса для данного сетевого адаптера и гостевой системы.

Мне необходимо настроить два правила; одно для получения доступа к web-серверу Apache на гостевой системе, второе - для регулирования всего остального TCP-трафика (в большинстве это http-запросы).

Не мудрствуя лукаво, я назвал эти правила Apache и TCP, соответственно; оба используют TCP-протокол. Если говорить о привязке номеров портов, то порт 8888 на хосте перенаправляет трафик на гостевую систему для сервера Apache; порт 2222 на хосте перенаправляет трафик на порт 22, расположенный на гостевой операционной системе; такая настройка предоставляет мне доступ к гостевой системе для управления ее службами. Любой другой трафик будет отклонен виртуальной машиной, как не подпадающий под правила.

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

Посмотрело: 236354

4

Настройка Host-части VirtualBox:
В качестве host-системы в данном случае выступает операционная система Windows 7, а качестве гостевой Windows Server 2008 R2 . Как и в предыдущей статье, рассматриваться будет платформа VirtualBox-4.1.14.

В настройках приложения VirtualBox через меню «Файл» открываем вкладку «свойства», «Сеть», и производим следующие действия:

Сначала выставляем IPv4-адрес и IPv4-маску подсети:

Затем включаем DHCP-сервер (независимо от того, статический или динамический IP-адрес Вашего реального сетевого адаптера):

Адрес сервера должен находиться в диапазоне адресов реальных адаптеров, IPv4-маска подсети должна соответствовать маске, используемой реальным адаптером, верхняя и нижняя границы адресов должны захватывать все адреса, используемые в системе.

В графе "Тип подключения", в ниспадающем меню, нужно выбрать необходимое подключение.

Для каждой сетевого интерфейса возможно указать в каком из следующих режимов они будут функционировать:

Не подключен

В этом режиме, VirtualBox сообщает гостю что сетевой адаптер есть, но он не подключен -- так как если бы Ethernet кабль не присоединен к карте. Таким образом возможно симулировать "выдергивание" кабеля из виртуальной сетевой карты и обрыв соединения,что может быть полезно для информирования гостевой ОС об отсутствии сетевого соединения, но возможности его настройки.

Network Address Translation (NAT)

NAT - наипростейший способ предоставить гостевой ОС доступ в интернет, при таком режиме осуществляется просто перенаправление (транзакции) пакетов

Если вам нужно просматривать Web, загружать файлы и пользоваться почтой e-mail в гостевой системе, то данная сетевая конфигурация по умолчанию подойдет вам и вы может пропустить чтение этого раздела.

Сетевой мост

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

Внутренняя сеть

Этот режим можно использовать для создания виртуальной сети которая доступна из виртуальной машины, но не для приложений запущенных на хосте или других внешних сетевых устройств.

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

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

Универсальный драйвер

Редко используемый режим универсального сетевого интерфейса (Rarely used modes share the same generic network interface), позволяет выбирать пользователю драйвер, который может быть включен в VirtualBox или поставляться с пакетом расширений (extension pack).

В данное время доступны два подтипа:

UDP тунель

Можно использовать для простого и прозрачного прямого соединения виртуальных машин работающих на разных хостах, через существующую сетевую инфраструктуру.
VDE (Virtual Distributed Ethernet) сеть

Позволяет использовать Virtual Distributed Ethernet коммутатор на Linux или FreeBSD хосте. В данный момент, для его использования требуется сборка VirtualBox из исходных кодов, т.к. в дистрибутив Oracle он не включен.

Так как для нормального функционирования Windows Server необходим статический ip, мы можем выбрать "сетевой мост" или "виртуальный адаптер хоста".
Рассмотрим "сетевой мост":

После того, как мы выбрали тип подключения: Сетевой мост, в графе " имя " мы можем выбрать необходимое подключение.
Так как у меня интернет раздаеться через адаптер минипорта виртуального Wi-Fi, я выбрал его.

Выбираем: протокол интернета версии 4(ТСР/IPv4) и нажимаем свойства:

Здесь выставляем IP-адрес маску и шлюз.
Так как у моего реального адаптера IP-адрес назначен 192.168.137.1 , я назначаю этот адрес шлюзом, а IP-адрес назначаю 192.168.137.2.
Далее OK , закрыть.
Для того чтобы удостовериться, что подключение к Интернету действительно активно, снова откроем окно командной строки и выполним команду ping для узла



Рекомендуем почитать

Наверх