https://wiki.archlinux.org/api.php?action=feedcontributions&user=MaxSoniX&feedformat=atomArchWiki - User contributions [en]2024-03-29T00:00:02ZUser contributionsMediaWiki 1.41.0https://wiki.archlinux.org/index.php?title=International_communities&diff=741894International communities2022-08-17T10:04:45Z<p>MaxSoniX: /* Russian */ New Homepage</p>
<hr />
<div>[[Category:Arch community]]<br />
[[Category:Lists]]<br />
[[bs:International communities]]<br />
[[de:Internationale Gemeinschaften]]<br />
[[es:International communities]]<br />
[[ja:国際コミュニティ]]<br />
[[lt:International communities]]<br />
[[pt:International communities]]<br />
[[zh-hans:International communities]]<br />
{{Related articles start}}<br />
{{Related|Help:i18n}}<br />
{{Related|ArchWiki:Translation Team}}<br />
{{Related|IRC channel}}<br />
{{Related articles end}}<br />
<br />
{{Move|Local communities|indicate that there are not only international community|section=Rename this page to Local Communities}}<br />
https://archlinux.org is the home of the official Arch Linux website, forums, and wiki. However, several unofficial community-run sites are available for international users who would rather communicate in their own language. You can find a list of these communities below.<br />
<br />
Please note that our official wiki also supports internationalized content. In addition, we have an international forum where you can post in your native language. These tools can be used in addition to, in parallel with, or as a part of the international communities listed below. <br />
<br />
This list is by no means complete. If you know of a community that is not listed, please feel free to add it. If you are looking for a community that does not have an existing community, start one or visit the [https://bbs.archlinux.org/viewforum.php?id=30 Other Languages forum].<br />
<br />
== International (English) ==<br />
<br />
English communication platforms can be found in [[Getting involved]].<br />
<br />
== Bangladeshi ==<br />
<br />
* Matrix Chat: [https://matrix.to/#/#archlinux-bd:matrix.org?via=matrix.org #archlinux-bd:matrix.org]<br />
<br />
== Chinese ==<br />
<br />
=== China ===<br />
<br />
* Homepage: https://www.archlinuxcn.org/<br />
* Forum: https://bbs.archlinuxcn.org/<br />
* Forum: https://tieba.baidu.com/f?kw=archlinux<br />
* Telegram Chat: https://t.me/archlinuxcn_group (join the news channel [https://t.me/archlinuxcn @archlinuxcn] first to pass the validation)<br />
* Matrix Chat: [https://matrix.to/#/#archlinux-cn:nichi.co #archlinux-cn:nichi.co]<br />
* IRC Chat: [ircs://irc.libera.chat:6697/#archlinux-cn #archlinux-cn @ libera.chat]<br />
* [archlinuxcn] repo: https://github.com/archlinuxcn/repo<br />
* Wiki: [[Main page (简体中文)]]<br />
* Planet: https://planet.archlinuxcn.org/<br />
<br />
=== Taiwan ===<br />
<br />
* Homepage: https://archlinux.tw/<br />
* Telegram chat: https://t.me/ArchLinuxTaiwan<br />
* Forum: https://groups.google.com/forum/#!forum/archlinux-tw-general<br />
* Wiki: [[Main page (正體中文)]]<br />
<br />
== Danish ==<br />
<br />
* Homepage: http://www.archlinux.dk/<br />
* Forum: http://forum.archlinux.dk/<br />
* Wiki: [[Main page (Dansk)]]<br />
<br />
== French ==<br />
<br />
* Homepage: https://archlinux.fr/<br />
* Forum: https://forums.archlinux.fr/<br />
* Wiki: [[Main page (Français)]]<br />
* Signal: https://signal.group/#CjQKILMI8IXAepQEWDL7SM7ZWxVDxUV6N2T7IurW2mPWHKI8EhDDHdp1VQlE9YjhzG-_XoZ_<br />
* Telegram groups:<br />
** News: https://t.me/archlinuxfr<br />
** Chat: https://t.me/+WZuO7soXDGQzZTM8<br />
<br />
== German ==<br />
<br />
* Homepage: https://www.archlinux.de/<br />
* Forum: https://forum.archlinux.de/<br />
* Wiki: https://wiki.archlinux.de/<br />
* Arch Linux User Group Berlin: https://archlinux.berlin/<br />
<br />
== Greek ==<br />
<br />
* Homepage: https://archlinux.gr<br />
* Wiki: [[Main page (Ελληνικά)]]<br />
<br />
== Hindi ==<br />
<br />
* Telegram group: https://t.me/ArchLinuxIndia<br />
<br />
== Indonesian ==<br />
<br />
* Telegram group: https://t.me/ArchLinuxID<br />
<br />
== Italian ==<br />
<br />
* Wiki: [[Main page (Italiano)]]<br />
* Telegram group Arch Linux Italia: https://t.me/archlinuxita<br />
<br />
== Japanese ==<br />
<br />
* Homepage: https://www.archlinux.jp/<br />
* Forum: https://bbs.archlinux.jp/<br />
* Wiki: https://wiki.archlinux.jp/<br />
* Slack: https://slack.archlinux.jp/<br />
* Planet: https://planet.archlinux.jp/<br />
* Projects: https://github.com/ArchLinuxJP<br />
<br />
== Lithuanian ==<br />
<br />
* Forum: http://sls.archlinux.lt/<br />
* Wiki: [[:lt:Main page]]<br />
<br />
== Luxembourgish ==<br />
<br />
* Arch Linux User Group Luxembourg: https://wiki.c3l.lu/doku.php?id=events:alugl<br />
<br />
== Norwegian ==<br />
<br />
* Homepage: https://archlinux.no/<br />
* Wiki: [[Main page (Norsk Bokmål)]]<br />
<br />
== Persian ==<br />
<br />
* Homepage: http://www.archusers.ir/<br />
* Forums: https://bbs.archusers.ir/<br />
* Wiki: https://wiki.archusers.ir/<br />
<br />
== Polish ==<br />
<br />
* Forum: https://forum.archlinux.org.pl/<br />
* Wiki: [[Main page (Polski)]]<br />
<br />
== Portuguese ==<br />
<br />
* Homepage: http://archlinux-br.org/<br />
* Forum: https://forum.archlinux-br.org/<br />
* Telegram Chat:<br />
** [https://t.me/archlinuxbr @archlinuxbr] — Arch Linux-only support and chat (Bridged to Matrix Chat)<br />
** [https://t.me/archlinux_l10n_pt @archlinux_l10n_pt] — Translation of ArchWiki and other related resources<br />
** [https://t.me/archofftopic @archofftopic] — Portuguese off-topic chat<br />
* Matrix Chat: [https://matrix.to/#/#archlinuxbr:matrix.org #archlinuxbr:matrix.org]<br />
* Wiki: [[Main page (Português)]]<br />
<br />
== Russian ==<br />
<br />
* Homepage: https://archlinux.com.ru (https://archlinux.org.ru - deprecated)<br />
* Forum: https://archlinux.com.ru/forum<br />
* Telegram groups:<br />
** https://t.me/ArchLinuxChatRU<br />
** https://t.me/archlinux_ru (with mirror in Matrix: [https://matrix.to/#/#archlinux_ru:matrix.org #archlinux_ru:matrix.org])<br />
* Wiki: [[Main page (Русский)]]<br />
<br />
== Serbian ==<br />
<br />
* Homepage: https://www.archlinux.rs/<br />
* Forum: https://bbs.archlinux.rs/<br />
* Wiki: [[:sr:Main page]]<br />
<br />
== Spanish ==<br />
<br />
* Homepage: https://www.archlinux-es.org/<br />
* Wiki: [[Main page (Español)]]<br />
* Forum: https://foros.archlinux-es.org/ (Redirects to https://bbs.archlinux.org -> Other Languages)<br />
* Arch Linux in Spanish Group Telegram: https://t.me/ArchlinuxLatinoamerica<br />
<br />
== Swedish ==<br />
<br />
* Homepage: https://archlinux.se/<br />
* Wiki: [[Main page (Svenska)]]<br />
<br />
== Ukrainian ==<br />
<br />
* Forum: https://archlinux.org.ua/<br />
* Telegram chat: https://t.me/archlinux_ukraine<br />
* Wiki: [[Main page (Українська)]]<br />
<br />
== Vietnamese ==<br />
<br />
* Homepage: https://archlinuxvn.tuxfamily.org/ (Vietnamese only)<br />
* Wiki: https://archlinuxvn.tuxfamily.org/<br />
* Projects: https://github.com/archlinuxvn/<br />
* Mailing list: https://groups.google.com/group/archlinuxvn/</div>MaxSoniXhttps://wiki.archlinux.org/index.php?title=VirtualBox_(%D0%A0%D1%83%D1%81%D1%81%D0%BA%D0%B8%D0%B9)&diff=596354VirtualBox (Русский)2020-01-27T10:22:45Z<p>MaxSoniX: Error VERR_VMX_NO_VMX and solution.</p>
<hr />
<div>[[Category:Hypervisors (Русский)]]<br />
[[Category:Oracle (Русский)]]<br />
[[Category:Русский]]<br />
[[cs:VirtualBox]]<br />
[[de:VirtualBox]]<br />
[[el:VirtualBox]]<br />
[[en:VirtualBox]]<br />
[[es:VirtualBox]]<br />
[[fr:VirtualBox]]<br />
[[hu:VirtualBox]]<br />
[[it:VirtualBox]]<br />
[[ja:VirtualBox]]<br />
[[pt:VirtualBox]]<br />
[[zh-hans:VirtualBox]]<br />
{{Unmaintained (Русский)}}<br />
{{Related articles start (Русский)}}<br />
{{Related|:Category:Hypervisors (Русский)}}<br />
{{Related|PhpVirtualBox}}<br />
{{Related|Moving an existing install into (or out of) a virtual machine}}<br />
{{Related articles end}}<br />
<br />
[https://www.virtualbox.org VirtualBox] — [[Wikipedia:ru:Гипервизор|гипервизор]], предназначенный для запуска операционных систем в специальной среде (виртуальной машине), которая работает в существующей операционной системе. VirtualBox постоянно развивается и периодически появляются новые возможности. Для запуска и управления виртуальными машинами может использоваться графический [[Qt (Русский)|Qt]] интерфейс, а также можно не управлять ими или управлять с помощью [[Wikipedia:ru:Simple DirectMedia Layer|SDL]] утилит командной строки.<br />
<br />
Чтобы интегрировать в гостевую систему функции хост системы, такие как общие папки и общий буфер обмена, видео ускорение и режим бесшовной интеграции окон, для некоторых гостевых операционных систем предоставляются ''дополнения гостевой ОС''.<br />
<br />
== Пошаговая установка на хост-компьютер под управлением Arch Linux==<br />
<br />
Для запуска виртуальной машины под VirtualBox на хост-компьютере под управлением Arch Linux, выполните следующие действия по установке пакетов.<br />
<br />
=== Установка базовых пакетов ===<br />
<br />
Установите пакет {{Pkg|virtualbox}}. Также необходимо выбрать пакет с модулями для хост-компьютера:<br />
<br />
* для ядра {{Pkg|linux}} выберите {{Pkg|virtualbox-host-modules-arch}}<br />
* для других [[Kernel (Русский)|ядер]] выберите {{Pkg|virtualbox-host-dkms}}<br />
<br />
Чтобы скомпилировать модули VirtualBox, предоставляемые {{Pkg|virtualbox-host-dkms}}, необходимо также установить соответствующий пакет заголовков для установленного ядра (например, {{Pkg|linux-lts-headers}} для {{Pkg|linux-lts}}). [https://lists.archlinux.org/pipermail/arch-dev-public/2016-March/027808.html] При обновлении VirtualBox или ядра модули ядра будут автоматически перекомпилированы с помощью [[DKMS]]-хука Pacman.<br />
<br />
=== Установка модулей ядра VirtualBox ===<br />
<br />
Чтобы полностью виртуализировать гостевую ОС, VirtualBox предоставляет следующие [[Kernel_modules_(Русский)|модули ядра]]: {{ic|vboxdrv}}, {{ic|vboxnetadp}}, {{ic|vboxnetflt}}, и {{ic|vboxpci}}. Они должны быть добавлены к вашему хост ядру. <br />
<br />
Бинарная совместимость модулей ядра зависит от API ядра, на котором они были собраны.<br />
API может не совпадать в разных версиях ядра. Чтобы избежать проблем совместимости и багов, каждый раз при обновлении ядра Linux рекомендуется перекомпилировать модули ядра с обновленным ядром. Вместе с обновлением ядра в репозиториях Arch Linux обновляются также и модули Virtualbox, так что достаточно обновиться через пакетный менеджер.<br />
<br />
Если вы используете ядро из [[Official repositories (Русский)|официального репозитория]] или стороннее (скомпилированное самостоятельно или установленное из [[Arch_User_Repository_(Русский)|AUR]]), то необходимо тем же способом переустановить ядро.<br />
<br />
==== Использование различных версий ядра Linux на хост-машине ====<br />
<br />
* Если вы используете ядро {{Pkg|linux}}, убедитесь, что пакет {{pkg|virtualbox-host-modules}}{{Broken package link (Русский)|replaced by {{Pkg|virtualbox-host-modules-arch}}}} установлен. По умолчанию последняя версия этого пакета устанавливается как зависимость {{Pkg|virtualbox}}.<br />
* Если вы используете LTS версию ядра ({{pkg|linux-lts}}), тогда вам нужно установить пакет {{AUR|virtualbox-host-modules-lts}}. Пакет {{Pkg|virtualbox-host-modules}}{{Broken package link (Русский)|replaced by {{Pkg|virtualbox-host-modules-arch}}}} после этого можно удалить.<br />
* Если вы используете ядро {{aur|linux-ck}}, установите пакет {{aur|virtualbox-ck-host-modules}}.<br />
<br />
<br />
==== Обновление ядра Linux на хост-машине ====<br />
После обновления ядра выполните команду <br />
<br />
# sudo /usr/bin/rcvboxdrv<br />
<br />
для рекомпиляции модулей ядра.<br />
<br />
==== Стороннее ядро на хост-машине ====<br />
<br />
{{Translateme (Русский)|Общие советы по использованию DKMS не принадлежат к этой странице.}}<br />
<br />
Если вы используете или планируете использовать самостоятельно собранное ядро, вы должны знать, что VirtualBox не требует каких-либо модулей виртуализации (например, virtio, KVM, ...). Модули ядра VirtualBox обеспечивают все необходимое для нормальной работы. Таким образом, вы можете отключить в вашем ядре ''.config''-файл модулей виртуализации, если они не требуются другим гипервизорам (например, Xen, KVM или QEMU).<br />
<br />
Пакет {{ic|virtualbox-host-modules}} отлично работает с пользовательской конфигурацией стокового ядра Arch Linux, такого как {{AUR|linux-ck}}. {{ic|virtualbox-host-modules}} поставляется с официальным ядром Arch Linux ({{Pkg|linux}}) в зависимостях, и если вы используете иное ядро, необходимо установить {{Pkg|virtualbox-host-dkms}}.<br />
<br />
Если вы используете самостоятельно собранное ядро, версия которого не совпадает с версией стокового ядра Arch Linux , нужно установить {{Pkg|virtualbox-host-dkms}}. Он поставляется в комплекте с исходниками модулей ядра VirtualBox.<br />
<br />
Пакет {{Pkg|virtualbox-host-dkms}} требует компиляции. Проверьте наличие заголовков ядра, соответствующих вашей версии пользовательского ядра, чтобы избежать ошибки {{ic|Your kernel headers for kernel ''your custom kernel version'' cannot be found at /usr/lib/modules/''your custom kernel version''/build or /usr/lib/modules/''your custom kernel version''/source}}<br />
<br />
* Если вы используете самостоятельно собранное ядро и использовали {{ic|make modules_install}} для установки модулей, директории {{ic|/usr/lib/modules/''your custom kernel version''/build}} и {{ic|(...)/source}} будут символическими ссылками на исходники ядра. Они могут использоваться в качестве заголовков ядра в случае необходимости. <br />
* Если вы используете ядро из [[AUR]] репозитория, убедитесь, что установлен пакет {{Pkg|linux-headers}}.<br />
<br />
После того, как {{Pkg|virtualbox-host-dkms}} установится, сгенерируйте модули ядра для пользовательского ядра следующей командой:<br />
<br />
# dkms install vboxhost/''virtualbox-host-source version'' -k ''your custom kernel version''/''your architecture''<br />
<br />
{{tip_(Русский)| Используйте эту команду вместо предыдущей, если вы не хотите её адаптировать:<br />
{{bc|<nowiki># dkms install vboxhost/$(pacman -Q virtualbox|awk '{print $2}'|sed 's/\-.\+//') -k $(uname -rm|sed 's/\ /\//')</nowiki>}}<br />
}}<br />
<br />
<br />
Чтобы автоматически перекомпилировать модули ядра VirtualBox, когда их исходники обновится (т.е. повысится версия пакета {{Pkg|virtualbox-host-dkms}}) и чтобы не повторять впоследствии вручную {{ic|dkms install}}, включите {{ic|dkms}} сервис командой:<br />
# systemctl enable dkms.service<br />
<br />
При включенной службе {{ic|dkms}} для обновления модулей можно перезагрузить компьютер. Если же вы не хотите включать эту службу, то нужно выполнять команду {{ic|dkms install}} каждый раз при обновлении {{Pkg|virtualbox-host-dkms}}. В противном случае модули не обновятся, и есть немалая возможность получить нерабочий VirtualBox.<br />
<br />
Однако, если вы не хотите включать этот сервис (например, для оптимизации systemd) можно также использовать [[mkinitcpio|initramfs hook]], который будет автоматически запускать {{ic|dkms install}} во время загрузки. Он требует перезагрузки для перекомпиляции модулей VirtualBox. Чтобы включить этот хук, нужно установить пакет {{AUR|vboxhost-hook}}{{Broken package link (Русский)|{{aur-mirror (Русский)|vboxhost-hook}}}} из [[AUR]] и добавить {{ic|vboxhost}} в {{ic|/etc/mkinitcpio.conf}}. Опять же, убедитесь, что заголовки Linux доступны для нового ядра: в противном случае компиляция не удастся.<br />
<br />
{{tip_(Русский) | Ровно как и команда {{ic|dkms}}, {{ic|vboxhost}} хук выведет ошибку, если что-то пойдет не так во время перекомпиляции модулей VirtualBox.}}<br />
<br />
=== Загрузка модулей ядра VirtualBox ===<br />
<br />
Среди используемых [[Kernel_modules_(Русский)|модулей ядра]] VirtualBox, есть обязательный модуль {{ic|vboxdrv}}, который должен быть загружен перед стартом любой виртуальной машины. Он может быть загружен автоматически при старте Arch Linux, или, при необходимости, его можно загрузить вручную.<br />
<br />
Для загрузки модуля вручную выполните следующую команду:<br />
# modprobe vboxdrv<br />
<br />
Для автоматической загрузки модуля VirtualBox при старте, посмотрите [[Kernel_modules_(Русский)#Автоматическое управление модулями|Модули ядра#Автоматическое управление модулями]] и создайте файл {{ic|*.conf}} (например {{ic|virtualbox.conf}}) в каталоге {{ic|/etc/modules-load.d/}} с записью:<br />
{{hc|/etc/modules-load.d/virtualbox.conf|<br />
vboxdrv}}<br />
<br />
=== Дополнительные модули VirtualBox ===<br />
<br />
Следующие модули не являются обязательными, но рекомендуются, если вы не хотите проблем с некоторыми конфигурациями (подробнее смотрите ниже): {{ic|vboxnetadp}}, {{ic|vboxnetflt}} и {{ic|vboxpci}}.<br />
<br />
* {{ic|vboxnetadp}} и {{ic|vboxnetflt}} необходимы, если вы собираетесь использовать [https://www.virtualbox.org/manual/ch06.html#network_hostonly "Локальную виртуальную сеть"]. Точнее, {{ic|vboxnetadp}} нужен для создания интерфейса в глобальных настройках VirtualBox, и {{ic|vboxnetflt}} нужен для запуска виртуальной машины с использованием этого интерфейса.<br />
<br />
* {{ic|vboxpci}} необходим, когда вашей виртуальной машине нужно получить доступ к PCI устройству на вашей машине.<br />
<br />
Для работы данных модулей выполните команду<br />
<br />
# pacman -S net-tools<br />
<br />
И создайте файл {{ic|vbox-other-modules.conf}} в каталоге {{ic|/etc/modules-load.d/}} с записью<br />
<br />
{{hc|/etc/modules-load.d/vbox-other-modules.conf|<br />
vboxnetadp vboxnetflt vboxpci}}<br />
<br />
{{note_(Русский)|Если модули ядра VirtualBox были загружены в ядро пока вы обновляли модули, то вы должны загрузить их вручную для использования новой, обновленной версии. Что бы это сделать, запустите<br />
<br />
# vboxreload<br />
<br />
}}<br />
<br />
VirtualBox использует {{ic|ifconfig}} и {{ic|route}}, чтобы назначить IP и маршрут до интерфейса хоста, настроенного с помощью {{ic|VBoxManage hostonlyif}} или с помощью GUI ''Settings > Network > Host-only Networks > Edit host-only network (space) > Adapter''.<br />
<br />
<br />
=== Добавление пользователей в группу vboxusers ===<br />
<br />
Чтобы использовать USB-порты хост-системы в виртуальных машинах, нужно добавить в [[groups_(Русский)|группу]] {{ic|vboxusers}} имена пользователей, которые смогут получить доступ к USB-портам. Новая группа не будет автоматически применяться к существующим сеансам. Пользователь должен перелогиниться или добавить пользователя в новую группу в текущей сессии командой {{ic|newgrp}} или {{ic|sudo -u $USER -s}}. Для добавления текущего пользователя в группу {{ic|vboxusers}} нужно выполнить:<br />
# gpasswd -a $USER vboxusers<br />
<br />
=== Образ диска с гостевыми дополнениями ===<br />
<br />
Для корректной работы VirtualBox рекомендуется установить пакет {{Pkg|virtualbox-guest-iso}} в хост-системе. Этот пакет создаёт образ диска, который может быть использован для установки гостевых дополнений в гостевых системах, отличных от Arch Linux.'' .iso '' образ будет находиться в {{ic|/usr/lib/virtualbox/additions/VBoxGuestAdditions.iso}} и может быть установлен вручную после подключения образа в виртуальной машине.<br />
<br />
=== Пакет дополнений ===<br />
<br />
Начиная с версии VirtualBox 4.0, компоненты, не распространяющиеся под лицензией GPL были отделены от основной части приложения. Несмотря на то, что данные компоненты выпущены под несвободной лицензией и '''доступны только для личного использования''', вам может понадобиться установка Oracle Extension Pack, который обеспечивает [https://www.virtualbox.org/manual/ch01.html#intro-installing дополнительный функционал]. {{aur|virtualbox-ext-oracle}} пакет доступен на [[AUR]], а нестабильная версия может быть найдена в репозитории [[Unofficial user repositories#seblu|seblu]].<br />
<br />
Если вы предпочитаете использовать ручной способ, можно скачать пакет дополнений вручную и установить его с помощью графического интерфейса (''Настройки > Расширения'') или с помощью команды {{ic|VBoxManage extpack install <.vbox-extpack>}}. Предварительно убедитесь, что у вас установлен инструментарий (например, [[Polkit]], gksu и т.д.) для предоставления привилегированного доступа к VirtualBox, так как установка этого пакета [https://www.virtualbox.org/ticket/8473 требует прав суперпользователя].<br />
<br />
=== Правильное использование в фронт-энде ===<br />
<br />
Теперь вы готовы использовать VirtualBox. Поздравляем!<br />
<br />
Вы можете использовать несколько удобных команд VirtualBox:<br />
* Если вы хотите использовать VirtualBox в командной строке (только запускать и изменять настройки существующих виртуальных машин), вы можете использовать команду {{ic|VBoxSDL}}. VBoxSDL создаёт простое окно, которое содержит только ''чистую'' виртуальную машину, без меню или других элементов управления (фрейм-буфер).<br />
* Если вы хотите использовать VirtualBox в командной строке без любого GUI-интерфейса (например, на сервере) для создания, запуска и настройки виртуальных машин, используйте {{ic|VBoxHeadless}}, который не производит никакого видимого вывода на хост-машине, а только предоставляет данные VRDP.<br />
<br />
Если вы установили {{AUR|qt4}} из дополнительных зависимостей, у вас будет приятный GUI-интерфейс.<br />
<br />
Наконец, вы можете использовать [[PhpVirtualBox]] для управления виртуальными машинами из веб-интерфейса.<br />
<br />
Обратитесь к [https://www.virtualbox.org/manual руководству VirtualBox], чтобы узнать, как создавать виртуальные машины.<br />
<br />
{{Warning_(Русский)|Если вы собираетесь хранить образы виртуальных дисков в файловой системе [[Btrfs]] , то перед созданием каких-либо образов вы должны отключить журналирование [[Btrfs#Copy-on-Write (CoW)|Copy-on-Write]] для каталога с образами.}}<br />
<br />
== Пошаговая установка Arch Linux как гостевой ОС ==<br />
<br />
=== Установка Arch Linux в виртуальную машину ===<br />
<br />
{{Note (Русский)|Хостам с ОС Windows, возможно, придется отключить Hyper-V для того, чтобы использовать возможности виртуализации устройств и создания 64-битных виртуальных машин в VirtualBox. Чтобы узнать, как отключить или снова включить Hyper-V, [http://superuser.com/questions/684966/switch-off-hyper-v-without-disable-functionality-in-windows-8-1 посмотрите пост на StackOverflow]. }}<br />
<br />
Загрузите установочный носитель Arch через один из виртуальных дисков виртуальной машины. Затем совершите установку базовой системы Arch, как описано в [[Installation guide (Русский)|руководстве по установке]], без установки графических драйверов: мы будем устанавливать драйвера, поставляемые VirtualBox на следующем этапе.<br />
<br />
==== Установка в режиме EFI ====<br />
<br />
Если вы хотите установить Arch Linux в режиме EFI внутри VirtualBox, в настройках виртуальной машины, перейдите в закладку ''Настройки'', и установите флажок ''Enable EFI (special OSes only)''. После выбора ядра из меню установочного носителя Arch Linux, установка будут висеть в течение минуты-двух, и после этого будет загружено ядро . Подождите и не прекращайте установку.<br />
<br />
При загрузке в режиме EFI, VirtualBox будет пытаться выполнить {{ic|/EFI/BOOT/BOOTX64.EFI}} из ESP. Если первый вариант не удается, VirtualBox будет пытаться выполнить сценарий оболочки EFI {{ic|startup.nsh}} из корня ESP. Если вы не хотите вручную запускать загрузчик из оболочки EFI каждый раз, вы должны будете переместить свой загрузчик в этот путь по умолчанию. Не заморачивайтесь с VirtualBox Boot Manager (доступен по {{ic|F2}} при загрузке): EFI данные будут добавлены в него вручную при загрузке или {{Pkg|efibootmgr}} будет сохранять их после перезагрузки, [https://www.virtualbox.org/ticket/11177 но терять после закрытия виртуальной машины].<br />
<br />
=== Установка гостевых дополнений ===<br />
<br />
После завершения установки гостевой системы, установите [https://www.virtualbox.org/manual/ch04.html дополнения гостевой ОС], которые включают драйверы и приложения, оптимизирующие гостевую операционную систему. Они могут быть установлены с помощью {{Pkg|virtualbox-guest-utils}}, которая прикреплена к {{Pkg|virtualbox-guest-modules}}{{Broken package link (Русский)|replaced by {{Pkg|virtualbox-guest-modules-arch}}}} как необходимая зависимость.<br />
<br />
{{note_(Русский)|Метод, описанный в [https://www.virtualbox.org/manual/ch04.html#idp54932560 VirtualBox руководстве] не работает на гостевой Arch Linux, в результате {{ic|Unable to determine your Linux distribution}} несколько раз повторено, как сообщение об ошибке. Если Вы уже попробовали этот первый метод и вы используете правильное описанное выше решение впоследствии, это не удастся. Вы получите ошибку {{ic|/usr/bin/VBox* exists in filesystem}} и {{ic|/usr/lib/VBox* exists in filesystem}}. Решение заключается в удалении конфликтующих файлов: {{ic|# rm /usr/bin/VBox* /usr/lib/VBox*}} Эти файлы на самом деле являются символическими ссылками на места, где были установлены гостевые дополнения; По умолчанию, это {{ic|/opt/VBoxGuestAdditions-''номер версии''}}. Удалите и эти файлы {{ic|# rm -r /opt/VBoxGuestAdditions-''номер версии''}},так как они не нужны. Теперь вы можете перезапустить установку правильным, вышеописанным способом.}}<br />
<br />
=== Установка гостевых модулей ядра VirtualBox ===<br />
<br />
==== Запуск гостевой ОС с официальным ядром ====<br />
<br />
* Если вы используете ядро {{Pkg|linux}}, убедитесь, что пакет {{pkg|virtualbox-guest-modules}}{{Broken package link (Русский)|replaced by {{Pkg|virtualbox-guest-modules-arch}}}} установлен. {{pkg|virtualbox-guest-modules}}{{Broken package link (Русский)|replaced by {{Pkg|virtualbox-guest-modules-arch}}}} устанавливается как зависимость пакета {{Pkg|virtualbox-guest-utils}}.<br />
* Если вы используете LTS ядро ({{pkg|linux-lts}}), установите пакет {{AUR|virtualbox-guest-modules-lts}}. Пакет {{Pkg|virtualbox-guest-modules}}{{Broken package link (Русский)|replaced by {{Pkg|virtualbox-guest-modules-arch}}}} может быть удалён по вашему желанию.<br />
* Если вы используете ядро {{aur|linux-ck}}, скомпилируйте пакет {{aur|virtualbox-ck-guest-modules}}{{Broken package link (Русский)|package not found}}. Пакет {{Pkg|virtualbox-guest-modules}}{{Broken package link (Русский)|replaced by {{Pkg|virtualbox-guest-modules-arch}}}} также может быть удалён.<br />
<br />
==== Запуск гостевой ОС со сторонним ядром ====<br />
<br />
Этот шаг установки очень похож на настройку модулей ядра в разделе Vitualbox для хоста, описанную выше. Обратитесь к [[#Install the VirtualBox kernel modules|этому разделу]]{{Broken section link}} для получения дополнительной информации и замените все {{Pkg|virtualbox-host-modules}}{{Broken package link (Русский)|replaced by {{Pkg|virtualbox-host-modules-arch}}}}, {{Pkg|virtualbox-host-dkms}} и {{AUR|vboxhost-hook}}{{Broken package link (Русский)|{{aur-mirror (Русский)|vboxhost-hook}}}} на {{Pkg|virtualbox-guest-modules}}{{Broken package link (Русский)|replaced by {{Pkg|virtualbox-guest-modules-arch}}}}, {{Pkg|virtualbox-guest-dkms}} и {{AUR|vboxguest-hook}}{{Broken package link (Русский)|{{aur-mirror (Русский)|vboxguest-hook}}}} соответственно.<br />
<br />
=== Загрузка модулей ядра VirtualBox ===<br />
<br />
Для загрузки модуля вручную выполните:<br />
# modprobe -a vboxguest vboxsf vboxvideo<br />
<br />
Чтобы загрузить модуль VirtualBox во время загрузки системы, обратитесь к [[Kernel modules (Русский)#Автоматическое управление модулями|Загрузка ядра#Автоматическое управление модулями]] и создайте {{ic|*.conf}} файл (например, {{ic|virtualbox.conf}}) в директории {{ic|/etc/modules-load.d/}} с следующим содержанием:<br />
{{hc|/etc/modules-load.d/virtualbox.conf|<br />
vboxguest<br />
vboxsf<br />
vboxvideo}}<br />
<br />
Кроме того, команда<br />
# systemctl enable vboxservice <br />
включает автозагрузку модулей и синхронизацию времени хоста и гостевой ОС.<br />
<br />
=== Запуск гостевых сервисов VirtualBox ===<br />
<br />
После довольно непростой установки с модулями ядра VirtualBox, необходимо обеспечить взаимодействие гостевой ОС и хоста посредством сервисов. Гостевой сервис - на самом деле просто исполняемый файл, обращающийся к {{ic|VBoxClient}}, который будет взаимодействовать с вашей X Window System. {{ic|VBoxClient}} управляет следующими функциями:<br />
* Общий буфер обмена и перетаскивания между принимающей стороной и гостевой ОС;<br />
* Бесшовный оконный режим;<br />
* Гостевой дисплей автоматически изменяется в соответствии с размером окна гостевой ОС;<br />
* Проверка версии VirtualBox, установленной на хосте.<br />
<br />
Все эти особенности могут быть включены независимо следующими параметрами:<br />
$ VBoxClient --clipboard --draganddrop --seamless --display --checkhostversion<br />
<br />
Как ссылка, {{ic|VBoxClient-all}} bash скрипт позволяет использовать все эти функции. Вы должны установить {{ic|VBoxClient}}, который будет автоматически загружен в качестве [[Desktop_environment_(Русский)|DE]] или [[window manager_(Русский)|оконного менеджера]] <br />
<br />
На практике,<br />
* Если вы используете [[Desktop_environment_(Русский)|DE]], вам просто нужно установить флажок или добавить {{ic|/usr/sbin/VBoxClient-all}}} в разделе автозапуска вашей DE (DE обычно устанавливают флаг на ''.desktop'' файлы в {{ic|~/.config/autostart}}, см. [[Desktop_entries|настройку автозапуска]] для более подробной информации);<br />
* Если у вас нет каких-либо DE, добавьте следующую строку в начале [[Xinitrc (Русский)|~/.xinitrc]] перед любыми {{ic|exec}} функциями:<br />
{{hc|~/.xinitrc|<br />
/usr/bin/VBoxClient-all}}<br />
<br />
VirtualBox также может синхронизировать время между хостом и гостевой ОС. Чтобы сделать это, выполните {{ic|VBoxService}} с правами суперпользователя. Чтобы установить автоматический запуск этого кода при загрузке, выполните:<br />
# systemctl enable vboxservice<br />
<br />
Теперь у вас есть рабочая гостевая Arch Linux. Поздравляем!<br />
<br />
Если вы хотите расшарить директории между вашим компьютером и гостевым Arch Linux, читайте дальше.<br />
<br />
=== Расшаривание директорий ===<br />
<br />
Общие папки управляются в хосте через настройки виртуальной машины, доступной через графический интерфейс VirtualBox, на вкладке ''Shared Folders''. Там путь к директории и имя точки монтирования определены как ''Имя папки'' и аргументы, такие как ''Read-only'', ''Auto-mount'' и ''Make permanent'' Эти параметры могут быть определены через утилиту {{ic|VBoxManage}}. См. [https://www.virtualbox.org/manual/ch04.html#sharedfolders для более подробной информации].<br />
<br />
Независимо от того, какой метод вы будете использовать, чтобы смонтировать директорию, требуются некоторые начальные действия.<br />
<br />
Чтобы избежать проблемы {{ic|/sbin/mount.vboxsf: mounting failed with the error: No such device}}, убедитесь, что модуль ядра {{ic|vboxsf}} загружен правильно. Он должен быть загружен, поскольку мы включили все гостевые модули ядра ранее.<br />
<br />
Два дополнительных шага необходимы для того, чтобы точки монтирования должны быть доступны из пользователей кроме root-а:<br />
* Пакет {{Pkg|virtualbox-guest-utils}} создает группу {{ic|vboxsf}}; <br />
* Ваше имя пользователя должно быть в этой группе, используйте команду {{ic|gpasswd -a $USER vboxsf}}, чтобы добавить свое имя пользователя и запустите {{ic|newgrp}}, чтобы применить изменения немедленно.<br />
<br />
==== Ручное монтирование ====<br />
<br />
Выполните следующую команду для монтирования директории в гостевой Arch Linux:<br />
# mount -t vboxsf ''имя_расшариваемой_директории'' ''точка_монтирования_в_гостевой_ОС''<br />
<br />
Файловая система {{ic|vboxsf}} предоставляет и другие способы, просмотреть которые можно выполнив:<br />
# mount.vboxsf<br />
<br />
Например, если пользователь не добавлен в ''vboxsf'' группу, мы могли бы использовать эту команду, чтобы смонтировать директорию в гостевой ОС:<br />
# mount -t vboxsf -o uid=1000,gid=1000 home /mnt/<br />
<br />
Где ''UID'' и ''GID'' являются значениями, соответствующими пользователям, которым мы хотим дать доступ к монтированию директории. Эти значения можно узнать из вывода команды {{ic|id}}, выполненной из сессии этого пользователя.<br />
<br />
==== Автомонтирование ====<br />
<br />
Чтобы функция автоматического монтирования заработала, вы должны включить флажок в графическом интерфейсе или использовать дополнительный аргумент {{ic|--automount}} при команде {{ic|VBoxManage общая_директория}}<br />
<br />
Теперь общая директория должна появиться в {{ic|/media/sf_''имя_расшаренной_директории''}}.<br />
<br />
Вы можете использовать символические ссылки, если хотите иметь более удобный доступ:<br />
<br />
$ ln -s /media/sf_''имя_расшаренной_директории'' ~/''мои_документы''<br />
<br />
==== Монтирование при загрузке ====<br />
<br />
Вы можете монтировать директории с помощью [[fstab_(Русский)|fstab]]. Во избежание проблем с systemd, необходимо добавить в {{ic|/etc/fstab}} строчку {{ic|1=comment=systemd.automount}}. <br />
Таким образом, общие папки монтируются только тогда, когда доступны точки подключения, а не во время запуска. Это может избежать некоторых проблем, особенно если гостевая ОС еще не загружена, когда systemd уже начал читать fstab и монтировать разделы.<br />
desktop /media/desktop vboxsf uid=user,gid=group,rw,dmode=700,fmode=600,comment=systemd.automount 0 0<br />
<br />
mount.vboxsf [https://www.virtualbox.org/ticket/10676| может не поддерживать] ''nofail'' аргумент:<br />
desktop /media/desktop vboxsf uid=user,gid=group,rw,dmode=700,fmode=600,nofail 0 0<br />
<br />
== Импорт/экспорт виртуальных машин VirtualBox в/из других гипервизоров ==<br />
<br />
Если вы планируете использовать виртуальную машину на другом гипервизоре или хотите импортировать в VirtualBox виртуальную машину, созданную в другом гипервизоре, вы можете быть заинтересованы в чтении следующих шагов.<br />
<br />
=== Удаление дополнений гостевой ОС ===<br />
<br />
Гостевые дополнения доступны в большинстве гипервизоров: VirtualBox поставляется с гостевыми дополнениями, VMware с VMware Tools, Parallels с инструментами Parallels, и т.д. Это дополнительные компоненты, предназначенные для установки внутри виртуальной машины после гостевой операционной системы, состоящие из драйверов устройств и системных приложений, которые оптимизируют гостевую операционной системы для повышения производительности и удобства использования. [https://www.virtualbox.org/manual/ch04.html Читать подробнее].<br />
<br />
Если у вас установлены дополнения в вашей виртуальной машине - удалите их в первую очередь. Ваша гостевая ОС, особенно если это ОС из семейства Windows, может вести себя странно, аварийно или не загрузиться вообще, если вы используете специальные драйверы одного гипервизора на другом.<br />
<br />
=== Использование правильного формата виртуального диска ===<br />
<br />
От этого шага будет зависеть способность преобразовывать образ диска виртуальной в другие форматы - непосредственно или конвейерным методом.<br />
<br />
==== Автоматические инструменты ====<br />
<br />
Некоторые компании предоставляют инструменты, которые предлагают возможность создания виртуальных машин с операционной системой Windows или GNU / Linux, расположенной в виртуальной машине или даже в оригинальной установке. С таким продуктом вам не нужно применять этот и следующие шаги, и можно далее не читать.<br />
* ''[Http://www.parallels.com/products/transporter Parallels Transporter]'' - не бесплатный, продукт от Parallels Inc. Это решение в основном заключается в части программного обеспечения под названием ''агент'', который будет установлен в гостевой ОС, которую вы хотите импортировать / преобразовать. Затем, Parallels Transporter, ''который работает только на OS X'' , создаст виртуальную машину с этим ''агентом'', который контактирует либо по USB или по сети Ethernet.<br />
* ''[Https://www.vmware.com/products/converter/ VMware vCenter Converter]'' - бесплатен при регистрации на Webiste VMware, работает почти так же, как Parallels Transporter, но часть программного обеспечения, которая собирает данные для создания виртуальной машины работает только на платформе Windows.<br />
<br />
==== Ручное преобразование ====<br />
<br />
Во-первых, ознакомьтесь с [[#Форматы, поддерживаемые VirtualBox|форматами, поддерживаемыми Virtualbox]] и [[Wikipedia:Comparison of platform virtual machines#Image type compatibility|форматами других гипервизоров]].<br />
<br />
* Импорт и экспорт виртуальной машины из/в формат VMware не является проблемой, если вы используете формат диска VMDK или OVF, в противном случае преобразования [[#VMDK в VDI и VDI в VMDK|VMDK в VDI и VDI в VMDK]] можно осуществить вышеописанным VMware vCenter Converter.<br />
<br />
* Импорт и экспорт из/в QEMU почти не проблема: некоторые форматы QEMU поддерживает непосредственно VirtualBox и преобразование между [[#QCOW2 в VDI и VDI в QCOW2|QCOW2 в VDI и VDI в QCOW2]] по-прежнему доступны в случае необходимости.<br />
<br />
* Импорт и экспорт из/в Parallels гипервизора является трудный задачей: Parallels поддерживает только свой собственный формат жесткого диска (даже стандартные форматы и портативный формат OVF не поддерживается!).<br />
:* Чтобы экспортировать виртуальную машину для Parallels, вам нужно будет использовать инструмент описанной выше Parallels - Transporter.<br />
:* Чтобы импортировать виртуальную машину в VirtualBox, вы должны будете использовать VMware vCenter Converter , чтобы преобразовать виртуальную машину в формат VMware в первую очередь - а затем используйте инструмент для миграции с VMware.<br />
<br />
=== Создание конфигурации VM для гипервизора ===<br />
<br />
Каждый гипервизор имеет свой собственный файл конфигурации виртуальной машины: {{ic|.vbox}} для VirtualBox, {{ic|.vmx}} для VMware, {{ic|config.pvs}} файл, расположенный в виртуальной машине ({{ic|.pvm}} файл), и т.д. Вы можете, таким образом, создать новую виртуальную машину в новом гипервизоре и указать его конфигурацию как можно ближе относительно начальной виртуальной машины.<br />
<br />
Обратите пристальное внимание на интерфейс прошивки (BIOS или UEFI), используемый для установки гостевой операционной системы. В то время как опция доступна выбирать между этими 2 интерфейсов на VirtualBox и на Parallels решений, на VMware, вам придется вручную добавить следующую строку в ваш ''.vmx'' файл.<br />
<br />
{{hc|ArchLinux_vm.vmx|2=<br />
firmware = "efi"<br />
}}<br />
<br />
Наконец, настройте ваш гипервизор, для использования существующего виртуального диска, который вы преобразовали и запустите виртуальную машину.<br />
{{tip_(Русский)|<br />
* В VirtualBox, если вы не хотите просмотривать весь графический интерфейс, чтобы найти нужное место где можно добавить новый виртуальный диск устройства, вы можете [[#Замена виртуального диска из файла .vbox вручную|Заменить виртуальный диск вручную из файла .vbox]], или использовать {{ic|VBoxManage storageattach}}, описанный в [[#Увеличение размера виртуальных дисков|увеличении вируального диска]] или в [https://www.virtualbox.org/manual/ch08.html#vboxmanage-storageattach руководстве VirtualBox]<br />
* Кроме того, в продуктах VMware, вы можете заменить местоположение текущего местоположения виртуального диска путем адаптации ''.vmdk'' местоположения файла в ''.vmx'' конфигурационном файле.}}<br />
<br />
== Управление виртуальными дисками ==<br />
<br />
=== Форматы, поддерживаемые VirtualBox ===<br />
<br />
VirtualBox поддерживает следующие форматы виртуальных дисков:<br />
<br />
* VDI: Virtual Disk Image является собственным стандартои VirtualBox, используемыи по умолчанию, когда вы создаете виртуальную машину в VirtualBox.<br />
<br />
* VMDK: изначально разработан VMware для своих продуктов.Спецификация была закрытым исходным кодом, но сейчас стало открытым форматом, который полностью поддерживается VirtualBox. Этот формат дает возможность разбивать себя на несколько файлов по 2 Гб. Эта функция особенно полезна, если вы хотите сохранить виртуальную машину на компьютерах, которые не поддерживают очень большие файлы. Другие форматы, за исключением формата HDD от Parallels, не обеспечивают такую эквивалентную функцию.<br />
<br />
* VHD: Virtual Hard Disk - формат, используемый в Microsoft в Windows Virtual PC и Hyper-V. Если вы собираетесь использовать любой из этих продуктов Microsoft, вы должны будете выбрать этот формат.<br />
: {{tip_(Русский) | Начиная с Windows 7, этот формат может быть установлен непосредственно без каких-либо дополнительных приложений.}}<br />
<br />
* VHDX (только для чтения): Это расширенная версия формата виртуального жесткого диска, разработанного Microsoft, которая была выпущена на 2012-09-04 с Hyper-V 3.0 при переходе на Windows Server 2012. Эта новая версия имеет повышенную производительность (лучшее расположение блоков), большие размеры блоков и поддержку журнала. VirtualBox [https://www.virtualbox.org/manual/ch15.html#idp63002176 поддерживает этот формат только для чтения].<br />
<br />
* Версия 2 HDD: Формат HDD разработан Parallels Inc и используются в их гипервизоре, например Parallels Desktop для Mac. Новые версии этого формата (т.е. 3 и 4) не поддерживаются из-за отсутствия документации для этого форматф. {{note_(Русский) | Существуют споры в отношении поддержки версии 2 формата. Официальное руководство VirtualBox [https://www.virtualbox.org/manual/ch05.html#vdidetails сообщает, что поддерживается только 2 версия], авторы Википедии утверждают,что [[Wikipedia: Comparison of platform virtual machines # Image type compatibility|частично может работать и первая версия]]. Приветствуется помощь, если вы можете выполнить некоторые тесты с первой версией формата HDD.}}<br />
<br />
* QED: Формат Enhanced Disk QEMU - старый формат для QEMU, свободный и открытый. Этот формат был разработан в 2010 году таким образом, чтобы обеспечить превосходную альтернативу qcow2 и другим форматам. Этот формат имеет полностью асинхронный ввод / вывод, хорошую целостность данных, откат файлов и разреженные файлы. Формат QED поддерживается только для совместимости с виртуальными машинами, созданными в старых версиях QEMU.<br />
<br />
* QCOW: QEMU CoW - нынешний формат для QEMU.Формат QCOW поддерживает прозрачное сжатие на основе ZLIB и шифрование (последнее имеет недостаток, и не рекомендуется к сипользованию). QCOW доступен в двух версиях: QCOW и qcow2. Последний, как правило, заменяет первый. QCOW [https://www.virtualbox.org/manual/ch15.html#idp63002176 в настоящее время поддерживается VirtualBox]. Qcow2 поставляется в двух версиях: qcow2 0.10 и qcow2 1.1 (по умолчанию используемый при создании виртуального диска с QEMU). VirtualBox не поддерживает qcow2.<br />
<br />
* OVF: Open Virtualization Format является открытым форматом, который был разработан для обеспечения взаимодействия и распределения виртуальных машин между различными гипервизоров. VirtualBox поддерживает все версии этого формата через [https://www.virtualbox.org/manual/ch08.html#idp55423424 {{ic|VBoxManage}} импорт / экспорт], но с [https: //www.virtualbox.org/manual/ch14.html#KnownProblems известными ограничениями].<br />
<br />
* RAW: Это режим, когда виртуальный диск скидывается непосредственно на диск без определенного формата файл контейнера. VirtualBox поддерживает эту функцию несколькими способами: преобразование RAW диск [https://www.virtualbox.org/manual/ch08.html#idp59139136 к определенному формату], или [https://www.virtualbox.org/manual/ch08.html#VBoxManage-clonevdi клонированием диска в формате RAW], или непосредственно через файл VMDK, [https://www.virtualbox.org/manual/ch09.html#idp57804112 который указывает на физический диск или просто файл].<br />
<br />
=== Преобразование виртуальных дисков разных форматов ===<br />
<br />
==== VMDK в VDI и VDI в VMDK ====<br />
<br />
VirtualBox может конвертировать VDI в VMDK и обратно с использованием [https://www.virtualbox.org/manual/ch08.html#vboxmanage-clonevdi {{ic|VBoxManage clonehd}}].<br />
<br />
VMDK в VDI:<br />
<br />
$ VBoxManage clonehd ''source.vmdk'' ''destination.vdi'' --format VDI<br />
<br />
VDI в VMDK:<br />
<br />
$ VBoxManage clonehd ''source.vdi'' ''destination.vmdk'' --format VMDK<br />
<br />
==== VHD в VDI и VDI в VDH ====<br />
<br />
VirtualBox также может конвертировать VHD в VDI и наоборот с использованием [https://www.virtualbox.org/manual/ch08.html#vboxmanage-clonevdi {{ic|VBoxManage clonehd}}]:<br />
<br />
VHD в VDI:<br />
<br />
$ VBoxManage clonehd ''source.vhd'' ''destination.vdi'' --format VDI<br />
<br />
VDI в VHD:<br />
<br />
$ VBoxManage clonehd ''source.vdi'' ''destination.vhd'' --format VHD<br />
<br />
==== QCOW2 в VDI и VDI в QCOW2 ====<br />
<br />
[https://www.virtualbox.org/manual/ch08.html#vboxmanage-clonevdi {{ic|VBoxManage clonehd}}] не может конвертировать QEMU форматы и необходимо воспользоваться иными инструментами. Команда {{ic|qemu-img}} из пакета {{Pkg|qemu}} может осуществлять преобразования QCOW2<=>VDI. {{note_(Русский)|{{ic|qemu-img}} также обрабатывает кучу других форматов. В соответствии выводу {{ic|qemu-img --help}}, {{ic|qemu-img}} поддерживает данные форматы : "''vvfat vpc vmdk vhdx vdi ssh sheepdog sheepdog sheepdog raw host_cdrom host_floppy host_device file qed qcow2 qcow parallels nbd nbd nbd iscsi dmg tftp ftps ftp https http cow cloop bochs blkverify blkdebug'".}}<br />
<br />
QCOW2 в VDI:<br />
<br />
$ qemu-img convert -pO vdi ''source.qcow2'' ''destination.vdi''<br />
<br />
VDI в QCOW2:<br />
<br />
$ qemu-img convert -pO qcow2 ''source.vdi'' ''destination.qcow2''<br />
<br />
Так как QCOW2 предостовляется в двух версиях (0.10 и 1.1) (см. [[#Форматы, поддерживаемые VirtualBox|форматы, поддерживаемые VirtualBox]]. Используйте параметр {{ic|1=-o compat=}} для выбора версии.<br />
<br />
$ qemu-img convert -pO qcow2 ''source.vdi'' ''destination.qcow2'' -o compat=0.10<br />
или<br />
$ qemu-img convert -pO qcow2 ''source.vdi'' ''destination.qcow2'' -o compat=1.1<br />
<br />
{{tip_(Русский)|Параметр {{ic|-p}} отображает прогресс выполнения преобразования.}}<br />
<br />
=== Монтирование виртуальных дисков ===<br />
<br />
==== VDI ====<br />
<br />
Монтирование образов VDI работает только с образами фиксированного размера (т.е. статичными образами); динамические образы (динамическое выделение размера) монтируются довольно-таки не просто.<br />
<br />
Если необходимо смещение раздела (в VDI), добавьте значение {{ic|offData}} в {{ic|32256}} (например, 69632 + 32256 = 101888):<br />
<br />
$ VBoxManage internalcommands dumphdinfo <storage.vdi> | grep "offData"<br />
<br />
Теперь cмонтируем:<br />
<br />
# mount -t ext4 -o rw,noatime,noexec,loop,offset=101888 <storage.vdi> /mntpoint/<br />
<br />
Вы также можете использовать скрипт [https://github.com/pld-linux/VirtualBox/blob/master/mount.vdi mount.vdi], который можно использовать (и даже установить скрипт в {{ic|/usr/bin/}}:<br />
<br />
# mount -t vdi -o fstype=ext4,rw,noatime,noexec ''vdi_file_location'' ''/mnt/''<br />
<br />
Также можно использовать модули ядра {{Pkg|qemu}} , которые выполняют эту же функцию [http://bethesignal.org/blog/2011/01/05/how-to-mount-virtualbox-vdi-image/ attrib]:<br />
<br />
# modprobe nbd max_part=16<br />
# qemu-nbd -c /dev/nbd0 <storage.vdi><br />
# mount /dev/nbd0p1 /mnt/dir/<br />
# # to unmount:<br />
# umount /mnt/dir/<br />
# qemu-nbd -d /dev/nbd0<br />
<br />
Если файлы раздела не распространяются, попробуйте использовать {{ic|partprobe /dev/nbd0}}. В противном случае, VDI раздел может быть отображен непосредственно в файл с помощью {{ic|qemu-nbd -P 1 -c /dev/nbd0 <storage.vdi>}}.<br />
<br />
=== Сжатие виртуальных дисков ===<br />
<br />
Сжатие работает только с файлами {{ic|.vdi}} и в основном состоит из следующих действий: <br />
<br />
Загрузите виртуальную машину и удалите все ненужное вручную или с помощью специальных средств, например {{Pkg|bleachbit}} ([http://bleachbit.sourceforge.net/download/windows доступна для ОС Windows]).<br />
<br />
Затирание свободного места нулями может быть выполнено следующими инструментами:<br />
* Если вы пользовались Bleachbit, просто установите галочку ''System > Free disk space'' в графическом интерфейсе, выполните команду {{ic|bleachbit -c system.free_disk_space}};<br />
* В UNIX-based системах, выполните команду {{ic|dd}} или, предпочтительно, {{Pkg|dcfldd}} (см. [http://superuser.com/a/355322 здесь] информацию об отличиях):<br />
:{{bc|1=# dcfldd if=/dev/zero of=''/fillfile'' bs=4M}}<br />
:Когда {{ic|fillfile}} достигает лимита раздела, вам будет выдано сообщение вида {{ic|1280 blocks (5120Mb) written.dcfldd:: No space left on device}}. Это означает, что все пространство пользователя и незарезервированные блоки раздела будут затерты. Используя эту команду от суперпользователя, важно убедится в том, что все свободные блоки затерты. По умолчанию некий процент блоков ФС зарезервирован для супер-пользователя (см. вывод {{ic|-m}} аргумента при команде {{ic|mkfs.ext4}} или используйте {{ic|tune2fs -l}} чтобы увидеть, сколько места зарезервировано под приложения запущенные от root).<br />
:Когда вышеописанный процесс будет завершён, вы можете удалить созданный вами файл {{ic|''fillfile''}}.<br />
<br />
* В ОС Windows есть два инструмента:<br />
:*{{ic|sdelete}} - [http://technet.microsoft.com/en-us/sysinternals/bb842062.aspx Sysinternals Suite], выполните {{ic|sdelete -s ''c:''}} для каждого виртуального диска;<br />
:* Для любителей PowerShell есть скрипт [http://blog.whatsupduck.net/2012/03/powershell-alternative-to-sdelete.html PowerShell solution]. Его также необходимо отдельно выполнять для каждого виртуального диска.<br />
::{{bc|PS> ./Write-ZeroesToFreeSpace.ps1 -Root ''c:\'' -PercentFree 0}}<br />
::{{note_(Русский)|Этот скрипт должен быть запущен в среде PowerShell от имени администратора. По дефолту скрипты не запускаются из-за ограничений политик безопасности. Необходимо установить необходимое значение параметра {{ic|Get-ExecutionPolicy}} в политиках безопасности: {{ic|Set-ExecutionPolicy RemoteSigned}}.}}<br />
<br />
Перезагрузите виртуальную машину.<br />
После выполнения задач и перезагрузки виртуальной машины рекомендуется провести проверку диска.<br />
* В UNIX-based системах можно использовать {{ic|fsck}};<br />
:* В GNU/Linux системах, в том числе Arch Linux, вы можете установить проверку диска при загрузке вручную [[Fsck#Forcing the check|в параметрах загрузки ядра]];<br />
* В Windows системах:<br />
:* {{ic|chkdsk ''c:'' /F}} где {{ic|''c:''}} заменяется на имя проверяемого диска;<br />
:* или {{ic|FsckDskAll}} [http://therightstuff.de/2009/02/14/ChkDskAll-ChkDsk-For-All-Drives.aspx отсюда], который основан на {{ic|chkdsk}}, но не требует перезапуска для каждого отдельного диска;<br />
<br />
Теперь удалите нули из {{ic|vdi}} файлов с помощью {{ic|[https://www.virtualbox.org/manual/ch08.html#vboxmanage-modifyvdi VBoxManage modifyhd]}}:<br />
$ VBoxManage modifyhd ''your_disk.vdi'' --compact<br />
<br />
{{note_(Русский)|Если в вашей виртуальной машине есть снимки, вам необходимо выполнить команду для всех ваших {{ic|.vdi}} файлов.}}<br />
<br />
=== Увеличение размера виртуальных дисков ===<br />
<br />
Если вы выходите за рамки пространства жесткого диска, которое выбрали при создании виртуальной машины, проблему можно решить по совету из руководства VirtualBox [https://www.virtualbox.org/manual/ch08.html#VBoxManage-modifyvdi {{ic|VBoxManage modifyhd}}]. Эта команда работает только для динамически расширяемых дисков VDI и VHD . Если вы хотите изменить размер фиксированного виртуального диска, можете использовать нижеописанный трюк, который работает и на виртуальной машине Windows, и в UNIX-подобных системах.<br />
<br />
Во-первых, создайте новый виртуальный диск рядом с тем, который вы хотите увеличить:<br />
<br />
$ VBoxManage createhd -filename '' new.vdi '' --size '' 10000 ''<br />
<br />
где размер указан в MiB, в этом примере 10000MiB ~ = 10GiB, ''new.vdi'' - имя создаваемого нового виртуального диска.<br />
<br />
Далее старый виртуальный диск должен быть клонирован в новый(это может занять длительной время):<br />
<br />
$ VBoxManage clonehd ''old.vdi'' '' ew.vdi'' --existing<br />
<br />
{{note_(Русский)|По умолчанию, эта команда использует ''Standard'' (что соответствует динамическому выделению) формату файла диска, и, следовательно, не будет использовать тот же формат в качестве формата исходного виртуального диска. Если ваш ''old.vdi'' имеет фиксированный размер, и вы хотите, чтобы новый диск был тоже фиксированным, добавьте параметр {{ic|--variant Fixed}}.}}<br />
<br />
Отключите старый диск и установите новый, обязательно заменив все выделенные курсивом аргументы на свои:<br />
<br />
$ VBoxManage storageattach ''VM_name'' --storagectl ''SATA'' --port ''0'' --medium none<br />
$ VBoxManage storageattach ''VM_name'' --storagectl ''SATA'' --port ''0'' --medium ''new.vdi'' --type hdd<br />
<br />
Чтобы получить имя контроллера диска и номер порта, вы можете использовать команду {{ic|VBoxManage showvminfo ''VM_name''}}. Среди вывода вы получите такой результат (то, что вы ищете выделено курсивом):<br />
<br />
{{bc|<br />
[...]<br />
Storage Controller Name (0): IDE<br />
Storage Controller Type (0): PIIX4<br />
Storage Controller Instance Number (0): 0<br />
Storage Controller Max Port Count (0): 2<br />
Storage Controller Port Count (0): 2<br />
Storage Controller Bootable (0): on<br />
Storage Controller Name (1): SATA<br />
Storage Controller Type (1): IntelAhci<br />
Storage Controller Instance Number (1): 0<br />
Storage Controller Max Port Count (1): 30<br />
Storage Controller Port Count (1): 1<br />
Storage Controller Bootable (1): on<br />
IDE (1, 0): Empty<br />
''SATA'' (''0'', 0): /home/wget/IT/Virtual_machines/GNU_Linux_distributions/ArchLinux_x64_EFI/Snapshots/{6bb17af7-e8a2-4bbf-baac-fbba05ebd704}.vdi (UUID: 6bb17af7-e8a2-4bbf-baac-fbba05ebd704)<br />
[...]}}<br />
<br />
Скачайте [http://gparted.org/download.php GParted LiveCD] и установите его в качестве виртуального привода , загрузите вашу виртуальную машину, используйте увеличение / перемещение ваших разделов. По окончании работы отмонтируйте GParted LiveCD и перезагрузите машину.<br />
<br />
{{Примечание | На GPT дисках, увеличение размера диска приведет к созданию резервной копии заголовка GPT в месте, отличном от конца устройства. GParted попросит, чтобы исправить проблему, нажать на ''исправить'' два раза. На дисках MBR такой проблемы не возникнет.}}<br />
<br />
Наконец, отключите старый виртуальный диск в VirtualBox и удалите его:<br />
<br />
$ VBoxManage closemedium disk ''old.vdi''<br />
$ rm ''old.vdi''<br />
<br />
=== Замена виртуального диска из файла .vbox вручную===<br />
<br />
Если вы думаете, что редактирование простого ''XML'' файла более удобно, чем возня с GUI или {{ic|VBoxManage}} и вы хотите заменить (или добавить) виртуальный диск в вашей виртуальной машине, просто замените GUID, местоположение файла и формат для ваших нужд в конфигурационном файле ''.vbox'', соответствующем вашей виртуальной машине:<br />
<br />
{{hc|ArchLinux_vm.vbox|2=<br />
<HardDisk uuid="''{670157e5-8bd4-4f7b-8b96-9ee412a712b5}''" location="''ArchLinux_vm.vdi''" format="''VDI''" type="Normal"/><br />
}}<br />
<br />
в {{ic|<AttachedDevice>}} (суб-тег {{ic|<StorageController>}}) замените старый GUID на новый.<br />
<br />
{{hc|ArchLinux_vm.vbox|2=<br />
<AttachedDevice type="HardDisk" port="0" device="0"><br />
<Image uuid="''{670157e5-8bd4-4f7b-8b96-9ee412a712b5}''"/><br />
</AttachedDevice><br />
}}<br />
<br />
<br />
{{note_(Русский)|Если вы не знаете GUID диска который вы хотите добавить, вы можете использовать {{ic|VBoxManage showhdinfo ''file''}}. Если раньше вы использовали {{ic|VBoxManage clonehd}}, для копирования или конвертирования виртуальных дисков, он выводит GUID после завершения копирования / преобразования. Применение случайного GUID не работает, так как каждый [http://www.virtualbox.org/manual/ch05.html#cloningvdis UUID хранится внутри любого образа диска].}}<br />
<br />
=== Клонирование виртуального диска и назначение ему нового UUID ===<br />
<br />
UUID широко используются VirtualBox. Каждая виртуальная машина и каждый виртуальный диск виртуальной машины должны иметь разные UUID. Когда вы запускаете виртуальную машину в VirtualBox, он будет отслеживать все UUID. См [http://www.virtualbox.org/manual/ch08.html#vboxmanage-list {{ic|VBoxManage list}}], чтобы просмотреть список элементов, зарегистрированных в VirtualBox.<br />
<br />
Если вы клонировали виртуальный диск вручную путем копирования файла виртуального диска, необходимо будет назначить новый UUID клонированному виртуальному диску. Вы можете использовать этот диск в той же виртуальной машине или даже в другой (если он уже открыт и таким образом зарегистрирован в VirtualBox).<br />
<br />
Вы можете использовать эту команду, чтобы назначить новый UUID для вашего виртуального диска:<br />
$ VBoxManage internalcommands sethduuid ''/path/to/disk.vdi''<br />
<br />
{{tip_(Русский)|В будущем, чтобы избежать копирования виртуального диска и назначения нового UUID вручную, используйте {{ic|[http://www.virtualbox.org/manual/ch08.html#vboxmanage-clonevdi VBoxManage clonehd]}}.}}<br />
<br />
{{note_(Русский) | Все указанные команды поддерживают [[#Форматы, поддерживаемые VirtualBox|все форматы виртуальных дисков, поддерживаемые VirtualBox]].}}<br />
<br />
== Расширенная настройка ==<br />
<br />
=== Управление запуском виртуальной машины ===<br />
<br />
==== Запуск виртуальный машин как сервиса systemd ====<br />
<br />
<br />
{{hc|/etc/systemd/system/vboxvmservice@.service|2=<br />
[Unit]<br />
Description=VBox Virtual Machine %i Service<br />
Requires=systemd-modules-load.service<br />
After=systemd-modules-load.service<br />
<br />
[Service]<br />
User=''username''<br />
Group=vboxusers<br />
ExecStart=/usr/bin/VBoxHeadless -s %i<br />
ExecStop=/usr/bin/VBoxManage controlvm %i savestate<br />
<br />
[Install]<br />
WantedBy=multi-user.target<br />
}}<br />
<br />
{{note_(Русский)|Замените {{ic|''username''}} на имя вашего пользователя и добавьте его в группу {{ic|vboxusers}}. Убедитесь, что это именно тот пользователь, который управляет созданием VM. Иначе ничего не получится}}<br />
<br />
{{note_(Русский)|Если у вас есть несколько машин запускаемых {{ic|Systemd}}, и они завершаются некорректно, попробуйте добавить {{ic|RemainAfterExit&#61;true}} и {{ic|KillMode&#61;none}} в конец {{ic|[Service]}} секции.}}<br />
<br />
Для запуска VM начиная с следующей загрузки, выполните:<br />
# systemctl enable vboxvmservice@''your_virtual_machine_name''<br />
<br />
Для запуска же в текущий момент времени выполните:<br />
# systemctl start vboxvmservice@''your_virtual_machine_name''<br />
<br />
VirtualBox 4.2 [http://lifeofageekadmin.com/how-to-set-your-virtualbox-vm-to-automatically-startup/ предоставляет] для UNIX-like систем также другие способы автозапуска, без использования сервисов systemd.<br />
<br />
==== Запуск виртуальной машины по горячей клавише ====<br />
<br />
Может быть полезно запускать виртуальные машины непосредственно с клавиатуры вместо использования интерфейса VirtualBox (GUI или CLI). Для этого, вы можете просто определить ключевые привязки в {{ic|.xbindkeysrc}}. Обратитесь к [[Xbindkeys_(Русский)|Xbindkeys]] для более подробной информации.<br />
<br />
Например, запуск по {{ic|Fn+F3}}:<br />
"VBoxManage startvm 'Windows 7'"<br />
m:0x0 + c:244<br />
XF86Battery<br />
<br />
{{note_(Русский)|Если у вас есть пробел в имени виртуальной машины, то заключите его в одинарные апострофы как сделано в вышеуказанном примере.}}<br />
<br />
=== Использование конкретных устройств в виртуальной машине ===<br />
<br />
<br />
==== Использование USB веб-камеры/микрофона ====<br />
<br />
{{note_(Русский) |Вам понадобятся установленные гостевые дополнения, прежде чем следовать приведенному ниже примеру. См. [[#Образ диска с гостевыми дополнениями|Дополнения гостевой ОС]] для более подробной информации.}}<br />
<br />
# Убедитесь, что виртуальная машина не работает, а веб-камера / микрофон не используется.<br />
# Вызовите главное окно VirtualBox и перейдите к настройкам для Arch машины. Перейдите в раздел USB.<br />
# Убедитесь, что стоит галочка "Включить USB-контроллер". Также убедитесь, что выбран пункт "Разрешить USB 2.0 (EHCI) контроллер"<br />
# Нажмите кнопку "Добавить фильтр с устройства" (кабельное со значком «+»).<br />
# Выберите USB веб-камеру/микрофон из списка.<br />
# Нажмите кнопку ОК и запустите VM.<br />
<br />
==== Обнаружение веб-камер и прочих USB устройств ====<br />
<br />
Убедитесь, что вы фильтруете любые устройства, (кроме клавиатур или мышей), чтобы они не запускались при загрузке -это гарантирует, что ОС Windows обнаружит устройство при запуске.<br />
<br />
=== Доступ к гостевому серверу ===<br />
<br />
Для доступа к [[Wikipedia:Apache_HTTP_Server|Apache серверу]] в виртуальной машине только с хост-машины, выполните:<br />
$ VBoxManage setextradata GuestName "VBoxInternal/Devices/''pcnet''/0/LUN#0/Config/Apache/HostPort" ''8888''<br />
$ VBoxManage setextradata GuestName "VBoxInternal/Devices/''pcnet''/0/LUN#0/Config/Apache/GuestPort" ''80''<br />
$ VBoxManage setextradata GuestName "VBoxInternal/Devices/''pcnet''/0/LUN#0/Config/Apache/Protocol" TCP<br />
Where 8888 is the port the host should listen on and 80 is the port the VM will send Apache's signal on.<br />
Где 8888 порт должна слушать хост-система, а VM шлет сигнал Apache на 80 порт.<br />
<br />
Чтобы использовать порт ниже, чем 1024 на хост-машине, изменения должны быть внесены в брандмауэр на этом хосте. Он также может быть настроен на работу с SSH или иных услуг путем изменения «Apache» с соответствующими сервисами и портами.<br />
<br />
{{note_(Русский)|{{ic|pcnet}} относится к сетевой карте виртуальной машины. Если вы используете карту Intel в VM, необходимо изменить {{ic|pcnet}} на {{ic|e1000}}.}}<br />
<br />
=== D3D ускорение в гостевой Windows ===<br />
<br />
Последние версии Virtualbox имеют поддержку ускорения OpenGL внутри гостевой ОС. Эта функция может быть включена галочкой в настройках машины (при установленных дополнениях гостевой ОС VirtualBox). Тем не менее, большинство игр под Windows используют Direct3D (часть DirectX), а не OpenGL, и, таким образом, этот метод не поможет. Тем не менее возможно получить ускоренное Direct3D в гостевой Windows, за счет заимствования D3D библиотеки из Wine, который переводит инструкции d3d под OpenGL, который и занимается ускорением. Эти библиотеки теперь являются частью дополнений гостевой ОС.<br />
<br />
После включения OpenGL ускорения, как описано выше, перезагрузите гостевую ОС в безопасном режиме (нажмите F8 до появления экрана для Windows, но после исчезновения экрана Virtualbox), и установите дополнения гостевой ОС, во время установки установите галочку ''Включить поддержку Direct3D''. Перезагрузитесь обратно в нормальный режим, и вы получите ускоренный Direct3D.<br />
<br />
{{note_(Русский) | Этот хак может может не работать для некоторых игр, в зависимости от того, какую аппаратную проверку они делают и какие части D3D они используют}}<br />
{{note_(Русский) | Хак был проверено на Windows XP, 7 и 8,1. Если метод не работает на версии Windows, пожалуйста, добавьте эту информацию здесь.}}<br />
<br />
=== VirtualBox c USB-ключом ===<br />
<br />
При использовании VirtualBox с USB-ключом, например, для запуска установленной машины с ISO-образа, вы вручную должны создать VDMK-файлы существующих приводов. Тем не менее, как только новые файлы VMDK сохраняться и вы перейдёте на другую машину, у вас могут снова возникнуть проблемы. Чтобы избавиться от этой проблемы, можно использовать следующий скрипт для запуска VirtualBox. Этот сценарий будет убирать старые файлов VMDK и создавать новые:<br />
<br />
{{bc|<nowiki><br />
#!/bin/bash<br />
<br />
# Erase old VMDK entries<br />
rm ~/.VirtualBox/*.vmdk<br />
<br />
# Clean up VBox-Registry<br />
sed -i '/sd/d' ~/.VirtualBox/VirtualBox.xml<br />
<br />
# Remove old harddisks from existing machines<br />
find ~/.VirtualBox/Machines -name \*.xml | while read file; do<br />
line=`grep -e "type\=\"HardDisk\"" -n $file | cut -d ':' -f 1`<br />
if [ -n "$line" ]; then<br />
sed -i ${line}d $file<br />
sed -i ${line}d $file<br />
sed -i ${line}d $file<br />
fi<br />
sed -i "/rg/d" $file<br />
done<br />
<br />
# Delete prev-files created by VirtualBox<br />
find ~/.VirtualBox/Machines -name \*-prev -exec rm '{}' \;<br />
<br />
# Recreate VMDKs<br />
ls -l /dev/disk/by-uuid | cut -d ' ' -f 9,11 | while read ln; do<br />
if [ -n "$ln" ]; then<br />
uuid=`echo "$ln" | cut -d ' ' -f 1`<br />
device=`echo "$ln" | cut -d ' ' -f 2 | cut -d '/' -f 3 | cut -b 1-3`<br />
<br />
# determine whether drive is mounted already<br />
checkstr1=`mount | grep $uuid`<br />
checkstr2=`mount | grep $device`<br />
checkstr3=`ls ~/.VirtualBox/*.vmdk | grep $device`<br />
if [[ -z "$checkstr1" && -z "$checkstr2" && -z "$checkstr3" ]]; then<br />
VBoxManage internalcommands createrawvmdk -filename ~/.VirtualBox/$device.vmdk -rawdisk /dev/$device -register<br />
fi<br />
fi<br />
done<br />
<br />
# Start VirtualBox<br />
VirtualBox<br />
</nowiki>}}<br />
Обратите внимание, что ваш пользователь должен быть добавлен в группу {{ic|disk}}, чтобы создать VMDKs из существующих приводов.<br />
<br />
=== Запуск установленного Arch Linux внутри VirtualBox ===<br />
<br />
Если у вас есть дуалбут системы между Arch Linux и другими операционных системами, он может быстро стать утомительным для переключения туда-сюда, если вам нужно работать в обоих. Кроме того, с помощью виртуальных машин, у вас есть только крошечный фрагмент власти компьютера, который может привести к проблемам при работе на проектах, требующих производительности.<br />
<br />
Это руководство позволит вам использовать в виртуальной машине, вашу родную установку Arch Linux, когда вы используете свою вторую операционную систему. Таким образом, вы сохраняете возможность запуска каждой операционной систему изначально, но есть возможность запустить установленный физически Arch Linux внутри виртуальной машины.<br />
<br />
==== Убедитесь, что система наименования разделов не изменяется ====<br />
<br />
В зависимости от настроек вашего жесткого диска, файлы устройств, представляющих свои жесткие диски могут выглядеть по-разному когда вы будете запускать установку Arch Linux - изначально или в виртуальной машине. Эта проблема возникает, например, при использовании [[RAID#Implementation|FakeRAID]]. Поддельные RAID устройстве, будут перемещены в {{ic|/dev/mapper/}} при запуске дистрибутива GNU/Linux , в то время как будут устройства по-прежнему доступны по отдельности. Тем не менее, в вашей виртуальной машине может оказаться без отображения в {{ic|/dev/sdaX}} например, потому что драйвера, управляющие поддельными RAID в вашей локальной операционной системе (например, Windows) абстрагируются под поддельные RAID устройства.<br />
<br />
Чтобы обойти эту проблему, мы должны будем использовать схему адресации, работающую в обеих системах. Это может быть достигнуто с помощью [[Fstab#UUIDs|UUIDs]]{{Broken section link}} в файле {{ic|/etc/fstab}}. Убедитесь, что ваш [[Fstab_(Русский)|fstab]] использует UUID - в противном случае решайте эту проблему. Читайте [[Fstab]] и [[Persistent block device naming|Устойчивое именование разделов]].<br />
<br />
{{ic|/etc/fstab}} не является единственным местом, где используются UUID. Менеджеры загрузчиков тоже их используют. Убедитесь, что они действительно используют UUID-ы.<br />
<br />
; [[GRUB_Legacy_(Русский)|GRUB Legacy]]<br />
Если вы все еще используете [[GRUB_Legacy_(Русский)|GRUB Legacy]], может быть настало время его [[GRUB Legacy#Upgrading to GRUB2|обновить]], так как этот пакет в настоящее время удален из официальных репозиториев Arch Linux. Если вы хотите сохранить его, отредактируйте {{ic|/boot/grub/menu.lst}} и замените {{ic|1=root=/dev/sdXX}} в загрузочной записи Arch Linux на Linux UUID {{ic|/dev/disk/by-uuid/}}, соответствующий корневому разделу.<br />
<br />
title Arch Linux<br />
root<br />
kernel /vmlinuz-linux root=''/dev/disk/by-uuid/0a3407de-014b-458b-b5c1-848e92a327a3'' ro vga=773<br />
initrd /initramfs-linux-vbox.img<br />
<br />
Предварительно создайте резервную копию файла на случай ошибок.<br />
<br />
; [[GRUB_(Русский)|GRUB]]<br />
Если вы работаете с самой последней версией [[GRUB_(Русский)|GRUB]]; у вас нет проблем. Это ещё одна причина для перехода на GRUB 2.<br />
<br />
{{Warning_(Русский)|<br />
* Убедитесь, что ваш хост-раздел доступна только для чтения с вашей виртуальной машины Arch Linux. Это позволит избежать риска повреждения.<br />
* Вы никогда не должны позволять VirtualBox загружаться с момента загрузки вашей второй операционной системы, которая используется в качестве хоста для этой виртуальной машины! Возьмите, таким образом, за правило - особенно если ваша загрузка производится по умолчанию в другую операционную систему. Установите более большой тайм-аут или переместите систему ниже в порядке предпочтений.}}<br />
<br />
==== Убедитесь в корректности образа mkinitcpio ====<br />
<br />
Убедитесь, что в конфигурации вашего [[Mkinitcpio_(Русский)|mkinitcpio]] есть [[Mkinitcpio_(Русский)#Запрет обработчиков|хук]] {{ic|block}}:<br />
<br />
{{hc|/etc/mkinitcpio.conf|2=<br />
[...]<br />
HOOKS="base udev autodetect modconf ''block'' filesystems keyboard fsck"<br />
[...]}}<br />
<br />
<br />
Если это не так, добавьте хук и сгенерируйте свой initramfs, с помощью команды {{ic|# mkinitcpio -p linux}}, что [[Mkinitcpio_(Русский)#Создание образа|описано здесь более подробно]]{{Broken section link}}.<br />
<br />
==== Создание конфигурации виртуальной машины для загрузки с физического диска ====<br />
<br />
===== Создайте потоковый(raw) образ .vmdk =====<br />
<br />
Теперь нам нужно создать новую виртуальную машину, которая будет использовать [https://www.virtualbox.org/manual/ch09.html#rawdisk RAW диск] в качестве виртуального диска, для этого мы будем использовать файл ~ 1Kib VMDK, которые будет сбрасываться на физический диск. VirtualBox не имеет этой опции в графическом интерфейсе, так что мы должны использовать консоль и внутреннюю команду из {{ic|VBoxManage}}.<br />
<br />
Загрузите хост, который будет использовать виртуальную машину Arch Linux.Команда должны быть адаптированы в соответствии с вашей хост-машиной.<br />
<br />
; На хосте GNU/Linux:<br />
<br />
Существует 3 способа этого достичь: вход от суперпользователя, изменение прав доступа к устройству командой {{ic|chmod}}, добавление пользователя в группу {{ic|disk}}. Последний путь является более элегантным. Реализуем таким образом:<br />
<br />
# gpasswd -a ''your_user'' disk<br />
<br />
Применить новые параметры сейчас же:<br />
<br />
$ newgrp<br />
<br />
Теперь вы можете использовать следующую команду:<br />
<br />
$ VBoxManage internalcommands createrawvmdk -filename ''/path/to/file.vmdk'' -rawdisk ''/dev/sdb'' -register <br />
<br />
Адаптируйте команду для ваших потребностей.<br />
<br />
; На хосте с Windows:<br />
<br />
Откройте окно командной строки (необходимо запускать от имени администратора). {{tip_(Русский) | В Windows откройте меню Пуск / стартовый экран, введите {{ic|cmd}}, и нажмите {{ic|Ctrl+Shift+Enter}}, это ярлык для запуска выбранной программы с правами администратора.}}<br />
<br />
В Windows наименование дисков отлично от UNIX. Используйте эту команду, чтобы определить значения в вашей системе Windows, и их расположение:<br />
<br />
{{hc|# wmic diskdrive get name,size,model|<br />
Model Name Size<br />
WDC WD40EZRX-00SPEB0 ATA Device \\.\PHYSICALDRIVE1 4000783933440<br />
KINGSTON SVP100S296G ATA Device \\.\PHYSICALDRIVE0 96024821760<br />
Hitachi HDT721010SLA360 ATA Device \\.\PHYSICALDRIVE2 1000202273280<br />
Innostor Ext. HDD USB Device \\.\PHYSICALDRIVE3 1000202273280}}<br />
<br />
В этом примере Windows называет диски {{ic|\\.\PhysicalDriveX}}, Где X представляет собой число от 0, {{ic|\\.\PHYSICALDRIVE1}} может быть сопоставим с {{ic|/dev/sdb}} из терминологии Linux.<br />
<br />
Для использования в командной строке {{ic|VBoxManage}} в Windows, вы должны изменить текущую папку в папку установки VirtualBox, обычно это {{ic|cd C:\Program Files\Oracle\VirtualBox\}}<br />
<br />
# .\VBoxManage.exe internalcommands createrawvmdk -filename C:\file.vmdk -rawdisk \\.\PHYSICALDRIVE1<br />
<br />
<br />
или использовать абсолютный путь:<br />
<br />
# "C:\Program Files\Oracle\VirtualBox\VBoxManage.exe" internalcommands createrawvmdk -filename C:\file.vmdk -rawdisk \\.\PHYSICALDRIVE1<br />
<br />
; На другой хост-OS:<br />
<br />
Есть и другие ограничения, касающиеся вышеприведенной команды, когда она используется в других операционных системах - таких как OS X. Прочитайте [https://www.virtualbox.org/manual/ch09.html#rawdisk внимательно руководство], если это вас беспокоит.<br />
<br />
===== Создание файла конфигурации виртуальной машины =====<br />
<br />
{{note_(Русский) |<br />
* Для использования команды VBoxManage в Windows, вам нужно сначало изменить текущую директорию в папку установки VirtualBox : <br />
cd C:\Program Files\Oracle\VirtualBox\<br />
* Windows делает использование обратного слеша вместо слеша, пожалуйста, замените все вхождения / на \ в командах, которые вы будете использовать.}}<br />
<br />
После этого мы должны создать новую машину (замените ''VM_name'' ная ваш вариант) и зарегистрировать её в VirtualBox.<br />
<br />
$ VBoxManage createvm -name ''VM_name'' -register<br />
<br />
Затем виртуальный диск должен быть подключен к машине. Это будет зависеть от того, находится ли корень в вашей оригинальной установке Arch Linux на IDE или контроллере SATA.<br />
<br />
Если вам нужен контроллер IDE:<br />
<br />
$ VBoxManage storagectl ''VM_name'' --name "IDE Controller" --add ide<br />
$ VBoxManage storageattach machineA --storagectl "IDE Controller" --port 0 --device 0 --type hdd --medium /path/to/file.vmdk<br />
<br />
В противном случае:<br />
<br />
$ VBoxManage storagectl ''VM_name'' --name "SATA Controller" --add sata<br />
$ VBoxManage storageattach machineA --storagectl "SATA Controller" --port 0 --device 0 --type hdd --medium /path/to/file.vmdk<br />
<br />
В то время как вы продолжаете использовать интерфейс командной строки, рекомендуется использовать VirtualBox GUI, чтобы персонализировать настройки виртуальной машины. Необходимо указать аппаратную конфигурацию как можно ближе к родной машине: включение ускорения 3D, увеличение видеопамяти, установка сетевого интерфейса и т.д.<br />
<br />
==== Установка дополнений гостевой ОС ====<br />
<br />
Наконец, вы можете легко интегрировать Arch Linux с хост-системой и синхронизировать буфер обмена между двумя ОС. Обратитесь к [[#Образ диска с гостевыми дополнениями|установке гостевых дополнений]] для этого.<br />
<br />
{{Warning_(Русский)| Для [[Xorg (Русский)]], чтобы работать в родной и в виртуальной машине, так как очевидно, он должен использовать другой драйвер, то лучше, если не будет {{ic|/etc/X11/xorg.conf}} - так как Xorg будет собирать все, что необходимо на лету. Однако, если вам действительно нужно свою собственную конфигурацию Xorg, может быть, стоит установить используемые по умолчанию цели Systemd к {{ic|multi-user.target}} с {{ic|# systemctl isolate graphical.target}} (более [[Systemd_(Русский)#Изменение текущей цели|подробно]]). Таким образом, графический интерфейс будет отключен (т.е. Xorg не запустится) и после входа в систему вы сможете выполнить {{ic|startx}} вручную с пользовательским {{ic|xorg.conf}}.}}<br />
<br />
=== Физическая установка системы Arch Linux из VirtualBox ===<br />
<br />
В некоторых случаях это может быть полезно для установки родной системы Arch Linux из другой операционной системы: один из способов достижения этой цели является выполнение установки через VirtualBox на [http://www.virtualbox.org/manual/ch09.html#rawdisk жёсткий диск]. Если существующая операционная система на основе Linux, вы можете рассмотреть [[Install from existing Linux (Русский)|установку из существующего Linux]] вместо этого.<br />
<br />
Этот сценарий очень похож на [[#Запуск установленного Arch Linux внутри VirtualBox|Запуск установленного ArchLinux в VirtualBox]], но будет реализовывать эти шаги в другом порядке: начать с создания [[#Создайте потоковый(raw) образ .vmdk|.vmdk образа жёсткого диска]], а затем [[#Создание файла конфигурации виртуальной машины|создавать файл конфигурации виртуальной машины]].<br />
<br />
Теперь вы должны иметь рабочую конфигурацию виртуальной машины, чей виртуальный VMDK-диск связан с реальным диском. Процесс установки точно такой же, как и описанный в [[#Пошаговая установка Arch Linux как гостевой ОС|пошаговой установке ArchLinux в VirtualBox]], но сначала [[#Убедитесь, что система наименования разделов не изменяется|убедитесь в постоянной схеме наименования разделов]] и [[#Убедитесь в корректности образа mkinitcpio|корректности образа mkinitcpio]].<br />
<br />
{{Warning_(Русский)|<br />
* Для BIOS и MBR дисков: не устанавливайте загрузчик внутри виртуальной машины - он не будет работать, так как MBR не связан с MBR вашей реальной машины, и виртуальный диск отображается только в реальном разделе без MBR<br />
* Для UEFI систем без [[Wikipedia:Unified Extensible Firmware Interface#Compatibility Support Module|CSM]] и GPT дискa установка не будет работать вообще, так как:<br />
:* [[Wikipedia:EFI system partition|ESP]] не отображается на виртуальный диск и Arch Linux требует, чтобы ядро Linux было на нём, чтобы загрузиться в качестве приложения EFI (смотрите статью [[EFISTUB (Русский)]])<br />
:* и efivars, если вы устанавливаете Arch Linux через VirtualBox, используя режим EFI, не загрузит ни одну из ваших реальных систем: записи Bootmanager не смогут быть зарегистрированы<br />
* Вот почему рекомендуется создавать разделы в родной установке. В противном случае разделы не будут приниматься во внимание в MBR / GPT таблице разделов}}<br />
<br />
После завершения установки загрузите компьютер сперва с установочного носителя GNU/Linux (будь то Arch Linux или нет), выполните [[Installation guide (Русский)#Chroot|chroot]] в установленной Arch Linux и установите и настройте [[Installation guide (Русский)#Загрузчик|загрузчик]].<br />
<br />
=== Перемещение физически установленного Windows в виртуальную машину ===<br />
<br />
Если вы хотите перенести существующую Windows на виртуальную машину, которая будет использоваться с VirtualBox на GNU/Linux, этот вариант использования для вас. В этом разделе описан перенос только Windows с использованием схемы MSDOS/Intel разделов. Ваш Windows должен находиться на первом после MBR разделе. Работа в других разделах доступна, но были не тестировалась (см [[#Известные ограничения|Известные ограничения]] для более подробной информации)<br />
<br />
{{Warning_(Русский)|Если вы используете OEM версию Windows, этот процесс является неправомочным по конечной пользовательской лицензии. Действительно, лицензия OEM, как правило, указывает, что Windows Install связана с аппаратными средствами. Сделайте так, что бы у вас был полный Windows Install или полная лицензия, прежде чем продолжить. Если у вас есть полная лицензию для Windows, но последний не приходит в объеме, ни в качестве специальной лицензии на нескольких компьютерах, это означает, что вы должны будете удалить родную установку после операции клонирования в VM.}}<br />
<br />
Несколько задач необходимо выполнить внутри вашей Windows, а затем в хост-машине GNU/Linux.<br />
<br />
==== Задачи в Windows ====<br />
<br />
Первые три следующих моменты происходит от [https://www.virtualbox.org/wiki/Migrate_Windows#HAL этой устаревшей вики-страницы VirtualBox], но обновляются здесь.<br />
<br />
* Удалите проверку IDE/ATA контроллеров (только Windows XP): Windows запоминает IDE/ATA после установки, и не будет загружаться, если он обнаружит что они изменились.Решение, предложенное Microsoft является повторным использованием того же контроллера или использовать один из той-же серии, что невозможно сделать, поскольку мы используем виртуальную машину. [https://www.virtualbox.org/wiki/Migrate_Windows#HardDiskSupport MergeIDE], немецкий инструмент, разработан как другое решением, предложенное Microsoft. Решение в основном состоит в принятии всех IDE/ATA драйверов контроллера IDE, поддерживаемые Windows XP от первоначального архива драйвера, их установке и регистрации в реестре через Regedit.<br />
<br />
* Используйте правильный тип слоя абстрагирования оборудования (старые 32-битный Windows): Microsoft использует с 3 версии по умолчанию: {{ic|Hal.dll}} (Standard PC), {{ic|Halacpi.dll}} (ACPI HAL) и {{ic|halaacpi.dll}} (ACPI HAL с IO APIC). Ваша Windows-установка могла устанавитmся с первого или второго варианта. В этом случае, пожалуйста, [https://www.virtualbox.org/manual/ch08.html#idp56927888 отключите ''Enable IO/APIC '' в расширенных возможностях VirtualBox].<br />
<br />
* Отключите драйвер AGP устройства (только устаревшие версии ОС Windows): Если у вас есть файлы {{ic|agp440.sys}} или {{ic|intelppm.sys}} внутри {{ic| C:\Windows\System32\drivers\}}, то удалите его. Так как VirtualBox использует PCI виртуальную графическую карту, это может вызвать проблемы, когда используется драйвер AGP.<br />
<br />
* Создайте диск восстановления ОС Windows: В следующих шагах, если что-то испортится, вам нужно будет восстановить установку Windows. Убедитесь, что у вас есть установочного носителя под рукой, или создайте через ''Создать диск восстановления'' в Vista SP1, ''Создать диск восстановления системы'' в Windows 7 или ''Создать диск восстановления'' в Windows 8.x).<br />
<br />
==== Задачи в GNU/Linux ====<br />
<br />
* Уменьшите родной размер раздела Windows, для чего нужен {{ic|ntfsresize}} из пакета {{Pkg|ntfs-3g}}. Вы определяете размер, который будет равен размере VDI, который будет создан на следующем шаге. Если этот размер будет слишком мал, вы можете сломать ваш Windows и он может не загружаться вообще.<br />
<br />
:Включите параметр {{ic|--no-action}} для тестового запуска:<br />
:{{bc|# ntfsresize --no-action --size ''52Gi'' ''/dev/sda1''}}<br />
<br />
:Если только предыдущий тест прошел успешно, необходимо выполнить следующую команду снова, только без вышеупомянутого параметра {{ic|--no-action}}.<br />
<br />
* Установите VirtualBox на ваш GNU/Linux-хост (см. [[#Пошаговая установка на хост-компьютер под управлением Arch Linux|подробнее]] ).<br />
<br />
* Создайте образ диска для Windows от начала диска до конца первого раздела, на котором находится Windows. Копирование с начала диска необходимо потому, что пространство MBR в начале привода должно быть перенесено на виртуальный диск вместе с самим Windows. В этом примере следующие два раздела {{ic|sda2}} и {{ic|sda3}} будут позже удалены из таблицы разделов и загрузчик MBR будет обновляться.<br />
<br />
:{{bc|<nowiki># sectnum=$(( $(cat /sys/block/''sda/sda1''/start) + $(cat /sys/block/''sda/sda1''/size) ))</nowiki>}}<br />
Использование {{ic|cat /sys/block/''sda/sda1''/size}} выведет количество секторов первого раздела диска {{ic|sda}}. Адаптируйте команду, если это вам нужно.<br />
<br />
:{{bc|<nowiki># dd if=''/dev/sda'' bs=512 count=$sectnum | VBoxManage convertfromraw stdin ''windows.vdi'' $(( $sectnum * 512 ))</nowiki>}}<br />
:Мы должны показать размер в байтах, {{ic|$(( $sectnum * 512 ))}} преобразует номера секторов в байты.<br />
<br />
* Так как вы создали свой образ диска с правами администратора, установите права доступа на образ диска: {{ic|# chown $USER:users windows.vdi}}.<br />
<br />
* Создайте Ваш файл конфигурации виртуальной машины - используйте виртуальный диск, созданный ранее в качестве основного виртуального жесткого диска.<br />
<br />
* Постарайтесь загрузиться с виртуальной машины Windows (может работать). Во-первых, хотя бы отключите восстановление дисков из процесса загрузки, так как это может помешать (и, вероятно, будет мешать) загрузиться в безопасном режиме.<br />
<br />
* Попытка загрузить виртуальную машину в безопасном режиме (нажмите клавишу F8 до логотипа Windows) ... при возникновении вопросов о загрузке, читайте [[#Исправление MBR и загрузчика Microsoft|Исправление MBR и загрузчика Microsoft]]. В безопасном режиме вероятно будут установлен драйверы. Кроме того, установите Дополнения гостевой ОС через меню ''Devices'' > ''Insert Guest Additions CD image...''. Если новое диалоговое окно не отображается, перейдите к компакт-дискам и запустите программу установки вручную.<br />
<br />
* Наконец-то у вас есть необходимый Windows в виртуальной машине. Ознакомьтесь с [[#Известные ограничения|известными ограничениями]].<br />
<br />
==== Исправление MBR и загрузчика Microsoft ====<br />
<br />
Если ваша виртуальная машина с Windows отказывается загружаться, вам, возможно, потребуется применить следующие изменения в вашей виртуальной машине.<br />
<br />
* Начальная загрузка GNU/Live внутри виртуальной машины, прежде чем загрузится ОС Windows .<br />
<br />
* Удалить другие записи разделы с MBR виртуального диска. В самом деле, так как мы скопировали MBR и только раздел Windows, записи, относящихся к другим разделам по-прежнему присутствуют в MBR, но разделы ведь больше не доступны. Используйте {{ic|fdisk}}, чтобы добиться этого, например.<br />
<br />
:{{bc|<nowiki>fdisk ''/dev/sda''<br />
Command (m for help): a<br />
Partition number (''1-3'', default ''3''): ''1''</nowiki>}}<br />
<br />
* Запишите обновленную таблицу разделов на диск (это будет пересозданием MBR) с помощью {{ic|m}} команды в окружении {{ic|fdisk}}.<br />
<br />
* Используйте {{Pkg|testdisk}} (см. [http://www.cgsecurity.org/index.html?testdisk.html здесь] для более подробной информации), чтобы добавить общий MBR:<br />
<br />
:{{bc|# testdisk > ''Disk /dev/sda...''' > [Proceed] > [Intel] Intel/PC partition > [MBR Code] Write TestDisk MBR to first sector > Write a new copy of MBR code to first sector? (Y/n) > Y > Write a new copy of MBR code, confirm? (Y/N) > A new copy of MBR code has been written. You have to reboot for the change to take effect. > [OK]}}<br />
<br />
<br />
* С новым MBR и обновленной таблицей разделов, ваша виртуальная машина с Windows должна загрузиться. Если вы все еще сталкиваетесь с вопросами, загрузите диск восстановления Windows с предыдущей стадии, и внутри вашей среды Windows RE, выполняйте команды [http://support.microsoft.com/kb/927392 описанные здесь].<br />
<br />
==== Известные ограничения ====<br />
<br />
<br />
* Ваша виртуальная машина может иногда зависать и забивать оперативную память, это может быть вызвано конфликтующими драйверами , установленными внутри виртуальной машины Windows. Удачи вам найти их!<br />
* Дополнительное ПО ожидало драйвер,который не может установиться из-за невозможности отключения / деинсталляции старого драйвера.<br />
* Ваша Windows должна находиться в первом разделе для описанного выше процесса, чтобы заработать. Если это требование не выполнено, система может работать, но это не было испытаны. Это потребует либо копирования MBR и редактирования в шестнадцатеричном коде, см. [http://superuser.com/questions/237782/virtualbox-booting-cloned-disk/253417#253417 VirtualBox: загрузка клонированного диска] или потребуется исправить таблицу разделов [http://gparted.org/h2-fix-msdos-pt.php вручную] или восстанавливать Windows с диска восстановления, созданного в предыдущем шаге. Рассмотрим нашу установку окна на втором раздела; мы скопируем MBR, второму разделу, где лужит образ диска {{ic|VBoxManage convertfromraw}} необходимо общее количество байтов, которые будут записаны: Вычислим как сумму размера MBR (начало первого раздела) плюс размер второго (Windows) раздела.{{ic|<nowiki>{ dd if=/dev/sda bs=512 count=$(cat /sys/block/sda/sda1/start) ; dd if=/dev/sda2 bs=512 count=$(cat /sys/block/sda/sda2/size) ; } | VBoxManage convertfromraw stdin windows.vdi $(( ($(cat /sys/block/sda/sda1/start) + $(cat /sys/block/sda/sda2/size)) * 512 ))</nowiki>}}.<br />
<br />
== Возможные проблемы ==<br />
<br />
=== VERR_ACCESS_DENIED ===<br />
<br />
Чтобы получить доступ к образу vdmk, расположенного на хосте под Windows, запустите VirtualBox GUI от имени администратора.<br />
<br />
=== Клавиатура и мышка заблокированы виртуальной машиной ===<br />
<br />
Это означает, что ваша виртуальная машина захватила ввод клавиатуры и мышки. Просто нажмите правый {{ic|Ctrl}} и ваши устройства ввода будут доступны в основной системе.<br />
<br />
Для того, чтобы управление мышкой возвращалось основной ОС при выходе курсора за границы окна виртуальной машины, без нажатия каких-либо клавиш, и для возможности бесшовной интеграции, установите гостевое дополнение на виртуальную машину. Читайте шаг [[#Установка гостевых дополнений]] если вы новичок в Arch Linux, или читайте официальную справку VirtualBox.<br />
<br />
=== Не могу отправить комбинацию CTRL+ALT+Fn в виртуальную машину ===<br />
<br />
Если в вашей виртуальной машине установлен дистрибутив GNU/Linux и вы хотите открыть новую оболочку TTY нажатием {{ic|Ctrl+Alt+F2}} или выйти из X сессии с помощью {{ic|Ctrl+Alt+Backspace}}, просто нажав это сочетание клавиш без какой-либо адаптации, гостевая машина его не получит и основная ОС (если это тоже дистрибутив GNU/Linux) распознает это сочетание клавиш. Для отправки {{ic|Ctrl+Alt+F2}} на виртуальную машину нужно просто нажать ваш ''Host Key'' (обычно это правый {{ic|Ctrl}}) и одновременно нажать {{ic|F2}}.<br />
<br />
=== Исправление проблем в ISO-образах ===<br />
<br />
В то время как VirtualBox монтирует оригинальный образы ISO без проблем, есть такие форматы образов, которые не могут надежно быть преобразованы в ISO. Например, ccd2iso игнорирует .ccd и .sub файлы, что может привести к созданию образа диска с разбитыми файлами.<br />
<br />
В этом случае вам придется использовать [[CDemu]] для Linux внутри VirtualBox или любую другую утилиту, предназначенную для монтирования образов дисков.<br />
<br />
=== VirtualBox GUI не видит мою тему GTK 2x/3x ===<br />
<br />
Смотрите [[Uniform look for Qt and GTK applications (Русский)|Единый интерфейс GTK/QT приложений]] для получения информации о настройке GUI Qt в GTK-окружениях.<br />
<br />
=== OpenBSD не работает при недоступных инструкциях виртуализации ===<br />
<br />
В то время как OpenBSD отлично работает на других гипервизорах без включенной виртуализации (VT-х AMD-V), виртуальная машина с OpenBSD работает в VirtualBox без этих инструкций некорректно, выдавая кучу ошибок сегментации. Запуская VirtualBox с аргументом ''-norawr0'' [https://www.virtualbox.org/ticket/3947 можно избавиться от этой проблемы]. Вы можете сделать это следующим образом:<br />
$ VBoxSDL -norawr0 -vm ''имя_OpenBSD_VM''<br />
<br />
=== VBOX_E_INVALID_OBJECT_STATE (0x80BB0007) ===<br />
<br />
Это может произойти при некорректном завершении виртуальной машины. Разблокировка машины тривиальна:<br />
$ VBoxManage controlvm ''virtual_machine_name'' poweroff<br />
<br />
=== Подсистема USB не работает в хост-машине или гостевой ОС ===<br />
<br />
Ваш пользователь должен быть в группе {{ic|vboxusers}}, и вы должны установить [[#Пакет дополнений|пакет дополнений]], если хотите иметь поддержку USB 2. Тогда вы сможете включить USB 2 в настройках виртуальной машины и добавить один или несколько фильтров для устройств, которые будут иметь доступ из гостевой ОС.<br />
<br />
Иногда, на старых Linux-хостах, подсистема USB не распознается автоматически и выдает ошибку {{ic|Could not load the Host USB Proxy service: VERR_NOT_FOUND}} или при невидимом USB-диске в хост-машине, [HTTPS://bbs.archlinux.org/viewtopic.php?id=121377, даже когда пользователь находится в группе '''vboxusers''']. Эта проблема происходит из-за того, что VirtualBox переключается с ''usbfs'' на ''sysfs'' с версии 3.0.8. Если хост-машина не распознаёт этого изменения, вы можете вернуться к старому поведению, определив следующую переменную окружения в любом файле, которые конфигурирует вашу оболочку (например, в {{ic|~/.bashrc}}, если вы используете ''bash''):<br />
<br />
{{hc|~/.bashrc|VBOX_USB<nowiki>=</nowiki>usbfs}}<br />
<br />
Затем убедитесь, что, окружающая среда приняла это изменение (перелогиньтесь, запустите новый экземпляр оболочки или перезагрузитесь).<br />
<br />
Также убедитесь, что ваш пользователь состоит в группе {{ic|storage}}.<br />
<br />
=== Ошибка создания сетевого интерфейса "host-only" ===<br />
<br />
Убедитесь в том, что все модули ядра VirtualBox загружены (см. [[#Загрузка модулей ядра VirtualBox|Загрузка модулей ядра VirtualBox]]).<br />
<br />
=== WinXP: глубина цвета не может превышать 16 цветов ===<br />
<br />
Если Вы работаете в 16-битной глубине цвета, то значки будут отображаться некорректно. Тем не менее, при попытке изменить глубину цвета на более высокий уровень, система может ограничить вас с более низким разрешением или просто не позволит вам изменить глубину вообще. Чтобы это исправить, запустите {{ic|regedit}} в Windows и добавьте следующий ключ реестра для виртуальной машины Windows XP:<br />
<br />
[HKEY_LOCAL_MACHINE\SOFTWARE\Policies\Microsoft\Windows NT\Terminal Services]<br />
"ColorDepth"=dword:00000004<br />
<br />
Затем обновите глубину цвета в "Свойствах рабочего стола". Если ничего не происходит, заставьте экран перерисоваться (например, нажмите{{ic|Host+f}}).<br />
<br />
=== Использование последовательных портов в гостевой ОС ===<br />
<br />
Проверьте наличие прав для доступа к последовательным портам:<br />
$ /bin/ls -l /dev/ttyS*<br />
crw-rw---- 1 root uucp 4, 64 Feb 3 09:12 /dev/ttyS0<br />
crw-rw---- 1 root uucp 4, 65 Feb 3 09:12 /dev/ttyS1<br />
crw-rw---- 1 root uucp 4, 66 Feb 3 09:12 /dev/ttyS2<br />
crw-rw---- 1 root uucp 4, 67 Feb 3 09:12 /dev/ttyS3<br />
<br />
Добавьте пользователя в группу {{ic|uucp}}<br />
# gpasswd -a $USER uucp <br />
и перелогиньтесь.<br />
<br />
=== Windows 8.x ошибка 0x000000C4===<br />
<br />
Если вы получаете этот код ошибки при загрузке, даже при выбранном типе OS Win 8, попробуйте включить инструкцию процессора {{ic|CMPXCHG16B}}:<br />
<br />
$ vboxmanage setextradata ''virtual_machine_name'' VBoxInternal/CPUM/CMPXCHG16B 1<br />
<br />
=== Windows 8 VM вылетает при загрузке с ошибкой "ERR_DISK_FULL" ===<br />
<br />
Если ваша Windows 8 не запускается, VirtualBox выдаёт ошибку что виртуальный диск заполнен, но тем не менее вы уверены что диск не является заполненным,<br />
откройте настройки виртуальной машины ''Настройки>Память>Контроллер: SATA'' и выберите ''Use Host I/O Cache''.<br />
<br />
=== Гостевая ОС Linux выдает искажённый или запаздывающий звук ===<br />
<br />
Аудио драйвер AC97 в ядре linux иногда неправильно считывает время из Virtual Box, что приводит к различным искажениям звука. Для исправления проблемы, создайте файл {{ic|/etc/modprobe.d}} со следующим содержанием:<br />
<br />
options snd-intel8x0 ac97_clock=48000<br />
<br />
=== Гостевая ОС зависает после запуска Xorg ===<br />
<br />
Неисправные или отсутствующие драйверы могут привести к остановке после запуска Xorg, см., например, [https://bbs.archlinux.org/viewtopic.php?pid=1167838] и [https://bbs.archlinux.org/viewtopic.PHP?ID=156079]. Попробуйте отключить 3D-ускорение в ''Настройки> Дисплей'', и проверьте, все ли драйверы [[Xorg]] установлены.<br />
<br />
=== Исчезновение пунктов меню и ошибка "NS_ERROR_FAILURE" ===<br />
<br />
Если после первого запуска машины вы столкнулись с такой ошибкой:<br />
<br />
{{bc|Failed to open a session for the virtual machine debian.<br />
Could not open the medium '/home/.../VirtualBox VMs/debian/debian.qcow'.<br />
QCow: Reading the L1 table for image '/home/.../VirtualBox VMs/debian/debian.qcow' failed (VERR_EOF).<br />
VD: error VERR_EOF opening image file '/home/.../VirtualBox VMs/debian/debian.qcow' (VERR_EOF).<br />
<br />
Result Code: <br />
NS_ERROR_FAILURE (0x80004005)<br />
Component: <br />
Medium<br />
}}<br />
<br />
Выйдите из VirtualBox, удалите все файлы новой машины и из файла конфигурации VirtualBox удалите последнюю строку в {{ic|MachineRegistry}} меню:<br />
<br />
{{hc|~/.config/VirtualBox/VirtualBox.xml|2=<br />
...<br />
<MachineRegistry><br />
<MachineEntry uuid="{00000000-0000-0000-0000-000000000000}" src="/home/void/VirtualBox VMs/debian/debian.vbox"/><br />
<MachineEntry uuid="{00000000-0000-0000-0000-000000000000}" src="/home/void/VirtualBox VMs/ubuntu/ubuntu.vbox"/><br />
<strike><MachineEntry uuid="{00000000-0000-0000-0000-000000000000}" src="/home/void/VirtualBox VMs/lastvmcausingproblems/lastvmcausingproblems.qcow"/></strike><br />
</MachineRegistry><br />
...<br />
}}<br />
<br />
Это иногда происходит при выборе ''QCOW''/''QCOW2''/''QED'' формата виртуального диска.<br />
<br />
<br />
=== "Указанный путь не существует. Проверьте путь и попробуйте еще раз." Ошибка в гостевой ОС Windows ===<br />
<br />
Это сообщение об ошибке часто появляется при работе с расширением .exe который требует привелегий администратора из общей папки в гостевой Windows. См. [https://www.virtualbox.org/ticket/5732 отчет об ошибке].<br />
<br />
Есть несколько способов обойти ошибку:<br />
<br />
# Отключить UAC с помощью Панель управления -> Центр поддержки -> "Settings Change User Account Control" из левой боковой панели -> Установить ползунок "Никогда не уведомлять» -> OK и перезагрузить ОС<br />
# Скопируйте файл из папки общего доступа в гостевую ОС и запустите оттуда<br />
<br />
=== Не работают 64-битные гостевые ОС ===<br />
<br />
При запуске клиента VM, если никакие 64-битные варианты не доступны, убедитесь что ваши возможности виртуализации процессора (обычно с именем {{ic|VT-X}}) включены в BIOS.<br />
<br />
=== Ошибка "VT-x is not available. (VERR_VMX_NO_VMX)" и процессор без поддержки виртуализации ===<br />
<br />
С версии 6.1.0 [https://www.virtualbox.org/wiki/Changelog-6.1#v0 (released December 10 2019)] VirtualBox требует аппаратную поддержку виртуализации. Решение откатится либо установить версию старше <6.1. Например {{aur|virtualbox-bin-5}}.<br />
<br />
== Смотрите также ==<br />
<br />
* [https://www.virtualbox.org/manual/UserManual.html Руководство пользователя VirtualBox]<br />
* [https://ru.wikipedia.org/wiki/VirtualBox Википедия:VirtualBox]</div>MaxSoniX