Поиск по сайту:

Как установить WebVirtCloud KVM Management в Ubuntu 20.04


На этой странице

  1. Предпосылки
  2. Начало работы
  3. Подтверждение поддержки виртуализации
  4. Установка гипервизора KVM
  5. Установка Nginx и других пакетов
  6. Установка и настройка WebVirtCloud
  7. Настройка KVM и Libvirt
  8. Доступ к WebVirtCloud
  9. Заключение

WebVirtCloud — это веб-инструмент управления виртуализацией KVM. Это позволяет администраторам и пользователям создавать, управлять и удалять виртуальные машины, работающие на гипервизоре KVM, из веб-интерфейса. Он построен на Django и поддерживает авторизацию и аутентификацию на основе пользователей. С помощью WebVirtCloud вы можете управлять несколькими гипервизорами QEMU/KVM, управлять сетями гипервизоров и управлять пулами хранилищ данных из одной установки.

В этом руководстве я покажу вам, как установить инструмент управления WebVirtCloud KVM в Ubuntu 20.04.

Предпосылки

  • Сервер под управлением Ubuntu 20.04.
  • На сервере настроен пароль root.

Начиная

Сначала обновите системные пакеты до обновленной версии, выполнив следующую команду:

apt-get update -y

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

Проверить поддержку виртуализации

Прежде чем начать, вам нужно будет проверить, поддерживает ли ваша операционная система аппаратную виртуализацию или нет.

Выполните следующую команду, чтобы проверить это.

grep -E -c "vmx|svm" /proc/cpuinfo

Если вывод больше 0, ваша операционная система поддерживает аппаратную виртуализацию.

2

Далее вам также необходимо проверить, способна ли ваша система запускать виртуальные машины KVM.

Для этого установите cpu-checker с помощью следующей команды:

apt-get install cpu-checker -y

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

kvm-ok

Вы должны увидеть следующий вывод:

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

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

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

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

apt-get install qemu qemu-kvm libvirt-daemon bridge-utils virt-manager virtinst -y

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

lsmod | grep -i kvm

Вы должны увидеть следующий вывод:

kvm_intel             286720  0
kvm                   663552  1 kvm_intel

Затем проверьте состояние службы libvirtd с помощью следующей команды:

systemctl status libvirtd

Вы должны увидеть следующий вывод:

? libvirtd.service - Virtualization daemon
     Loaded: loaded (/lib/systemd/system/libvirtd.service; enabled; vendor preset: enabled)
     Active: active (running) since Sun 2021-08-01 04:57:14 UTC; 1min 3s ago
TriggeredBy: ? libvirtd-admin.socket
             ? libvirtd-ro.socket
             ? libvirtd.socket
       Docs: man:libvirtd(8)
             https://libvirt.org
   Main PID: 5236 (libvirtd)
      Tasks: 19 (limit: 32768)
     Memory: 16.2M
     CGroup: /system.slice/libvirtd.service
             ??5236 /usr/sbin/libvirtd
             ??5385 /usr/sbin/dnsmasq --conf-file=/var/lib/libvirt/dnsmasq/default.conf --leasefile-ro --dhcp-script=/usr/lib/libvirt/libvirt_>
             ??5386 /usr/sbin/dnsmasq --conf-file=/var/lib/libvirt/dnsmasq/default.conf --leasefile-ro --dhcp-script=/usr/lib/libvirt/libvirt_>

Aug 01 04:57:14 ubunt4 systemd[1]: Started Virtualization daemon.
Aug 01 04:57:15 ubunt4 dnsmasq[5385]: started, version 2.80 cachesize 150
Aug 01 04:57:15 ubunt4 dnsmasq[5385]: compile time options: IPv6 GNU-getopt DBus i18n IDN DHCP DHCPv6 no-Lua TFTP conntrack ipset auth net>
Aug 01 04:57:15 ubunt4 dnsmasq-dhcp[5385]: DHCP, IP range 192.168.122.2 -- 192.168.122.254, lease time 1h
Aug 01 04:57:15 ubunt4 dnsmasq-dhcp[5385]: DHCP, sockets bound exclusively to interface virbr0
Aug 01 04:57:15 ubunt4 dnsmasq[5385]: reading /etc/resolv.conf
Aug 01 04:57:15 ubunt4 dnsmasq[5385]: using nameserver 127.0.0.53#53
Aug 01 04:57:15 ubunt4 dnsmasq[5385]: read /etc/hosts - 5 addresses
Aug 01 04:57:15 ubunt4 dnsmasq[5385]: read /var/lib/libvirt/dnsmasq/default.addnhosts - 0 addresses
Aug 01 04:57:15 ubunt4 dnsmasq-dhcp[5385]: read /var/lib/libvirt/dnsmasq/default.hostsfile

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

Установите Nginx и другие пакеты

Далее вам нужно будет установить Nginx, Python и другие необходимые пакеты на ваш сервер. Вы можете установить их все с помощью следующей команды:

apt-get install git virtualenv python3-virtualenv python3-dev python3-lxml libvirt-dev zlib1g-dev libxslt1-dev nginx supervisor libsasl2-modules gcc pkg-config python3-guestfs libsasl2-dev libldap2-dev libssl-dev -y

После установки всех пакетов можно переходить к следующему шагу.

Установите и настройте WebVirtCloud

Сначала загрузите последнюю версию WebVirtCloud из репозитория Git с помощью следующей команды:

git clone https://github.com/retspen/webvirtcloud

После завершения загрузки измените каталог на webvirtcloud и скопируйте образец файла settings.py:

cd webvirtcloud
cp webvirtcloud/settings.py.template webvirtcloud/settings.py

Затем сгенерируйте секретный ключ с помощью следующей команды:

openssl rand -base64 32

Вы должны получить следующий результат:

mTHhsUm5adG8DABJaIvmRLpQjNbL1vdeIpBDi/jQCV0=

Затем отредактируйте файл settings.py и определите секретный ключ:

nano webvirtcloud/settings.py

Измените следующую строку:

SECRET_KEY = "mTHhsUm5adG8DABJaIvmRLpQjNbL1vdeIpBDi/jQCV0="

Сохраните и закройте файл, затем скопируйте файл конфигурации WebVirtCloud в каталог Nginx и Supervisor:

cp conf/supervisor/webvirtcloud.conf /etc/supervisor/conf.d
cp conf/nginx/webvirtcloud.conf /etc/nginx/conf.d

Затем вернитесь в свой домашний каталог и переместите каталог webvirtcloud из каталога /srv:

cd ..
mv webvirtcloud /srv/

Затем установите правильное право собственности на каталог webvirtcloud:

chown -R www-data:www-data /srv/webvirtcloud/

Затем измените каталог на webvirtcloud и создайте виртуальную среду:

cd /srv/webvirtcloud/
virtualenv -p python3 venv

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

source venv/bin/activate

Затем установите необходимые зависимости Python с помощью следующей команды:

pip install -r conf/requirements.txt

Вы должны увидеть следующий вывод:

Successfully built libvirt-python qrcode rwlock websockify
Installing collected packages: sqlparse, pytz, asgiref, Django, soupsieve, beautifulsoup4, django-bootstrap5, django-icons, django-login-required-middleware, django-otp, segno, django-qr-code, gunicorn, six, libsass, libvirt-python, lxml, qrcode, rwlock, numpy, websockify, zipp, pyasn1, ldap3
Successfully installed Django-3.2.5 asgiref-3.4.1 beautifulsoup4-4.9.3 django-bootstrap5-2.0.1 django-icons-4.0.0 django-login-required-middleware-0.6.1 django-otp-1.0.6 django-qr-code-2.2.0 gunicorn-20.1.0 ldap3-2.9 libsass-0.21.0 libvirt-python-7.4.0 lxml-4.6.3 numpy-1.21.1 pyasn1-0.4.8 pytz-2021.1 qrcode-7.0 rwlock-0.0.7 segno-1.3.3 six-1.16.0 soupsieve-2.2.1 sqlparse-0.4.1 websockify-0.9.0 zipp-3.4.1

Затем запустите команду migrate, чтобы сгенерировать все таблицы:

python3 manage.py migrate

Вы должны увидеть следующий вывод:

  Applying otp_totp.0001_initial... OK
  Applying otp_totp.0002_auto_20190420_0723... OK
  Applying sessions.0001_initial... OK
* Creating default admin user
! SHOW_PROFILE_EDIT_PASSWORD is found inside settings.py
* Applying permission can_change_password for all users
! Warning!!! Setting to True for all users
! Don`t forget to remove the option from settings.py
* Migrating can_clone_instaces user attribute to permission
* Applying permission passwordless_console for all users

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

deactivate

Затем установите правильное право собственности на каталог webvirtcloud с помощью следующей команды:

chown -R www-data:www-data /srv/webvirtcloud/

Затем удалите файл конфигурации виртуального хоста Nginx по умолчанию:

rm /etc/nginx/sites-enabled/default

Затем перезапустите службу Nginx и Supervisor, чтобы применить изменения:

systemctl restart nginx
systemctl restart supervisor

Теперь вы можете проверить статус Nginx с помощью следующей команды:

systemctl status nginx

Вы должны увидеть следующий вывод:

? nginx.service - A high performance web server and a reverse proxy server
     Loaded: loaded (/lib/systemd/system/nginx.service; enabled; vendor preset: enabled)
     Active: active (running) since Sun 2021-08-01 10:35:57 UTC; 12s ago
       Docs: man:nginx(8)
    Process: 29055 ExecStartPre=/usr/sbin/nginx -t -q -g daemon on; master_process on; (code=exited, status=0/SUCCESS)
    Process: 29068 ExecStart=/usr/sbin/nginx -g daemon on; master_process on; (code=exited, status=0/SUCCESS)
   Main PID: 29076 (nginx)
      Tasks: 3 (limit: 4691)
     Memory: 3.4M
     CGroup: /system.slice/nginx.service
             ??29076 nginx: master process /usr/sbin/nginx -g daemon on; master_process on;
             ??29077 nginx: worker process
             ??29078 nginx: worker process

Aug 01 10:35:57 ubunt4 systemd[1]: Starting A high performance web server and a reverse proxy server...
Aug 01 10:35:57 ubunt4 systemd[1]: Started A high performance web server and a reverse proxy server.

Настройка KVM и Libvirt

Затем запустите следующий скрипт для настройки KVM и Libvirt:

wget -O - https://bit.ly/36baWUu | sh

Вы должны увидеть следующий вывод:

Length: 151 [text/plain]
Saving to: ‘/etc/supervisor/conf.d/gstfsd.conf’

/etc/supervisor/conf.d/gstfsd.conf  100%[==================================================================>]     151  --.-KB/s    in 0s      

2021-08-01 10:36:51 (5.50 MB/s) - ‘/etc/supervisor/conf.d/gstfsd.conf’ saved [151/151]

 *  INFO: Found function daemons_running_ubuntu
 * DEBUG: DAEMONS_RUNNING_FUNC=daemons_running_ubuntu
 *  INFO: Running daemons_running_ubuntu()

Наконец, добавьте пользователя KVM в группу www-data с помощью следующей команды:

adduser www-data kvm

Доступ к WebVirtCloud

На данный момент WebVirtCloud установлен и настроен. Пришло время получить доступ к веб-интерфейсу WebVirtCloud.

Откройте веб-браузер и введите URL-адрес http://your-server-ip. Вы будете перенаправлены на страницу входа в WebVirtCloud:

Укажите имя пользователя и пароль по умолчанию как admin/admin и нажмите кнопку «Войти». Вы должны увидеть панель инструментов WebVirtCloud на следующей странице:

Заключение

Поздравляем! вы успешно установили WebVirtCloud на сервер Ubuntu 20.04. Теперь вы можете создавать виртуальные машины и управлять ими через веб-интерфейс. Не стесняйтесь спрашивать меня, если у вас есть какие-либо вопросы.