Оглавление
VBoxSDL это простой графический интерфейс пользователя (GUI) из которого исключены графические элементы управления имеющиеся в VirtualBox. В настоящее время VBoxSDL используется в первую очередь для внутренней отладки VirtualBox и поэтому официально не поддерживается. Однако, вы можете найти его полезным для использования в среде, где не требуется управление виртуальными машинами пользователям использующим эти машины.
VBoxSDL не доступен на хостах платформы Mac OS X.
Как вы можете видеть на следующей картинке, VBoxSDL предоставляет только простое окно которое отображает "чистую" виртуальную машину, без меню, управляющих элементов и индикаторов активности виртуальной машины:
Для запуска виртуальной машины с помощью VBoxSDL, без использования VirtualBox GUI, выполните в командной строке команду:
VBoxSDL --startvm <vm>
где <vm>
имя или UUID существующей ВМ.
Когда гостевая операционная система работает в полноэкранном режиме, то гостевая система получает контроль над всей рабочей зоной монитора. Это может приводить к некоторому риску, поскольку пользователь может спутать экраны гостевой и хост системы или поверх окна гостевой системы могут выводится диалоговые сообщения операционной системы хоста.
Для защиты пользователя от этих рисков, была разработана функция безопасносных меток. Данный функционал доступен в настоящее время только для VBoxSDL. При ее включении, часть области экрана выделяется для показа определяемых пользователем сообщений (меток). В VBoxSDL высота метки установлена в 20 пикселей . Цвет шрифта и фона могут быть произвольно установлены как шестнадцатеричные значения цвета RGB. Используется следующий синтаксис команды для включения маркеров безопасности:
VBoxSDL --startvm "VM name" --securelabel --seclabelfnt ~/fonts/arial.ttf --seclabelsiz 14 --seclabelfgcol 00FF00 --seclabelbgcol 00FFFF
Здесь дополнительно устанавливается также шрифт меток. Для указания другого размера шрифта(стандартный 12), используется параметр --seclabelsiz
.
Текст метки может быть установлен командой
VBoxManage setextradata "VM name" "VBoxSDL/SecureLabel" "The Label"
Эта команда приводит к немедленному изменению метки.
Как правило, разрешение полноэкранного режима ограничено "стандартным" размером 1024 x 768. Increasing this by twenty lines is not usually feasible, so in most cases, VBoxSDL will chose the next higher resolution, e.g. 1280 x 1024 and the guest's screen will not cover the whole display surface. If VBoxSDL is unable to choose a higher resolution, the secure label will be painted on top of the guest's screen surface. In order to address the problem of the bottom part of the guest screen being hidden, VBoxSDL can provide custom video modes to the guest that are reduced by the height of the label. For Windows guests and recent Solaris and Linux guests, the VirtualBox Guest Additions automatically provide the reduced video modes. Additionally, the VESA BIOS has been adjusted to duplicate its standard mode table with adjusted resolutions. The adjusted mode IDs can be calculated using the following formula:
reduced_modeid = modeid + 0x30
For example, in order to start Linux with 1024 x 748 x 16, the standard mode 0x117 (1024 x 768 x 16) is used as a base. The Linux video mode kernel parameter can then be calculated using:
vga = 0x200 | 0x117 + 0x30 vga = 839
The reason for duplicating the standard modes instead of only supplying the adjusted modes is that most guest operating systems require the standard VESA modes to be fixed and refuse to start with different modes.
When using the X.org VESA driver, custom modelines have to be
calculated and added to the configuration (usually in
/etc/X11/xorg.conf
. A handy tool to determine
modeline entries can be found at http://www.tkk.fi/Misc/Electronics/faq/vga2rgb/calc.html
.)
При переключения с одного виртуального X терминала (VT) на другой, с помощью клавиатурной комбинации Ctrl-Alt-Fx, в фокус ввода находится в окне VBoxSDL, гостевая система получает события нажатия клавиш Ctrl и Alt, но не получает полного события нажатия . Это архитектурное ограничение Linux. In order to reset the modifier keys, it is possible to send SIGUSR1
to the VBoxSDL main thread (first entry in the ps
list). For example, when switching away to another VT and saving the virtual machine from this terminal, the following sequence can be used to make sure the VM is not saved with stuck modifiers:
kill -usr1 <pid> VBoxManage controlvm "Windows 2000" savestate
Гостевые дополнения VirtualBox поставляются с модулями для Windows, Linux и Solaris позволяющие реализовать автоматический вход в гостевую систему.
В виртуальной машине существует возможность установить автоматический вход в гостевую ОС используя учетные данные гостя - мандат системы. (Говоря о "мандате", мы говорим о данных входа в систему: имя пользователя, пароль и доменное имя, где каждое значение может быть пустым).
Начина с Windows NT, Windows предоставляет модульную подсистему входа в систему ("Winlogon"), которая может быть настроена с помощью так называемых модулей GINA (Graphical Identification and Authentication). В Windows Vista и Windows 7, GINA модули были заменен новым механизмом, называемым "credential providers". Гостевые дополнения для Windows поставляются с обоими модулем (GINA и credential provider).
Для их активации нужно установить гостевые дополнения, используя командную строку с параметром /with_autologon
. Все шаги требующие установки этих модулей, выполняемые "вручную", выполняются инсталятром.
Для "ручной" установки модуля VirtualBox GINA, распакуйте гостевые дополнения (см. раздел “Ручная распаковка файла”) и скопируйте файл VBoxGINA.dll
в папку Windows SYSTEM32
. Затем в реестре создайте следующую запись ключа:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon\GinaDLL
с установленным значением VBoxGINA.dll
.
VirtualBox GINA реализован как обертка над стандартным модулем Windows GINA ( MSGINA.DLL
). Поэтому, существует возможность, что модуль не всегда будет правильно работать с модулями GINA сторонних разработчиков.
Для "ручной" установки модуля VirtualBox credential provider, распакуйте гостевые дополнения (см. раздел “Ручная распаковка файла”) и скопируйте файл VBoxCredProv.dll
в папку Windows SYSTEM32
. Затем в реестре создайте следующую запись ключа:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\ Authentication\Credential Providers\{275D3BCC-22BB-4948-A7F6-3A3054EBA92B} HKEY_CLASSES_ROOT\CLSID\{275D3BCC-22BB-4948-A7F6-3A3054EBA92B} HKEY_CLASSES_ROOT\CLSID\{275D3BCC-22BB-4948-A7F6-3A3054EBA92B}\InprocServer32
все значения по умолчанию, установите (ключ с именем (Default)
) в VBoxCredProv
. После этого будет создана новая строка
HKEY_CLASSES_ROOT\CLSID\{275D3BCC-22BB-4948-A7F6-3A3054EBA92B}\InprocServer32\ThreadingModel
с значением Apartment
.
Для применения мандата, используйте следующую команду запуска виртуальной машины:
VBoxManage controlvm "Windows XP" setcredentials "John Doe" "secretpassword" "DOMTEST"
Пока работает ВМ, мандат может быть запрошен модулем "автологона" VirtualBox с использованием драйвера устройства гостевых дополнений VirtualBox. Когда Windows находится в режиме "logged out" (нет пользователей вошедших в систему), модуль "автологона" постоянно запрашивает мандат и как только он будет установлен происходит попытка входа в систему. После получения мандата, модуль удаляет его, поэтому нужно будет повторить указанную выше команду для последующего входа в систему.
По соображениям безопасности, мандат не хранится постоянно и будет удален при перезагрузке ВМ. Так же мандат можно только записать, т.е. нет способа получить мандат со стороны хоста. Мандат можно сбросить установкой его параметров в пустые значения .
В зависимости от гостевой системы Windows, имеются следующие ограничения:
Для гостей Windows XP, подсистема входа должна быть настроена с использованием с классического диалога входа, т.к. VirtualBox GINA не поддерживает стиль XP диалога "добро пожаловать".
В Windows Vista и Windows 7 гостях, подсистема входа не поддерживает так называемую безопасную последовательность (Secure Attention Sequence) (CTRL+ALT+DEL
). Поэтому, групповая политика гостя должна быть настроена без использования безопасной последовательности. Кроме того, имя пользователся сравнивается только с истинным именем учетной записи, а не его пользовательским представлением. Это значит, что когда вы изменяете имя пользователя, то вы должны все равно передавать первоначальное имя пользователся (в нутри Windows никогда не переименовывает пользовательский аккаунт).
Обработка автовхода в встроеной службе удаленного рабочего стола Windows (называемой ранее терминальной службой) по умолчанию отключена. Для ее включения, необходимо задать значение ключа
HKEY_LOCAL_MACHINE\SOFTWARE\Oracle\VirtualBox Guest Additions\AutoLogon
с типом DWORD
в 1
.
Следующая команда заставляет VirtualBox сохранять мандат, после его получения гостем и сбросом ВМ:
VBoxManage setextradata "Windows XP" VBoxInternal/Devices/VMMDev/0/Config/KeepCredentials 1
Имейте ввиду, что это приводит к возникновению потенциальных рисков для безопасности.
Начиная с версии 3.2, VirtualBox поставляется с PAM модулем (Pluggable Authentication Module), который может выполнять автоматический вход в системы, которые используют эти модули. Фактически все современные Linux/Unix дистрибутивы используют PAM.
Сам модуль pam_vbox.so
не делает проверки учетных данных полученых гостевой ОС; вместо этого он использует другие модули, такие как pam_unix.so
или pam_unix2.so
. Поэтому pam_vbox.so
должен быть размещен в начале списка служб PAM .
pam_vbox.so
поддерживает только auth
. Другие элементы, account
, session
или password
не поддерживаются.
Модуль pam_vbox.so
поставляется с гостевыми дополнениями, но по умолчанию не устанавливается и не активируется в гостевой ОС. Для его установки, его нужно скопировать из /opt/VBoxGuestAdditions-<version>/lib/VBoxGuestAdditions/
в директорию PAM модулей - обычно /lib/security/
в 32-bit или /lib64/security/
в 64-bit гостях Linux . Пожалуйстя обратитесь к документации вашей гостевой ОС, для определения правильного расположения директории PAM модулей.
Например, что бы использовать pam_vbox.so
в Ubuntu Linux и GDM ( GNOME Desktop Manager) для автоматического входа в систему с использованием учетных данных передаваемых хостом, гостевая система должна быть настроена следующим образом:
Модуль pam_vbox.so
должен быть скопирован в директорию модулей безопасности, в данном случае в /lib/security
.
Отредактируйте файл настроек PAM для GDM /etc/pam.d/gdm
, вставив в начало строку auth requisite pam_vbox.so
. Дополнительно, во многих Linux дистрибутивах существует файл /etc/pam.d/common-auth
. Этот файл включается в настройки множества других служб (как и в файл упомянутой выше службы GDM). В него вы должны также добавить строку auth requisite pam_vbox.so
.
Для аутентификации через теневую базу паролей (shadow database) с помощью pam_unix.so
или pam_unix2.so
, нужно задать аргумент try_first_pass
для pam_unix.so
или use_first_pass
для pam_unix2.so
, если необходимо передать мандат от модуля irtualBox в модуль аутентификации теневой базы паролей. В Ubuntu, нужно добавить в конец файла /etc/pam.d/common-auth
, ссылку на pam_unix.so
. Данный аргумент сообщает PAM модулю, что использовать учетные данные, уже сохраненные в стеке системе, т.е. предаставляемых PAM модулем VirtualBox .
Неправильная настройка PAM может привести к невозможности входа в гостевую систему!
Для упрощения настроки, вы можете указать агрумент debug
в правой части строки pam_vbox.so
. Отладочные сообщения будут регестрироваться в журнале через syslog.
В настоящее время, менеджер GDM получает учетные данные только при запуске, поэтому если мандат не был предоставлен гостевой системе до его запуска, то автологон работать не будет. This limitation needs to be addressed by the GDM developers or another display manager must be used.
Начиная с Windows NT 4.0, Microsoft предоставляет инструмент "подготовки системы"("system preparation") (коротко: Sysprep) для подготовки развертывания Windows систем. Windows 2000 и XP поставляются с Sysprep на установочном носителе, а также этот инстумент доступен на веб сайте Microsoft. В Windows Vista и 7, Sysprep уже включен в стандартный установщик. Sysprep состоит из основной программы с именем sysprep.exe
, при запуске которой пользователь настраивает установщик Windows в режим подготовки.
Начиная с VirtualBox 3.2.2, гостевые дополнения предоставляют способ запустить подготовку системы в автоматическом режиме, которым управляет хост ситема. Ознакомтесь с разделом “Guest control” для использования этой функции, передав на выполнение как прогрумму специальный идентификатор sysprep
, используя для идентификации имя пользователя sysprep
и пароль sysprep
. В данном случае Sysprep запустится с нужнвми для этого правами.
Определить местоположение "sysprep.exe" не представляется возможным -- используйте следующие пути (в зависимости от гостевой ОС):
C:\sysprep\sysprep.exe
для Windows NT 4.0, 2000 и XP
%WINDIR%\System32\Sysprep\sysprep.exe
для Windows Vista, 2008 Server и 7
Гостевые дополнения автоматически будут использовать соостветствующий путь для запуска инструмента подготовки системы.
Гостевые дополнения VirtualBox содержат несколько различных драйверов. Если по каким либо причинам, вы не хотите устанавливать все, то вы можете запустить установку гостевых дополнений из командной строки:
sh ./VBoxLinuxAdditions.run no_setup
После этого, вам необходимо скомпилировать модули ядра, выпонив команду
/usr/lib/VBoxGuestAdditions/vboxadd setup
от пользователя root (необходимо заменитьlib на lib64 в некоторых 64bit гостях), а на гостевых системах без сервиса udev, вам нужно добавить vboxadd сервис в дефолтный runlevel, для гарантированой загрузки модулей.
Для установки службы синхронизации времени, запустите команду
/usr/lib/VBoxGuestAdditions/vboxadd-service setup
и добавте службу vboxadd-service в runlevel по умолчанию. Для установки модулей X11 и OpenGL , выполните
/usr/lib/VBoxGuestAdditions/vboxadd-x11 setup
(нет необходимости настройки запуска этих сервисов).
Для компиляция модулей ядра гостя используйте команду:
/usr/lib/VBoxGuestAdditions/vboxadd setup
После компиляции вам необходимо перезагрузить гостевую систему.
This section assumes that you are familiar with configuring the X.Org server using xorg.conf and optionally the newer mechanisms using hal or udev and xorg.conf.d. If not you can learn about them by studying the documentation which comes with X.Org.
The VirtualBox Guest Additions come with drivers for X.Org versions
By default these drivers can be found in the directory
/opt/VBoxGuestAdditions-<version>/lib/VBoxGuestAdditions
and the correct versions for the X server are symbolically linked into the X.Org driver directories.
For graphics integration to work correctly, the X server must load the vboxvideo driver (many recent X server versions look for it automatically if they see that they are running in VirtualBox) and for an optimal user experience the guest kernel drivers must be loaded and the Guest Additions tool VBoxClient must be running as a client in the X session. For mouse integration to work correctly, the guest kernel drivers must be loaded and in addition, in X servers from X.Org X11R6.8 to X11R7.1 and in XFree86 version 4.3 the right vboxmouse driver must be loaded and associated with /dev/mouse or /dev/psaux; in X.Org server 1.3 or later a driver for a PS/2 mouse must be loaded and the right vboxmouse driver must be associated with /dev/vboxguest.
The VirtualBox guest graphics driver can use any graphics configuration for which the virtual resolution fits into the virtual video memory allocated to the virtual machine (minus a small amount used by the guest driver) as described in the section called “Display settings”. The driver will offer a range of standard modes at least up to the default guest resolution for all active guest monitors. In X.Org Server 1.3 and later the default mode can be changed by setting the output property VBOX_MODE to "<width>x<height>" for any guest monitor. When VBoxClient and the kernel drivers are active this is done automatically when the host requests a mode change. The driver for older versions can only receive new modes by querying the host for requests at regular intervals.
With pre-1.3 X Servers you can also add your own modes to the X server configuration file. Вам просто необходимо добавить их в запись "Modes" подсекции "Display" секции "Screen" . Например, в приведенном ниже примере добавляется пользовательское разрешение 2048x800:
Section "Screen" Identifier "Default Screen" Device "VirtualBox graphics card" Monitor "Generic Monitor" DefaultDepth 24 SubSection "Display" Depth 24 Modes "2048x800" "800x600" "640x480" EndSubSection EndSection
With virtual machines running modern server operating systems, VirtualBox supports CPU hot-plugging.[37] Whereas on a physical computer this would mean that a CPU can be added or removed while the machine is running, VirtualBox supports adding and removing virtual CPUs while a virtual machine is running.
CPU hot-plugging works only with guest operating systems that support it. So far this applies only to Linux and Windows Server 2008 x64 Data Center Edition. Windows supports only hot-add while Linux supports hot-add and hot-remove but to use this feature with more than 8 CPUs a 64bit Linux guest is required.
At this time, CPU hot-plugging requires using the VBoxManage command-line interface. First, hot-plugging needs to be enabled for a virtual machine:
VBoxManage modifyvm "VM name" --cpuhotplug on
After that, the --cpus option specifies the maximum number of CPUs that the virtual machine can have:
VBoxManage modifyvm "VM name" --cpus 8
When the VM is off, you can then add and remove virtual CPUs with the modifyvm --plugcpu and --unplugcpu subcommands, which take the number of the virtual CPU as a parameter, like this:
VBoxManage modifyvm "VM name" --plugcpu 3 VBoxManage modifyvm "VM name" --unplugcpu 3
Note that CPU 0 can never be removed.
While the VM is running, CPUs can be added with the
controlvm plugcpu/unplugcpu
commands
instead:
VBoxManage controlvm "VM name" plugcpu 3 VBoxManage controlvm "VM name" unplugcpu 3
See the section called “VBoxManage modifyvm” and the section called “VBoxManage controlvm” for details.
With Linux guests, the following applies: To prevent ejection while the CPU is still used it has to be ejected from within the guest before. The Linux Guest Additions contain a service which receives hot-remove events and ejects the CPU. Also, after a CPU is added to the VM it is not automatically used by Linux. The Linux Guest Additions service will take care of that if installed. If not a CPU can be started with the following command:
echo 1 > /sys/devices/system/cpu/cpu<id>/online
When running on Linux hosts, with a recent enough kernel (at least version
2.6.31
) experimental host PCI devices
passthrough is available.[38]
The PCI passthrough module is shipped as a VirtualBox extension package, which must be installed separately. См. раздел “Установка VirtualBox и модулей расширений”.
Essentially this feature allows to directly use physical PCI devices on the host by the guest even if host doesn't have drivers for this particular device. Both, regular PCI and some PCI Express cards, are supported. AGP and certain PCI Express cards are not supported at the moment if they rely on GART (Graphics Address Remapping Table) unit programming for texture management as it does rather nontrivial operations with pages remapping interfering with IOMMU. This limitation may be lifted in future releases.
To be fully functional, PCI passthrough support in VirtualBox depends upon an IOMMU hardware unit which is not yet too widely available. If the device uses bus mastering (i.e. it performs DMA to the OS memory on its own), then an IOMMU is required, otherwise such DMA transactions may write to the wrong physical memory address as the device DMA engine is programmed using a device-specific protocol to perform memory transactions. The IOMMU functions as translation unit mapping physical memory access requests from the device using knowledge of the guest physical address to host physical addresses translation rules.
Intel's solution for IOMMU is marketed as "Intel Virtualization Technology for Directed I/O" (VT-d), and AMD's one is called AMD-Vi. So please check if your motherboard datasheet has appropriate technology. Even if your hardware doesn't have a IOMMU, certain PCI cards may work (such as serial PCI adapters), but the guest will show a warning on boot and the VM execution will terminate if the guest driver will attempt to enable card bus mastering.
It is very common that the BIOS or the host OS disables the IOMMU by default. So before any attempt to use it please make sure that
Your motherboard has an IOMMU unit.
Your CPU supports the IOMMU.
The IOMMU is enabled in the BIOS.
The VM must run with VT-x/AMD-V and nested paging enabled.
Your Linux kernel was compiled with IOMMU support (including DMA
remapping, see CONFIG_DMAR
kernel
compilation option). The PCI stub driver
(CONFIG_PCI_STUB
) is required
as well.
Your Linux kernel recognizes and uses the IOMMU unit
(intel_iommu=on
boot option could be needed). Search for DMAR and PCI-DMA in kernel boot
log.
Once you made sure that the host kernel supports the IOMMU, the next step is
to select the PCI card and attach it to the guest. To figure out the list of
available PCI devices, use the lspci
command.
The output will look like this
01:00.0 VGA compatible controller: ATI Technologies Inc Cedar PRO [Radeon HD 5450] 01:00.1 Audio device: ATI Technologies Inc Manhattan HDMI Audio [Mobility Radeon HD 5000 Series] 02:00.0 Ethernet controller: Realtek Semiconductor Co., Ltd. RTL8111/8168B PCI Express Gigabit Ethernet controller (rev 03) 03:00.0 SATA controller: JMicron Technology Corp. JMB362/JMB363 Serial ATA Controller (rev 03) 03:00.1 IDE interface: JMicron Technology Corp. JMB362/JMB363 Serial ATA Controller (rev 03) 06:00.0 VGA compatible controller: nVidia Corporation G86 [GeForce 8500 GT] (rev a1)
The first column is a PCI address (in format bus:device.function
).
This address could be used to identify the device for further operations.
For example, to attach a PCI network controller on the system listed above
to the second PCI bus in the guest, as device 5, function 0, use the following command:
VBoxManage modifyvm "VM name" --pciattach 02:00.0@01:05.0
To detach same device, use
VBoxManage modifyvm "VM name" --pcidetach 02:00.0
Please note that both host and guest could freely assign a different PCI address to the card attached during runtime, so those addresses only apply to the address of the card at the moment of attachment (host), and during BIOS PCI init (guest).
If the virtual machine has a PCI device attached, certain limitations apply:
Отдельно от стандартных разрешений VESA , VirtualBox VESA BIOS позволяет вам добавить до 16 видео режимов которые будут доступны гостевой ОС. При использовании гостя Windows с гостевыми дополнениями VirtualBox, a custom graphics driver will be used instead of the fallback VESA solution so this information does not apply.
Дополнительные видео режимы можно настроить для каждой ВМ используя механизм дополнительных данных (the extra data facility). The extra data key is called CustomVideoMode<x>
with x
being a number from 1 to 16. Please note that modes will be read from 1 until either the following number is not defined or 16 is reached. Следующая команда добавит видео режим который является "родным" для большинства ноутбуков:
VBoxManage setextradata "VM name" "CustomVideoMode1" "1400x1050x16"
The VESA mode IDs for custom video modes start at
0x160
. In order to use the above defined custom video
mode, the following command line has be supplied to Linux:
vga = 0x200 | 0x160 vga = 864
For guest operating systems with VirtualBox Guest Additions, a custom video mode can be set using the video mode hint feature.
При запуске гостевой системы, с установленными дополнениями, используя графический интерфейс started using the graphical frontend (обычно программу VirtualBox),не возможно использовать разрешения больше чем размер экрана хоста, если пользователь вручную изменяя размер окна, переключаясь в полноэкранный режим, seamless режим или посылая сообщение смены видеорежима командой VBoxManage. Это поведение требуется большинству пользователей, но если ва это не нужно, то существует возможность изменить его используя командную строку:
VBoxManage setextradata global GUI/MaxGuestResolution any
эта команда кдалит все ограничения на видео разрешения гостевой системы.
VBoxManage setextradata global GUI/MaxGuestResolution >width,height<
вручную установит максимальное разрешение.
VBoxManage setextradata global GUI/MaxGuestResolution auto
востановит настройку по умолчанию. Заметьте, что эта настройка применяется ко всем гостевым системам , а не к одной машине.
Starting with version 1.4, as an alternative to using virtual disk images (as described in detail in Chapter 5, Virtual storage), VirtualBox can also present either entire physical hard disks or selected partitions thereof as virtual disks to virtual machines.
В VirtualBox этот вид доступа называется "raw hard disk access"; он позволяет гостевой операционной системы получить доступ к своему виртуальному жесткому диску без использования файловой системы хоста. The actual performance difference for image files vs. raw disk varies greatly depending on the overhead of the host file system, whether dynamically growing images are used and on host OS caching strategies. Кеширования также косвенно затрагивает другие аспекты - такие как отказоустойчивость файловой системе, т.е. будет ли виртуальный диск содержать ошибки после аварийного завершения ОС хоста. Ищите подробную информацию о вашей файловой системе в документации по вашей ОС.
Использовать "raw hard disk access" рекомендуется только опытным пользователям. Incorrect use or use of an outdated configuration can lead to total loss of data on the physical disk. Most importantly, do not attempt to boot the partition with the currently running host operating system in a guest. Это может привести к непредсказуемым повреждениям ваших данных.
Доступ через "raw hard disk access" - как ко всему диску так и к отдельным его разделам, - осуществляется через механизм образов диска VMDK. Поэтому, вам придется создать специальный файл VMDK, который определяет, где данные будут хранится. После его создания, вы можете использовать его как обычный виртуальный образ диска. For example, you can use the Virtual Media Manager (the section called “The Virtual Media Manager”) or VBoxManage
to assign the image to a virtual machine.
While this variant is the simplest to set up, you must be aware that this will give a guest operating system direct and full access to an entire physical disk. If your host operating system is also booted from this disk, please take special care to not access the partition from the guest at all. С другой стороны, на физическом диске можно изменить структуру или состав разделов, без повторного создания файлов виртуальных образов дисков.
Чтобы создать образ, который представляет весь физический жесткий диск на Linux хосте, используйте команду
VBoxManage internalcommands createrawvmdk -filename /path/to/file.vmdk -rawdisk /dev/sda
This creates the image
/path/to/file.vmdk
(must be absolute), and all data will
be read and written from /dev/sda
.
On a Windows host, instead of the above device specification,
use e.g. \\.\PhysicalDrive0
. On a Mac OS X host, instead
of the above device specification use e.g. /dev/disk1
.
Note that on OS X you can only get access to an entire disk if no
volume is mounted from it.
Создание образа (физического диска) требует полных прав (чтение и запись) к этому устройству. Полный доступ к нему также необходим при использовании образа в виртуальной машине.
Just like with regular disk images, this does not automatically attach the newly created image to a virtual machine. This can be done with e.g.
VBoxManage storageattach WindowsXP --storagectl "IDE Controller" --port 0 --device 0 --type hdd --medium /path/to/file.vmdk
После выполнения данной команды указанная виртуальная машина будет грузиться с данного физического диска.
Данный режим "raw partition support" сильно похож на режим "full hard disk", который описан выше. Однако, в этом случае, в VMDK образе будет содержаться информация о разделах диска. В данном режиме вы можете, например, указать другой образ загрузчика для виртуального жесткого диска без внесения изменений в физический диск. While the guest will be able to see all partitions that exist on the physical disk, access will be filtered in that reading from partitions for which no access is allowed the partitions will only yield zeroes, and all writes to them are ignored.
Для создания образа "raw partition support" (который будет небольшим по размеру, как было упомянуто ранее), в Linux используйте команду:
VBoxManage internalcommands createrawvmdk -filename /path/to/file.vmdk -rawdisk /dev/sda -partitions 1,5
As you can see, the command is identical to the one for "full
hard disk" access, except for the additional
-partitions
parameter. This example
would create the image /path/to/file.vmdk
(which, again,
must be absolute), and partitions 1 and 5 of /dev/sda
would be made accessible to the guest.
VirtualBox использует ту же самую нумерацию разделов, что и ваш хост Linux. Поэтому , номера указанные в вышеприведенном примере будут указывать на первый диск первичного раздела и первый диск дополнительного раздела (first primary partition and first logical drive in the extended partition).
On a Windows host, instead of the above device specification,
use e.g. \\.\PhysicalDrive0
. On a Mac OS X host, instead
of the above device specification use e.g. /dev/disk1
.
Note that on OS X you can only use partitions which are not mounted
(eject the respective volume first). Partition numbers are the same on
Linux, Windows and Mac OS X hosts.
Список номеров разделов вы можете получить командой
VBoxManage internalcommands listpartitions -rawdisk /dev/sda
Вывод этой команды содержит список разделов, их тип и размер, что позволяет пользователю определить нужный раздел.
Образы которые предоставляют доступ к отдельным разделам привязаны к дискам хост системы. You cannot transfer these images to another host; also, whenever the host partitioning changes, the image must be recreated.
Создание образа (физического диска) требует полных прав (чтение и запись) к этому устройству. Полный доступ к нему также необходим при использовании образа в виртуальной машине. Если это не возможно, имеется особый вариант "raw partition access" (в настоящее время доступен только для Linux хостов) который позволяет избежать предоставления полного доступа ко всему диску текущему пользователю. Для настройки этих образов используйте команду
VBoxManage internalcommands createrawvmdk -filename /path/to/file.vmdk -rawdisk /dev/sda -partitions 1,5 -relative
When used from a virtual machine, the image will then refer not to the entire disk, but only to the individual partitions (in the example /dev/sda1
and /dev/sda5
). Поэтому, полный доступ требуется только к этим разделам, а не ко всему диску. Однако для создания этого образа полный доступ ко всему диску необходим для получения информации о структуре диска.
В некоторых конфигурация возможно потребуется изменение кода MBR создаваемого образа, например чтобы заменить загрузчик Linux, вместо того который используется хостом. Это позволит, например, сразу загрузить гостевую систему Windows, если Linux хост система загружается с "того же самого" диска. For this purpose the -mbr
parameter is provided. Он определяет имя файла в котором хранится код MBR. При этом таблица разделов не изменяется, что позволяет использовать один файл с кодом MBR для загрузки с различных разделов. Пример использования:
VBoxManage internalcommands createrawvmdk -filename /path/to/file.vmdk -rawdisk /dev/sda -partitions 1,5 -mbr winxp.mbr
Код из файла MBR будет сохранен внутри образа, а не на диске хоста.
The created image can be attached to a storage controller in a VM configuration as usual.
VirtualBox предоставляет информацию поставщика для своих виртуальных дисках, которая состоит из серийного номера диска, версии прошивки и номере модели. Эта информация может быть изменена командами:
VBoxManage setextradata "VM name" "VBoxInternal/Devices/ahci/0/Config/Port0/SerialNumber" "serial" VBoxManage setextradata "VM name" "VBoxInternal/Devices/ahci/0/Config/Port0/FirmwareRevision" "firmware" VBoxManage setextradata "VM name" "VBoxInternal/Devices/ahci/0/Config/Port0/ModelNumber" "model"
Серийный номер является строкой 20 из байт, версия прошивки строкой из 8 байт, а номер моделистрокой из 40 байт. Instead of "Port0" (referring to the first port), specify the desired SATA hard disk port.
The above commands apply to virtual machines with an AHCI (SATA) controller. The commands for virtual machines with an IDE controller are:
VBoxManage setextradata "VM name" "VBoxInternal/Devices/piix3ide/0/Config/PrimaryMaster/SerialNumber" "serial" VBoxManage setextradata "VM name" "VBoxInternal/Devices/piix3ide/0/Config/PrimaryMaster/FirmwareRevision" "firmware" VBoxManage setextradata "VM name" "VBoxInternal/Devices/piix3ide/0/Config/PrimaryMaster/ModelNumber" "model"
For hard disks it's also possible (experimental!) to mark the drive as having a non-rotational medium with:
VBoxManage setextradata "VM name" "VBoxInternal/Devices/ahci/0/Config/Port0/NonRotational" "1"
Additional three parameters are needed for CD/DVD drives to report the vendor product data:
VBoxManage setextradata "VM name" "VBoxInternal/Devices/ahci/0/Config/Port0/ATAPIVendorId" "vendor" VBoxManage setextradata "VM name" "VBoxInternal/Devices/ahci/0/Config/Port0/ATAPIProductId" "product" VBoxManage setextradata "VM name" "VBoxInternal/Devices/ahci/0/Config/Port0/ATAPIRevision" "revision"
The vendor id is an 8 byte alphanumeric string, the product id an 16 byte alphanumeric string and the revision a 4 byte alphanumeric string. Instead of "Port0" (referring to the first port), specify the desired SATA hard disk port.
As an experimental feature, VirtualBox allows for accessing an iSCSI target running in a virtual machine which is configured for using Internal Networking mode. Please see the section called “iSCSI servers”; the section called “Internal networking”; and the section called “VBoxManage storageattach” for additional information.
Для виртуальной машины которая используется в качестве iSCSI target должен быть сконфигурирован виртуальный сетевой адаптер в режиме "внутренней сети". Необходимо выбрать IP и MAC адреса не используемые в других виртуальных машинах. In the example below, adapt the name of the virtual machine, the MAC address, the IP configuration and the Internal Networking name ("MyIntNet") according to your needs. The following seven commands must first be issued:
VBoxManage setextradata "VM name" VBoxInternal/Devices/IntNetIP/0/Trusted 1 VBoxManage setextradata "VM name" VBoxInternal/Devices/IntNetIP/0/Config/MAC 08:00:27:01:02:0f VBoxManage setextradata "VM name" VBoxInternal/Devices/IntNetIP/0/Config/IP 10.0.9.1 VBoxManage setextradata "VM name" VBoxInternal/Devices/IntNetIP/0/Config/Netmask 255.255.255.0 VBoxManage setextradata "VM name" VBoxInternal/Devices/IntNetIP/0/LUN#0/Driver IntNet VBoxManage setextradata "VM name" VBoxInternal/Devices/IntNetIP/0/LUN#0/Config/Network MyIntNet VBoxManage setextradata "VM name" VBoxInternal/Devices/IntNetIP/0/LUN#0/Config/IsService 1
Finally the iSCSI disk must be attached with the
--intnet
option to tell the iSCSI
initiator to use internal networking:
VBoxManage storageattach ... --medium iscsi --server 10.0.9.30 --target iqn.2008-12.com.sun:sampletarget --intnet
Compared to a "regular" iSCSI setup, IP address of the target must be specified as a numeric IP address, as there is no DNS resolver for internal networking.
Виртуальная машина с iSCSI target должна запускаться до ВМ использующего его. Если виртуальная машина использующая iSCSI диск запускается без работающего iSCSI target, то это приводит к тому, что она будет пытаться обнаружить его в течении 200 секунд. И ВМ не сможет запуститься.
Хосты с ОС Solaris имеют фиксированное количество семафоров в IPC на процесс, что не позволяет запустить более чем 120 виртуальных машин. При попытке запустить больше ВМ вы увидете сообщение об ошибке "Cannot create IPC semaphore".
Что бы запустить больше ВМ, вы должны отключить лимит семафоров для процесса VBoxSVC. Execute as root the prctl
command as shown below. The process ID of VBoxSVC can be obtained using the ps
list command.
prctl -r -n project.max-sem-ids -v 2048 <pid-of-VBoxSVC>
Starting with version 1.4, VirtualBox provided support for virtual
serial ports, which, at the time, was rather complicated to set up with a
sequence of VBoxManage setextradata
statements. Since version 1.5, that way of setting up serial ports is no
longer necessary and deprecated. To set up virtual
serial ports, use the methods now described in the section called “Serial ports”.
For backwards compatibility, the old setextradata
statements, whose description is retained below from the old version of the manual, take precedence over the new way of configuring serial ports. Если настройка последовательных портов новым способом не работает , убедитесь, что виртуальная машина не имеет старых настроек.
Старая метод настройки последовательных портов использует следующие 6 команд:
VBoxManage setextradata "VM name" "VBoxInternal/Devices/serial/0/Config/IRQ" 4 VBoxManage setextradata "VM name" "VBoxInternal/Devices/serial/0/Config/IOBase" 0x3f8 VBoxManage setextradata "VM name" "VBoxInternal/Devices/serial/0/LUN#0/Driver" Char VBoxManage setextradata "VM name" "VBoxInternal/Devices/serial/0/LUN#0/AttachedDriver/Driver" NamedPipe VBoxManage setextradata "VM name" "VBoxInternal/Devices/serial/0/LUN#0/AttachedDriver/Config/Location" "\\.\pipe\vboxCOM1" VBoxManage setextradata "VM name" "VBoxInternal/Devices/serial/0/LUN#0/AttachedDriver/Config/IsServer" 1
This sets up a serial port in the guest with the default settings for COM1 (IRQ 4, I/O address 0x3f8) and the Location
setting assumes that this configuration is used on a Windows host, because the Windows named pipe syntax is used. Keep in mind that on Windows hosts a named pipe must always start with \\.\pipe\
. On Linux the same config settings apply, except that the path name for the Location
can be chosen more freely. Local domain sockets can be placed anywhere, provided the user running VirtualBox has the permission to create a new file in the directory. Последняя команда, из перечисленных выше, определяет что VirtualBox будет работать как сервер, т.е. она создает именованный канал, вместо подключения к уже существующему.
In NAT mode, the guest network interface is assigned to the IPv4
range 10.0.x.0/24
by default where
x
corresponds to the instance of the
NAT interface +2. So x
is 2 when there
is only one NAT instance active. In that case the guest is assigned to
the address 10.0.2.15
, the gateway is
set to 10.0.2.2
and the name server can
be found at 10.0.2.3
.
Если по каким то причинам, необходимо изменить эти настройки сети NAT, то это возможно сделать следующей командой:
VBoxManage modifyvm "VM name" --natnet1 "192.168/16"
This command would reserve the network addresses from
192.168.0.0
to
192.168.254.254
for the first NAT
network instance of "VM name". The guest IP would be assigned to
192.168.0.15
and the default gateway
could be found at 192.168.0.2
.
Для сетевой загрузки в режиме NAT, VirtualBox по умолчанию использует встроенный TFTP сервер с IP адресом 10.0.2.3. Эта стандартное поведение будет прекрасно работать в типичных сценариях удаленной загрузки. Однако, имеется возможность изменить IP сервер загрузки и расположение образа загрузки командой:
VBoxManage modifyvm "VM name" --nattftpserver1 10.0.2.2 VBoxManage modifyvm "VM name" --nattftpfile1 /srv/tftp/boot/MyPXEBoot.pxe
The VirtualBox NAT stack performance is often determined by its
interaction with the host's TCP/IP stack and the size of several buffers
(SO_RCVBUF
and
SO_SNDBUF
). For certain setups users
might want to adjust the buffer size for a better performance. This can
by achieved using the following commands (values are in kilobytes and
can range from 8 to 1024):
VBoxManage modifyvm "VM name" --natsettings1 16000,128,128,0,0
This example illustrates tuning the NAT settings. The first parameter is the MTU, then the size of the socket's send buffer and the size of the socket's receive buffer, the initial size of the TCP send window, and lastly the initial size of the TCP receive window. Note that specifying zero means fallback to the default value.
Each of these buffers has a default size of 64KB and default MTU is 1500.
By default, VirtualBox's NAT engine will route TCP/IP packets through the default interface assigned by the host's TCP/IP stack. (The technical reason for this is that the NAT engine uses sockets for communication.) If, for some reason, you want to change this behavior, you can tell the NAT engine to bind to a particular IP address instead. Use the following command:
VBoxManage modifyvm "VM name" --natbindip1 "10.45.0.2"
After this, all outgoing traffic will be sent through the interface with the IP address 10.45.0.2. Please make sure that this interface is up and running prior to this assignment.
The NAT engine by default offers the same DNS servers to the guest that are configured on the host. In some scenarios, it can be desirable to hide the DNS server IPs from the guest, for example when this information can change on the host due to expiring DHCP leases. In this case, you can tell the NAT engine to act as DNS proxy using the following command:
VBoxManage modifyvm "VM name" --natdnsproxy1 on
For resolving network names, the DHCP server of the NAT engine offers a list of registered DNS servers of the host. If for some reason you need to hide this DNS server list and use the host's resolver settings, thereby forcing the VirtualBox NAT engine to intercept DNS requests and forward them to host's resolver, use the following command:
VBoxManage modifyvm "VM name" --natdnshostresolver1 on
Note that this setting is similar to the DNS proxy mode, however whereas the proxy mode just forwards DNS requests to the appropriate servers, the resolver mode will interpret the DNS requests and use the host's DNS API to query the information and return it to the guest.
By default, the NAT core uses aliasing and uses random ports when generating an alias for a connection. This works well for the most protocols like SSH, FTP and so on. Though some protocols might need a more transparent behavior or may depend on the real port number the packet was sent from. It is possible to change the NAT mode via the VBoxManage frontend with the following commands:
VBoxManage modifyvm "VM name" --nataliasmode1 proxyonly
и
VBoxManage modifyvm "Linux Guest" --nataliasmode1 sameports
The first example disables aliasing and switches NAT into transparent mode, the second example enforces preserving of port values. These modes can be combined if necessary.
Данные DMI, которые VirtualBox предоставляет гостевым системам, можно изменить для определенной ВМ. Используются следующие команды для настройки информации DMI BIOS :
VBoxManage setextradata "VM name" "VBoxInternal/Devices/pcbios/0/Config/DmiBIOSVendor" "BIOS Vendor" VBoxManage setextradata "VM name" "VBoxInternal/Devices/pcbios/0/Config/DmiBIOSVersion" "BIOS Version" VBoxManage setextradata "VM name" "VBoxInternal/Devices/pcbios/0/Config/DmiBIOSReleaseDate" "BIOS Release Date" VBoxManage setextradata "VM name" "VBoxInternal/Devices/pcbios/0/Config/DmiBIOSReleaseMajor" 1 VBoxManage setextradata "VM name" "VBoxInternal/Devices/pcbios/0/Config/DmiBIOSReleaseMinor" 2 VBoxManage setextradata "VM name" "VBoxInternal/Devices/pcbios/0/Config/DmiBIOSFirmwareMajor" 3 VBoxManage setextradata "VM name" "VBoxInternal/Devices/pcbios/0/Config/DmiBIOSFirmwareMinor" 4 VBoxManage setextradata "VM name" "VBoxInternal/Devices/pcbios/0/Config/DmiSystemVendor" "System Vendor" VBoxManage setextradata "VM name" "VBoxInternal/Devices/pcbios/0/Config/DmiSystemProduct" "System Product" VBoxManage setextradata "VM name" "VBoxInternal/Devices/pcbios/0/Config/DmiSystemVersion" "System Version" VBoxManage setextradata "VM name" "VBoxInternal/Devices/pcbios/0/Config/DmiSystemSerial" "System Serial" VBoxManage setextradata "VM name" "VBoxInternal/Devices/pcbios/0/Config/DmiSystemSKU" "System SKU" VBoxManage setextradata "VM name" "VBoxInternal/Devices/pcbios/0/Config/DmiSystemFamily" "System Family" VBoxManage setextradata "VM name" "VBoxInternal/Devices/pcbios/0/Config/DmiSystemUuid" "9852bf98-b83c-49db-a8de-182c42c7226b"
Если строка DMI не определена, используется значение по умолчанию. To set an empty string use "<EMPTY>"
.
Note that in the above list, all quoted parameters (DmiBIOSVendor,
DmiBIOSVersion but not DmiBIOSReleaseMajor) are expected to be strings. If
such a string is a valid number, the parameter is treated as number and
the VM will most probably refuse to start with an
VERR_CFGM_NOT_STRING
error. In that case,
use "string:<value>"
, for instance
VBoxManage setextradata "VM name" "VBoxInternal/Devices/pcbios/0/Config/DmiSystemSerial" "string:1234"
Изменение этой информации может понадобиться для предотвращения запросов кода активации гостевой Windows. На хостах Linux информация DMI BIOS может быть получена командой
dmidecode -t0
а системная DMI информация, командой
dmidecode -t1
By default, VirtualBox keeps all sources of time visible to the guest synchronized to a single time source, the monotonic host time. This reflects the assumptions of many guest operating systems, which expect all time sources to reflect "wall clock" time. In special circumstances it may be useful however to make the TSC (time stamp counter) in the guest reflect the time actually spent executing the guest.
This special TSC handling mode can be enabled on a per-VM basis, and for best results must be used only in combination with hardware virtualization. To enable this mode use the following command:
VBoxManage setextradata "VM name" "VBoxInternal/TM/TSCTiedToExecution" 1
To revert to the default TSC handling mode use:
VBoxManage setextradata "VM name" "VBoxInternal/TM/TSCTiedToExecution"
Note that if you use the special TSC handling mode with a guest operating system which is very strict about the consistency of time sources you may get a warning or error message about the timing inconsistency. It may also cause clocks to become unreliable with some guest operating systems depending on they use the TSC.
For certain purposes it can be useful to accelerate or to slow down the (virtual) guest clock. This can be achieved as follows:
VBoxManage setextradata "VM name" "VBoxInternal/TM/WarpDrivePercentage" 200
The above example will double the speed of the guest clock while
VBoxManage setextradata "VM name" "VBoxInternal/TM/WarpDrivePercentage" 50
will halve the speed of the guest clock. Note that changing the rate of the virtual clock can confuse the guest and can even lead to abnormal guest behavior. For instance, a higher clock rate means shorter timeouts for virtual devices with the result that a slightly increased response time of a virtual device due to an increased host load can cause guest failures. Note further that any time synchronization mechanism will frequently try to resynchronize the guest clock with the reference clock (which is the host clock if the VirtualBox Guest Additions are active). Therefore any time synchronization should be disabled if the rate of the guest clock is changed as described above (see the section called “Tuning the Guest Additions time synchronization parameters”).
The VirtualBox Guest Additions ensure that the guest's system time is synchronized with the host time. There are several parameters which can be tuned. The parameters can be set for a specific VM using the following command:
VBoxManage guestproperty set VM_NAME "/VirtualBox/GuestAdd/VBoxService/PARAMETER" VALUE
where PARAMETER
is one of the
following:
--timesync-interval
Specifies the interval at which to synchronize the time with the host. The default is 10000 ms (10 seconds).
--timesync-min-adjust
The minimum absolute drift value measured in milliseconds to make adjustments for. The default is 1000 ms on OS/2 and 100 ms elsewhere.
--timesync-latency-factor
The factor to multiply the time query latency with to calculate the dynamic minimum adjust time. The default is 8 times, that means in detail: Measure the time it takes to determine the host time (the guest has to contact the VM host service which may take some time), multiply this value by 8 and do an adjustment only if the time difference between host and guest is bigger than this value. Don't do any time adjustment otherwise.
--timesync-max-latency
The max host timer query latency to accept. The default is 250 ms.
--timesync-set-threshold
The absolute drift threshold, given as milliseconds where to start setting the time instead of trying to smoothly adjust it. The default is 20 minutes.
--timesync-set-start
Set the time when starting the time sync service.
--timesync-set-on-restore
0|1
Set the time after the VM was restored from a saved state when passing 1 as parameter (default). Disable by passing 0. In the latter case, the time will be adjusted smoothly which can take a long time.
All these parameters can be specified as command line parameters to VBoxService as well.
Starting with VirtualBox 4.1, VirtualBox ships a new network filter driver that utilizes Solaris 11's Crossbow functionality. By default, this new driver is installed for Solaris 11 hosts (builds 159 and above) that has support for it.
To force installation of the older STREAMS based network filter driver, execute as root execute the below command before installing the VirtualBox package:
touch /etc/vboxinst_vboxflt
To force installation of the Crossbow based network filter driver, execute as root the below command before installing the VirtualBox package:
touch /etc/vboxinst_vboxbow
To check which driver is currently being used by VirtualBox, execute:
modinfo | grep vbox
If the output contains "vboxbow", it indicates VirtualBox is using the Crossbow network filter driver, while the name "vboxflt" indicates usage of the older STREAMS network filter.
VirtualBox supports VNIC (Virtual Network Interface) templates for configuring VMs over VLANs.[39] A VirtualBox VNIC template is a VNIC whose name starts with "vboxvnic_template".
Here is an example of how to use a VNIC template to configure a VLAN for VMs. Create a VirtualBox VNIC template, by executing as root:
dladm create-vnic -t -l nge0 -v 23 vboxvnic_template0
This will create a temporary VNIC over interface "nge0" with the
VLAN ID 23. To create VNIC templates that are persistent across host
reboots, skip the -t
parameter in the
above command. You may check the current state of links using:
$ dladm show-link LINK CLASS MTU STATE BRIDGE OVER nge0 phys 1500 up -- -- nge1 phys 1500 down -- -- vboxvnic_template0 vnic 1500 up -- nge0 $ dladm show-vnic LINK OVER SPEED MACADDRESS MACADDRTYPE VID vboxvnic_template0 nge0 1000 2:8:20:25:12:75 random 23
Once the VNIC template is created, all VMs that need to be part of
VLAN 23 over the physical interface "nge0" can use the same VNIC template.
This makes managing VMs on VLANs simpler and efficient, as the VLAN
details are not stored as part of every VM's configuration but rather
picked up via the VNIC template which can be modified anytime using
dladm
. Apart from the VLAN ID, VNIC
templates can be created with additional properties such as bandwidth
limits, CPU fanout etc. Refer to your Solaris network documentation on how
to accomplish this. These additional properties, if any, are also applied
to VMs which use the VNIC template.
By default VirtualBox provides you with one host-only network interface. Adding more host-only network interfaces on Solaris hosts requires manual configuration. Here's how to add two more host-only network interfaces.
You first need to stop all running VMs and unplumb all existing "vboxnet" interfaces. Execute the following commands as root:
ifconfig vboxnet0 unplumb
Once you make sure all vboxnet interfaces are unplumbed, remove the driver using:
rem_drv vboxnet
then edit the file
/platform/i86pc/kernel/drv/vboxnet.conf
and add a line for the new interfaces:
name="vboxnet" parent="pseudo" instance=1; name="vboxnet" parent="pseudo" instance=2;
Add as many of these lines as required and make sure "instance" number is uniquely incremented. Next reload the vboxnet driver using:
add_drv vboxnet
Now plumb all the interfaces using
ifconfig vboxnetX plumb
(where X can be
0, 1 or 2 in this case) and once plumbed you can then configure the
interface like any other network interface.
To make your newly added interfaces' settings persistent across
reboots you will need to edit the files
/etc/netmasks
, and if you are using NWAM
/etc/nwam/llp
and add the appropriate
entries to set the netmask and static IP for each of those interfaces. The
VirtualBox installer only updates these configuration files for the one
"vboxnet0" interface it creates by default.
VirtualBox is capable of producing its own core files when things go wrong and for more extensive debugging. Currently this is only available on Solaris hosts.
The VirtualBox CoreDumper can be enabled using the following command:
VBoxManage setextradata "VM name" VBoxInternal2/CoreDumpEnabled 1
You can specify which directory to use for core dumps with this command:
VBoxManage setextradata "VM name" VBoxInternal2/CoreDumpDir <path-to-directory>
Make sure the directory you specify is on a volume with sufficient free space and that the VirtualBox process has sufficient permissions to write files to this directory. If you skip this command and don't specify any core dump directory, the current directory of the VirtualBox executable will be used (which would most likely fail when writing cores as they are protected with root permissions). It is recommended you explicity set a core dump directory.
You must specify when the VirtualBox CoreDumper should be triggered. This is done using the following commands:
VBoxManage setextradata "VM name" VBoxInternal2/CoreDumpReplaceSystemDump 1 VBoxManage setextradata "VM name" VBoxInternal2/CoreDumpLive 1
At least one of the above two commands will have to be provided if you have enabled the VirtualBox CoreDumper.
Setting CoreDumpReplaceSystemDump
sets up the VM to override the host's core dumping mechanism and in the
event of any crash only the VirtualBox CoreDumper would produce the core
file.
Setting CoreDumpLive
sets up the VM
to produce cores whenever the VM receives a
SIGUSR2
signal. After producing the core
file, the VM will not be terminated and will continue to run. You can then
take cores of the VM process using:
kill -s SIGUSR2 <VM-process-id>
Core files produced by the VirtualBox CoreDumper are of the form
core.vb.<ProcessName>.<ProcessID>
,
e.g.core.vb.VBoxHeadless.11321
.
There are several advanced customization settings for locking down the VirtualBox manager, that is, removing some features that the user should not see.
VBoxManage setextradata global GUI/Customizations OPTION[,OPTION...]
where OPTION
is one of the
following keywords:
noSelector
Don't allow to start the VirtualBox manager. Trying to do so will show a window containing a proper error message.
noMenuBar
VM windows will not contain a menu bar.
noStatusBar
VM windows will not contain a status bar.
To disable any GUI customization do
VBoxManage setextradata global GUI/Customizations
To disable all host key combinations, open the preferences and change the host key to None. This might be useful when using VirtualBox in a kiosk mode.
Furthermore, you can disallow certain actions when terminating a VM. To disallow specific actions, type:
VBoxManage setextradata "VM name" GUI/RestrictedCloseActions OPTION[,OPTION...]
where OPTION
is one of the
following keywords:
SaveState
Don't allow the user to save the VM state when terminating the VM.
Shutdown
Don't allow the user to shutdown the VM by sending the ACPI power-off event to the guest.
PowerOff
Don't allow the user to power off the VM.
Restore
Don't allow the user to return to the last snapshot when powering off the VM.
Any combination of the above is allowed. If all options are specified, the VM cannot be shut down at all.
The VirtualBox web service
(vboxwebsrv
) is used for controlling
VirtualBox remotely. It is documented in detail in the VirtualBox Software
Development Kit (SDK); please see Chapter 11, VirtualBox programming interfaces. As the
client base using this interface is growing, we added start scripts for
the various operation systems we support. The following describes how to
use them.
On Mac OS X, launchd is used. An example configuration file
can be found in
$HOME/Library/LaunchAgents/org.virtualbox.vboxwebsrv.plist
.
It can be enabled by changing the
Disabled
key from
true
to
false
. To manually start the
service use the following command:
launchctl load ~/Library/LaunchAgents/org.virtualbox.vboxwebsrv.plist
For additional information on how launchd services could be
configured see http://developer.apple.com/mac/library/documentation/MacOSX/Conceptual/BPSystemStartup/BPSystemStartup.html
.
В версии 4.0.8 появилась новая программа VBoxBalloonCtrl
предназначеная для автоматического настройки memory balloon (см. раздел “Memory ballooning”). Она особенно полезна на серверах, где виртуальным машинам во время их работы требуется либо больше, либо меньше памяти.
VBoxBalloonCtrl переодически проверяет память ВМ и RAM гостевой системы и в изменяет размер memory ballon(балона), "расширяя" или "сдувая" его. Эта обработка применяется только к работающим ВМ с установлеными гостевыми дополнениями.
Для запуска VBoxBalloonCtrl и настройки максимального размера балона ВМ, выполняется проверка параметров в следующей последовательности:
--balloon-max
VBoxManage setextradata "VM-Name" VBoxInternal/Guest/BalloonSizeMax <Size in MB>
VBoxManage setextradata global VBoxInternal/Guest/BalloonSizeMax <Size in MB>
Если максимальный размер балона не задан ни одним из способов перечисленых выше, то механиз не будет использоваться.
Для получения дополнительной информации по команде запустите ее с аргументом --help
.
[37] Support for CPU hot-plugging was introduced with VirtualBox 3.2.
[38] Experimental support for PCI passthrough was introduced with VirtualBox 4.1.
[39] Support for Crossbow based bridged networking was introduced with VirtualBox 4.1 and requires Solaris 11 build 159 or above.
home start up prev next