sonyps4.ru

Работа с виртуальными машинами KVM. Введение

Выпуск WordPress 5.3 улучшает и расширяет представленный в WordPress 5.0 редактор блоков новым блоком, более интуитивным взаимодействием и улучшенной доступностью. Новые функции в редакторе […]

После девяти месяцев разработки доступен мультимедиа-пакет FFmpeg 4.2, включающий набор приложений и коллекцию библиотек для операций над различными мультимедиа-форматами (запись, преобразование и […]

  • Новые функции в Linux Mint 19.2 Cinnamon

    Linux Mint 19.2 является выпуском с долгосрочной поддержкой, который будет поддерживаться до 2023 года. Он поставляется с обновленным программным обеспечением и содержит доработки и множество новых […]

  • Вышел дистрибутив Linux Mint 19.2

    Представлен релиз дистрибутива Linux Mint 19.2, второго обновления ветки Linux Mint 19.x, формируемой на пакетной базе Ubuntu 18.04 LTS и поддерживаемой до 2023 года. Дистрибутив полностью совместим […]

  • Доступны новые сервисные релизы BIND, которые содержат исправления ошибок и улучшения функций. Новые выпуски могут быть скачано со страницы загрузок на сайте разработчика: […]

    Exim – агент передачи сообщений (MTA), разработанный в Кембриджском университете для использования в системах Unix, подключенных к Интернету. Он находится в свободном доступе в соответствии с […]

    После почти двух лет разработки представлен релиз ZFS on Linux 0.8.0, реализации файловой системы ZFS, оформленной в виде модуля для ядра Linux. Работа модуля проверена с ядрами Linux c 2.6.32 по […]

  • В WordPress 5.1.1 устранена уязвимость, позволяющая получить контроль над сайтом
  • Комитет IETF (Internet Engineering Task Force), занимающийся развитием протоколов и архитектуры интернета, завершил формирование RFC для протокола ACME (Automatic Certificate Management Environment) […]

    Некоммерческий удостоверяющий центр Let’s Encrypt, контролируемый сообществом и предоставляющий сертификаты безвозмездно всем желающим, подвёл итоги прошедшего года и рассказал о планах на 2019 год. […]

  • Вышла новая версия Libreoffice – Libreoffice 6.2
  • В жизни сисадмина однажды настает момент, когда приходится с нуля разворачивать инфраструктуру предприятия либо переделывать уже имеющуюся, перешедшую по наследству. В этой статье я расскажу о том, как правильно развернуть гипервизор на основе Linux KVM и libvirt c поддержкой LVM (логических групп).

    Мы пройдемся по всем тонкостям управления гипервизором, включая консольные и GUI-утилиты, расширение ресурсов и миграцию виртуальных машин на другой гипервизор.

    Для начала разберемся с тем, что такое виртуализация. Официальное определение звучит так: «Виртуализация - это предоставление набора вычислительных ресурсов или их логического объединения, абстрагированное от аппаратной реализации и обеспечивающее при этом логическую изоляцию друг от друга вычислительных процессов, выполняемых на одном физическом ресурсе». То есть, если выражаться человеческим языком, имея один мощный сервер, мы можем превратить его в несколько средних серверов, и каждый из них будет выполнять свою задачу, отведенную ему в инфраструктуре, не мешая при этом другим.

    Системные администраторы, работающие вплотную с виртуализацией на предприятии, мастера и виртуозы своего дела, поделились на два лагеря. Одни - приверженцы высокотехнологичной, но безумно дорогой VMware для Windows. Другие - любители open source и бесплатных решений на основе Linux VM. Можно долго перечислять преимущества VMware, но здесь мы остановимся на виртуализации, основанной на Linux VM.

    Технологии виртуализации и требования к железу

    Сейчас есть две популярные технологии виртуализации: Intel VT и AMD-V. В Intel VT (от Intel Virtualization Technology) реализована виртуализация режима реальной адресации; соответствующая аппаратная виртуализация ввода-вывода называется VT-d. Часто эта технология обозначается аббревиатурой VMX (Virtual Machine eXtension). В AMD создали свои расширения виртуализации и первоначально называли их AMD Secure Virtual Machine (SVM). Когда технология добралась до рынка, она стала называться AMD Virtualization (сокращенно AMD-V).

    Перед тем как вводить аппаратное обеспечение в эксплуатацию, убедись, что оборудование поддерживает одну из этих двух технологий (посмотреть можно в характеристиках на сайте производителя). Если поддержка виртуализации имеется, ее необходимо включить в BIOS перед развертыванием гипервизора.

    Среди других требований гипервизоров - поддержка аппаратного RAID (1, 5, 10), которая повышает отказоустойчивость гипервизора при выходе жестких дисков из строя. Если поддержки аппаратного RAID нет, то можно использовать программный на крайний случай. Но RAID - это мастхэв!

    Решение, описанное в этой статье, несет на себе три виртуальные машины и успешно работает на минимальных требованиях: Core 2 Quad Q6600 / 8 Гбайт DDR2 PC6400 / 2 × 250 Гбайт HDD SATA (хардверный RAID 1).

    Установка и настройка гипервизора

    Я покажу, как настраивать гипервизор, на примере Debian Linux 9.6.0 - Х64-86. Ты можешь использовать любой дистрибутив Linux, который тебе по душе.

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

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

    Logical Volume Manager

    Менеджер логических томов (LVM) - это подсистема, доступная в Linux и OS/2, построенная поверх Device Mapper. Ее задача - представление разных областей с одного жесткого диска или областей с нескольких жестких дисков в виде одного логического тома. LVM создает из физических томов (PV - Phisical Volumes) логическую группу томов (VG - Volumes Group). Она, в свою очередь, состоит из логических томов (LV - Logical Volume).

    Сейчас во всех дистрибутивах Linux с ядром 2.6 и выше есть поддержка LVM2. Для использования LVM2 на ОС с ядром 2.4 надо устанавливать патч.

    После того как система обнаружила жесткие накопители, запустится менеджер разбивки жестких дисков. Выбираем пункт Guided - use entire disk and set up LVM.


    Теперь выбираем диск, на который будет установлена наша группа томов.



    Система предложит варианты разметки носителя. Выбираем «Записать все файлы на один раздел» и идем дальше.




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

    Я отвечу просто: при создании логической группы VG загрузочный раздел boot не пишется в VG, а создается отдельным разделом с файловой системой ext2. Если этого не учесть, то загрузочный том окажется в логической группе. Это обречет тебя на мучения и страдания при восстановлении загрузочного тома. Именно поэтому загрузочный раздел отправляется на том без LVM.



    Переходим к конфигурации логической группы для гипервизора. Выбираем пункт «Конфигурация менеджера логических томов».



    Система оповестит о том, что все изменения будут записаны на диск. Соглашаемся.



    Создадим новую группу - к примеру, назовем ее vg_sata .



    INFO

    В серверах используются носители SATA, SSD, SAS, SCSI, NVMe. Хорошим тоном при создании логической группы будет указывать не имя хоста, а тип носителей, которые используются в группе. Советую логическую группу назвать так: vg_sata , vg_ssd , vg_nvme и так далее. Это поможет понять, из каких носителей построена логическая группа.




    Создаем наш первый логический том. Это будет том для корневого раздела операционной системы. Выбираем пункт «Создать логический том».



    Выбираем группу для нового логического тома. У нас она всего одна.



    Присваиваем имя логическому тому. Правильнее всего при назначении имени будет использовать префикс в виде названия логической группы - например, vg_sata_root , vg_ssd_root и так далее.



    Указываем объем для нового логического тома. Советую выделить под корень 10 Гбайт, но можно и меньше, благо логический том всегда можно расширить.



    По аналогии с примером выше создаем следующие логические тома:

    • vg_sata_home - 20 Гбайт под каталоги пользователей;
    • vg_sata_opt - 10 Гбайт для установки прикладного ПО;
    • vg_sata_var - 10 Гбайт для часто меняющихся данных, к примеру логов системы и других программ;
    • vg_sata_tmp - 5 Гбайт для временных данных, если объем временных данных велик, можно сделать и больше. В нашем примере этот раздел не создавался за ненадобностью;
    • vg_sata_swap - равен объему оперативной памяти. Это раздел для свопа, и создаем мы его для подстраховки - на случай, если закончится оперативная память на гипервизоре.

    После создания всех томов завершаем работу менеджера.



    Теперь имеем несколько томов для создания разделов операционной системы. Нетрудно догадаться, что для каждого раздела есть свой логический том.



    Создаем одноименный раздел под каждый логический том.



    Сохраняем и записываем проделанные изменения.



    После сохранения изменений разметки диска начнут ставиться базовые компоненты системы, а затем будет предложено выбрать и установить дополнительные компоненты системы. Из всех компонентов нам понадобится ssh-server и стандартные системные утилиты.



    После установки будет сформирован и записан на диск загрузчик GRUB. Устанавливаем его на тот физический диск, где сохранен загрузочный раздел, то есть /dev/sda .




    Теперь ждем, пока закончится запись загрузчика на диск, и после оповещения перезагружаем гипервизор.





    После перезагрузки системы заходим на гипервизор по SSH. Первым делом под рутом устанавливаем нужные для работы утилиты.

    $ sudo apt-get install -y sudo htop screen net-tools dnsutils bind9utils sysstat telnet traceroute tcpdump wget curl gcc rsync

    Настраиваем SSH по вкусу. Советую сразу сделать авторизацию по ключам. Перезапускаем и проверяем работоспособность службы.

    $ sudo nano /etc/ssh/sshd_config $ sudo systemctl restart sshd; sudo systemctl status sshd

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

    $ sudo pvscan $ sudo lvs

    Устанавливаем компоненты виртуализации и утилиты для создания сетевого моста на интерфейсе гипервизора.

    $ sudo apt-get update; apt-get upgrade -y $ sudo apt install qemu-kvm libvirt-bin libvirt-dev libvirt-daemon-system libvirt-clients virtinst bridge-utils

    После установки настраиваем сетевой мост на гипервизоре. Комментируем настройки сетевого интерфейса и задаем новые:

    $ sudo nano /etc/network/interfaces

    Содержимое будет примерно таким:

    Auto br0 iface br0 inet static address 192.168.1.61 netmask 255.255.255.192 gateway 192.168.1.1 broadcast 192.168.0.61 dns-nameserver 127.0.0.1 dns-search сайт bridge_ports enp2s0 bridge_stp off bridge_waitport 0 bridge_fd 0

    Добавляем нашего пользователя, под которым будем работать с гипервизором, в группы libvirt и kvm (для RHEL группа называется qemu).

    $ sudo gpasswd -a iryzhevtsev kvm $ sudo gpasswd -a iryzhevtsev libvirt

    Теперь необходимо инициализировать нашу логическую группу для работы с гипервизором, запустить ее и добавить в автозагрузку при запуске системы.

    $ sudo virsh pool-list $ sudo virsh pool-define-as vg_sata logical --target /dev/vg_sata $ sudo virsh pool-start vg_sata; sudo virsh pool-autostart vg_sata $ sudo virsh pool-list

    INFO

    Для нормальной работы группы LVM с QEMU-KVM требуется сначала активировать логическую группу через консоль virsh .

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

    $ sudo wget https://mirror.yandex.ru/debian-cd/9.5.0/amd64/iso-cd/debian-9.5.0-amd64-netinst.iso $ sudo mv debian-9.5.0-amd64-netinst.iso /var/lib/libvirt/images/; ls -al /var/lib/libvirt/images/

    Чтобы подключаться к виртуальным машинам по VNC, отредактируем файл /etc/libvirt/libvirtd.conf:

    $ sudo grep "listen_addr = " /etc/libvirt/libvirtd.conf

    Раскомментируем и изменим строчку listen_addr = "0.0.0.0" . Сохраняем файл, перезагружаем гипервизор и проверяем, все ли службы запустились и работают.

    Продолжение доступно только участникам

    Вариант 1. Присоединись к сообществу «сайт», чтобы читать все материалы на сайте

    Членство в сообществе в течение указанного срока откроет тебе доступ ко ВСЕМ материалам «Хакера», увеличит личную накопительную скидку и позволит накапливать профессиональный рейтинг Xakep Score!

    Подготовка сервера

    Проверяем наличие поддержки со стороны процессора:

    cat /proc/cpuinfo | egrep "(vmx|svm)"

    Если команда ничего не вернет, на сервере отсутствует поддержка виртуализации или она отключена в настройках БИОС. Сам KVM поставить на такой сервер можно, но при попытке ввести команду управления гипервизором мы получим ошибку «WARNING KVM acceleration not available, using "qemu"». В таком случае необходимо перезагрузить сервер, войти в БИОС, найти поддержку технологии виртуализации (Intel VT или AMD-V) и включить ее.

    Создадим каталоги, в которых будем хранить все, что касается виртуализации (предлагаемые по умолчанию не удобные):

    mkdir -p /kvm/{images,iso}

    * каталог /kvm/images для виртуальных дисков; /kvm/iso — для iso-образов.

    Установка и запуск

    Установка выполняется из репозитория следующей командой:

    yum install qemu-kvm libvirt virt-install

    * где qemu-kvm — сам гипервизор; libvirt — библиотека управления виртуализацией; virt-install — утилита для управления виртуальными машинами.

    Разрешаем автозапуск:

    systemctl enable libvirtd

    Запускаем KVM:

    systemctl start libvirtd

    Настройка сети

    В данной инструкции рассмотрим использование сетевого моста.

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

    Устанавливаем пакет для работы с bridge:

    yum install bridge-utils

    Смотрим список сетевых интерфейсов и их настроек:

    В моем примере были следующие данные:

    1: lo: mtu 65536 qdisc noqueue state UNKNOWN qlen 1
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo

    inet6::1/128 scope host
    valid_lft forever preferred_lft forever
    2: enp4s0f0: mtu 1500 qdisc pfifo_fast state UP qlen 1000

    inet 192.168.1.24/24 brd 192.168.1.255 scope global enp4s0f0
    valid_lft forever preferred_lft forever

    valid_lft forever preferred_lft forever
    3: enp5s5:

    4: virbr0:


    valid_lft forever preferred_lft forever
    5: virbr0-nic:
    link/ether 52:54:00:cd:86:98 brd ff:ff:ff:ff:ff:ff

    * из этого для нас важны enp4s0f0 — реальный сетевой интерфейс с настроенным IP-адресом 192.168.1.24 , через который идет подключение сервера к локальной сети (из него мы будем делать мост); 00:16:76:04:26:c6 — mac-адрес реального ethernet адаптера; virbr0 — виртуальный сетевой адаптер.

    Редактируем настройки реального адаптера:

    vi /etc/sysconfig/network-scripts/ifcfg-enp4s0f0

    Приводим его к виду:

    ONBOOT=yes
    BRIDGE=br0
    TYPE=Ethernet
    DEVICE=enp4s0f0
    BOOTPROTO=none

    Создаем интерфейс для сетевого моста:

    vi /etc/sysconfig/network-scripts/ifcfg-br0

    DEVICE=br0
    TYPE=Bridge
    ONBOOT=yes
    BOOTPROTO=static
    IPADDR=192.168.1.24
    NETMASK=255.255.255.0
    GATEWAY=192.168.1.1
    DNS1=8.8.8.8
    DNS2=77.88.8.8

    Перезапускаем сетевую службу:

    systemctl restart network

    Сетевые настройки должны измениться — в моем случае:

    2: enp4s0f0: mtu 1500 qdisc pfifo_fast master br0 state UP qlen 1000
    link/ether 00:16:76:04:26:c6 brd ff:ff:ff:ff:ff:ff
    3: enp5s5: mtu 1500 qdisc pfifo_fast state DOWN qlen 1000
    link/ether 00:16:76:04:26:c7 brd ff:ff:ff:ff:ff:ff
    4: virbr0: mtu 1500 qdisc noqueue state DOWN qlen 1000
    link/ether 52:54:00:cd:86:98 brd ff:ff:ff:ff:ff:ff
    inet 192.168.122.1/24 brd 192.168.122.255 scope global virbr0
    valid_lft forever preferred_lft forever
    5: virbr0-nic: mtu 1500 qdisc pfifo_fast master virbr0 state DOWN qlen 1000
    link/ether 52:54:00:cd:86:98 brd ff:ff:ff:ff:ff:ff
    6: br0: mtu 1500 qdisc noqueue state UP qlen 1000
    link/ether 00:16:76:04:26:c6 brd ff:ff:ff:ff:ff:ff
    inet 192.168.1.24/24 brd 192.168.1.255 scope global br0
    valid_lft forever preferred_lft forever
    inet6 fe80::216:76ff:fe04:26c6/64 scope link
    valid_lft forever preferred_lft forever

    Настаиваем перенаправления сетевого трафика:

    vi /etc/sysctl.d/99-sysctl.conf

    net.ipv4.ip_forward=1

    Применяем настройки:

    sysctl -p /etc/sysctl.d/99-sysctl.conf

    Перезапускаем libvirtd:

    systemctl restart libvirtd

    Создание виртуальной машины

    Смотрим доступные варианты гостевых операционных систем:

    Для создания первой виртуальной машины вводим следующую команду:

    virt-install -n FirstTest \
    --noautoconsole \
    --network=bridge:br0 \
    --ram 1024 --arch=x86_64 \
    --vcpus=1 --cpu host --check-cpu \
    --disk path=/kvm/images/FirstTest-disk1.img,size=16 \
    --cdrom /kvm/iso/CentOS-7-x86_64-Minimal-1611.iso \
    --graphics vnc,listen=0.0.0.0,password=my_password \
    --os-type linux --os-variant=rhel7 --boot cdrom,hd,menu=on

    • FirstTest — имя создаваемой машины;
    • noautoconsole — после создания не подключается автоматически к консоли виртуальной машины;
    • network — тип сети (в нашем примере сетевой мост);
    • ram — объем оперативной памяти, который будет выделен;
    • vcpus — количество виртуальных процессоров;
    • disk — виртуальный диск: path — путь до диска; size — его объем;
    • cdrom — виртуальный привод с образом системы;
    • graphics — параметры подключения к виртуальной машины с помощью графической консоли (в данном примере используем vnc); listen — на какой адресе принимает запросы vnc (в нашем примере на всех); password — пароль для подключения при помощи vnc;
    • os-variant — гостевая операционная система (весь список мы получали командой osinfo-query os , в данном примере устанавливаем Reв Hat 7 / CentOS 7).

    Разрешаем автостарт для созданной ВМ:

    virsh autostart FirstTest

    Подключение к виртуальной машине

    Для дальнейшей установки операционной системы скачиваем VNC-клиент на компьютер администратора, например, TightVNC и устанавливаем его.

    На сервере смотрим, на каком порту слушает VNC созданной машины:

    virsh vncdisplay FirstTest

    в моем случае было:

    Это значит, что нужно к 5900 прибавить 0. Если результат команды будет:1 — 5900 + 1 = 5901 и так далее.

    Открываем порт на брандмауэре:

    firewall-cmd --permanent --add-port=5900-5905/tcp

    firewall-cmd --reload

    * в данном примере добавлено сразу 6 tcp-портов от 5900 до 5905 .

    Запускаем установленный TightVNC Viewer, в открывшемся окне вводим IP-адрес сервера KVM и порт, на котором слушает наша ВМ (в данном примере, 5900):

    Нажимаем Connect . Программа запросит пароль — вводим тот, что указали при создании ВМ, (в данном примере, my_password ). Мы подключимся к виртуальной машине, как будто, к ней подключен монитор или удаленная консоль KVM.

    Admin и пароль, который создали при выполнении команды engine-setup . После успешного входа можно управлять виртуальными машинами через веб-интерфейс.

    KVM или Kernel Virtual Module - это модуль виртуализации для ядра Linux, который позволяет превратить ваш компьютер в гипервизор для управления виртуальными машинами. Этот модуль работает на уровне ядра и поддерживает такие технологии аппаратного ускорения, как Intel VT и AMD SVM.

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

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

    Перед тем как переходить к самой установке KVM нужно проверить поддерживает ли ваш процессор аппаратное ускорение виртуализации от Intel-VT или AMD-V. Для этого выполните такую команду:

    egrep -c "(vmx|svm)" /proc/cpuinfo

    Если в результате будет возвращено 0 - значит ваш процессор не поддерживает аппаратной виртуализации, если 1 или больше - то вы можете использовать KVM на своей машине.

    Теперь мы можем перейти к установке KVM, набор программ можно получить прямо из официальных репозиториев:

    sudo apt install qemu-kvm libvirt-bin bridge-utils virt-manager cpu-checker

    Мы установили не только утилиту kvm, но и библиотеку libvirt, а также менеджер виртуальных машин. После того, как установка будет завершена вам необходимо добавить своего пользователя в группу libvirtd, потому что только root и пользователи этой группы могут использовать виртуальные машины KVM:

    sudo gpasswd -a ПОЛЬЗОВАТЕЛЬ libvirtd

    После выполнения этой команды выйдите из системы и войдите снова. Далее, давайте проверим все ли правильно было установлено. Для этого используйте команду kvm-ok:

    INFO: /dev/kvm exists
    KVM acceleration can be used

    Если все было сделано правильно, то вы увидите такое же сообщение.

    Использование KVM в Ubuntu 16.04

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

    Настройка моста в NetworkManager

    Это можно сделать несколькими способами, например, можно использовать программу конфигурации сети NetworkManager.

    Кликните по значку NetworkManager на панели, затем выберите изменить соединения , затем нажмите кнопку Добавить :

    Затем выберите тип соединения Мост и нажмите Создать :

    В открывшемся окне нажмите кнопку Добавить, чтобы связать наш мост с подключением к интернету:

    Из списка выберите Ethernet и нажмите Создать :

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

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

    Ручная настройка моста

    Сначала нужно установить набор утилит bridge-utils если вы еще этого не сделали:

    sudo apt install bridge-utils

    Затем, с помощью программы brctl мы можем создать нужный нам мост. Для этого используйте такие команды:

    sudo brctl addbr bridge0
    $ sudo ip addr show
    $ sudo addif bridge0 eth0

    Первая команда добавляет устройство моста br0, с помощью второй вам нужно определить какой сетевой интерфейс является основным подключением к внешней сети, в моем случае это eth0. И с помощью последней команды мы связываем мост br0 с eth0.

    Теперь необходимо добавить несколько строк в настройки сети чтобы все поднималось автоматически после старта системы. Для этого откройте файл /etc/network/interfaces и добавьте туда такие строки:

    sudo gedit /etc/network/interfaces

    loopback
    auto lo bridge0
    iface lo inet loopback
    iface bridge0 inet dhcp
    bridge_ports eth0

    Когда настройки будут добавлены перезагрузите сеть:

    sudo systemctl restart networking

    Теперь установка и настройка KVM полностью завершена и вы можете создать свою первую виртуальную машину. После этого вы можете посмотреть доступные мосты с помощью команды:

    Создание виртуальных машин KVM

    Настройка KVM Ubuntu завершена и теперь мы можем перейти к ее использованию. Сначала давайте просмотрим список уже существующих виртуальных машин:

    virsh -c qemu:///system list

    Он пуст. Создать виртуальную машину можно через терминал или в графическом интерфейсе. Для создания через терминал используйте команду virt-install. Сначала перейдем в папку libvirt:

    cd /var/lib/libvirt/boot/

    Для установки CentOS команда будет выглядеть вот так:

    sudo virt-install \
    --virt-type=kvm \
    --name centos7 \
    --ram 2048 \
    --vcpus=2 \
    --os-variant=rhel7 \
    --hvm \
    --cdrom=/var/lib/libvirt/boot/CentOS-7-x86_64-DVD-1511.iso \
    --network=bridge=br0,model=virtio \
    --graphics vnc \
    --disk path=/var/lib/libvirt/images/centos7.qcow2,size=40,bus=virtio,format=qcow2

    Разберем подробнее что означают параметры этой команды:

    • virt-type - тип виртуализации, в нашем случае kvm;
    • name - имя новой машины;
    • ram - количество памяти в мегабайтах;
    • vcpus - количество ядер процессора;
    • os-variant - тип операционной системы;
    • cdrom - установочный образ системы;
    • network-bridge - сетевой мост, который мы настроили ранее;
    • graphics - способ получения доступа к графическому интерфейсу;
    • diskpath - адрес нового жесткого диска для этой виртуальной машины;

    После завершения установки виртуальной машины вы можете узнать параметры подключения по VNC с помощью команды:

    sudo virsh vncdisplay centos7

    Теперь вы можете ввести полученные данные в вашем клиенте VNC и подключится к виртуальной машине даже удаленно. Для Debian команда будет немного отличаться, но все выглядит похожим образом:

    Переходим в папку для образов:

    cd /var/lib/libvirt/boot/

    Можно скачать установочный образ из интернета если это необходимо:

    sudo wget https://mirrors.kernel.org/debian-cd/current/amd64/iso-dvd/debian-8.5.0-amd64-DVD-1.iso

    Затем создадим виртуальную машину:

    sudo virt-install \
    --virt-type=kvm \
    --name=debina8 \
    --ram=2048 \
    --vcpus=2 \
    --os-variant=debian8 \
    --hvm \
    --cdrom=/var/lib/libvirt/boot/debian-8.5.0-amd64-DVD-1.iso \
    --network=bridge=bridge0,model=virtio \
    --graphics vnc \
    --disk path=/var/lib/libvirt/images/debian8.qcow2,size=40,bus=virtio,format=qcow2

    Теперь снова посмотрим список доступных машин:

    virsh -c qemu:///system list

    Для запуска виртуальной машины можно использовать команду:

    sudo virsh start имя_машины

    Для остановки:

    sudo virsh shutdown имя_машины

    Для перевода в режим сна:

    sudo virsh suspend имя_машины

    Для перезагрузки:

    sudo virsh reboot имя_машины

    sudo virsh reset имя_машины

    Для полного удаления виртуальной машины:

    sudo virsh destroy имя_машины

    Создание виртуальных машин в GUI\

    Если у вас есть доступ к графическому интерфейсу то нет никакой необходимости использовать терминал, вы можете применить полноценный графический интерфейс менеджера виртуальных машин Virtual Manager. Программу можно запустить из главного меню:

    Для создания новой машины кликните по иконке со значком монитора. Дальше вам будет необходимо выбрать образ ISO вашей системы. Также можно использовать реальный CD/DVD привод:

    На следующем экране выберите количество памяти, которая будет доступна для виртуальной машины, а также количество ядер процессора:

    На этом экране вам нужно выбрать размер жесткого диска, который будет доступен в вашей машине:

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

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

    Выводы

    В этой статье мы рассмотрели как выполняется установка KVM Ubuntu 16.04, разобрали как полностью подготовить эту среду к работе, а также как создать виртуальные машины и использовать их. Если у вас остались вопросы, спрашивайте в комментариях!

    На завершение лекция от яндекса о том что такое виртуализация в Linux:

    В Ubuntu рекомендуется использовать гипервизор (менеджер виртуальных машин) KVM и библиотеку libvirt в качестве инструментария управления им. Libvirt включает в себя набор программного API и пользовательских приложений управления виртуальными машинами (ВМ) virt-manager (графический интерфейс, GUI) или virsh (командная строка, CLI). В качестве альтернативных менеджеров можно использовать convirt (GUI) или convirt2 (WEB интерфейс).

    В настоящее время в Ubuntu офицально поддерживается только гипервизор KVM. Этот гипервизор является частью кода ядра операционной системы Linux. В отличие от Xen, KVM не поддерживает паравиртуализацию, то есть, для того, чтобы его использовать, ваш CPU должен подерживать технологии VT. Вы можете проверить, поддерживает ли ваш процессор эту технологию, выполнив команду в терминале:

    Если в результате получили сообщение:

    INFO: /dev/kvm exists KVM acceleration can be used

    значит KVM будет работать без проблем.

    Если же на выходе получили сообщение:

    Your CPU does not support KVM extensions KVM acceleration can NOT be used

    то вы всё равно сможете использовать виртуальную машину, но работать она будет намного медленнее.

      Устанавливать в качестве гостевых 64-битные системы

      Выделять гостевым системам более 2 Гбайт ОЗУ

    Установка

    Sudo apt-get install qemu-kvm libvirt-bin ubuntu-vm-builder bridge-utils

    Это установка на сервер без X-ов, т. е. не включает в себя графический интерфейс. Установить его можно командой

    Sudo apt-get install virt-manager

    После этого в меню появится пункт «Менеджер виртуальных машин» и, с большой долей вероятности, всё заработает. Если какие-то проблемы всё же возникнут, то нужно будет почитать инструкцию в англоязычной вики.

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

    Процедура создания гостевой системы с помощью графического интерфейса достаточно проста.

    А вот текстовый режим можно и описать.

    qcow2

    При создании системы с помощью графического интерфейса в качестве жёсткого диска предлагается либо выбрать уже существующий файл-образ или блочное устройсво, либо создать новый файл с сырыми (RAW) данными. Однако, это далеко не единственный доступный формат файлов. Из всех перечисленных в man qemu-img типов дисков наиболее гибким и современным является qcow2 . Он поддерживает снапшоты, шифрование и сжатие. Его необходимо создавать до того, как создать новую гостевую систему.

    Qemu-img create -o preallocation=metadata -f qcow2 qcow2.img 20G

    Согласно тому же man qemu-img , предварительное размещение метаданных (-o preallocation=metadata) делает диск изначально немного больше, но обеспечивает лучшую производительность в те моменты, когда образу нужно расти. На самом деле, в данном случае эта опция позволяет избежать неприятного бага. Создаваемый образ изначально занимает меньше мегабайта места и по мере необходимости растёт до указанного размера. Гостевая система сразу должна видеть этот окончательный указанный размер, тем не менее, на этапе установки она может увидеть реальный размер файла. Естественно, устанавливаться на жёсткий диск размером 200 кбайт она откажется. Баг не специфичен для Ubuntu, проявляется ещё в RHEL, как минимум.

    Кроме типа образа впоследствии можно будет выбрать способ его подключения - IDE, SCSI или Virtio Disk. От этого выбора будет зависеть производительность дисковой подсистемы. Однозначно правильного ответа нет, выбирать нужно исходя из задачи, которая будет возложена на гостевую систему. Если гостевая система создаётся «на посмотреть», то сойдёт любой способ. Вообще, обычно именно I/O является узким местом виртуальной машины, поэтому при создании высоконагруженной системы к этому вопросу нужно отнестись максимально ответственно.



    Загрузка...