Виртуализация · 5 min read · Feb 01, 2026
Виртуализация с KVM на сервере Fedora 10
Виртуализация с KVM на сервере Fedora 10
Версия 1.0
Автор: Фалко Тимме
Этот гид объясняет, как вы можете установить и использовать KVM для создания и запуска виртуальных машин на сервере Fedora 10. Я покажу, как создать виртуальные машины на основе образов, а также виртуальные машины, которые используют логический том (LVM). KVM - это сокращение от Kernel-based Virtual Machine и использует аппаратную виртуализацию, т.е. вам нужен процессор, который поддерживает аппаратную виртуализацию, например, Intel VT или AMD-V.
Я не даю никаких гарантий, что это сработает для вас!
1 Предварительная заметка
Я использую сервер Fedora 10 с именем хоста server1.example.com и IP-адресом 192.168.0.100 здесь в качестве моего хоста KVM.
Перед тем, как мы начнем, убедитесь, что SELinux отключен. Откройте /etc/selinux/config…
vi /etc/selinux/config… и установите SELINUX в значение disabled:
| # Этот файл управляет состоянием SELinux в системе. # SELINUX= может принимать одно из этих трех значений: # enforcing - Политика безопасности SELinux применяется. # permissive - SELinux выводит предупреждения вместо применения. # disabled - Политика SELinux не загружена. SELINUX=disabled # SELINUXTYPE= может принимать одно из этих двух значений: # targeted - Защищены целевые процессы, # mls - Защита многоуровневой безопасности. SELINUXTYPE=targeted |
Запустите
setenforce 0… чтобы изменения вступили в силу.
Нам также нужна настольная система, на которой мы установим virt-manager, чтобы мы могли подключиться к графической консоли виртуальных машин, которые мы установим. Я использую настольную систему Ubuntu 8.10 здесь.
2 Установка KVM
Хост KVM Fedora 10:
Сначала проверьте, поддерживает ли ваш процессор аппаратную виртуализацию - если это так, команда
egrep '(vmx|svm)' --color=always /proc/cpuinfoдолжна отобразить что-то, например, вот так:
[root@server1 ~]# egrep '(vmx|svm)' --color=always /proc/cpuinfo
flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ht syscall
nx mmxext fxsr_opt rdtscp lm 3dnowext 3dnow rep_good nopl pni cx16 lahf_lm cmp_legacy svm extapic cr8_legacy 3dnowprefetch
flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ht syscall
nx mmxext fxsr_opt rdtscp lm 3dnowext 3dnow rep_good nopl pni cx16 lahf_lm cmp_legacy svm extapic cr8_legacy 3dnowprefetch
[root@server1 ~]#Если ничего не отображается, значит, ваш процессор не поддерживает аппаратную виртуализацию, и вы должны остановиться здесь.
Чтобы установить KVM и virtinst (инструмент для создания виртуальных машин), мы запускаем
yum install kvm qemu libvirt python-virtinstЗатем запустите демон libvirt:
/etc/init.d/libvirtd startЧтобы проверить, успешно ли установлен KVM, выполните
virsh -c qemu:///system listОн должен отобразить что-то вроде этого:
[root@server1 ~]# virsh -c qemu:///system list
Id Name State
----------------------------------
[root@server1 ~]#Если вместо этого отображается ошибка, значит, что-то пошло не так.
Далее нам нужно настроить сетевой мост на нашем сервере, чтобы наши виртуальные машины могли быть доступны с других хостов так, как если бы они были физическими системами в сети.
Для этого мы устанавливаем пакет bridge-utils…
yum install bridge-utils… и настраиваем мост. Удалите системные ссылки автозагрузки для NetworkManager и создайте системные ссылки автозагрузки для network:
chkconfig --del NetworkManager
chkconfig --levels 235 network onЗатем создайте файл /etc/sysconfig/network-scripts/ifcfg-br0 (пожалуйста, используйте значения BOOTPROTO, DNS1 (плюс любые другие настройки DNS, если есть), GATEWAY, IPADDR, NETMASK и SEARCH из файла /etc/sysconfig/network-scripts/ifcfg-eth0):
vi /etc/sysconfig/network-scripts/ifcfg-br0| DEVICE=br0 TYPE=Bridge BOOTPROTO=static DNS1=145.253.2.75 GATEWAY=192.168.0.1 IPADDR=192.168.0.100 NETMASK=255.255.255.0 ONBOOT=yes SEARCH="example.com" |
Измените /etc/sysconfig/network-scripts/ifcfg-eth0 следующим образом (закомментируйте BOOTPROTO, DNS1 (и все другие DNS-серверы, если есть), GATEWAY, IPADDR, NETMASK и SEARCH и добавьте BRIDGE=br0):
vi /etc/sysconfig/network-scripts/ifcfg-eth0| # nVidia Corporation Unknown (0x0760) DEVICE=eth0 #BOOTPROTO=static #DNS1=145.253.2.75 #GATEWAY=192.168.0.1 HWADDR=00:1e:90:f3:f0:02 #IPADDR=192.168.0.100 #NETMASK=255.255.255.0 ONBOOT=yes #SEARCH="example.com" BRIDGE=br0 |
Затем перезагрузите систему:
rebootПосле перезагрузки выполните
ifconfigТеперь он должен показать сетевой мост (br0):
[root@server1 ~]# ifconfig
br0 Link encap:Ethernet HWaddr 00:1E:90:F3:F0:02
inet addr:192.168.0.100 Bcast:192.168.0.255 Mask:255.255.255.0
inet6 addr: fe80::21e:90ff:fef3:f002/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:49 errors:0 dropped:0 overruns:0 frame:0
TX packets:72 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:6477 (6.3 KiB) TX bytes:10368 (10.1 KiB)
eth0 Link encap:Ethernet HWaddr 00:1E:90:F3:F0:02
inet6 addr: fe80::21e:90ff:fef3:f002/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:57 errors:0 dropped:0 overruns:0 frame:0
TX packets:55 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:9912 (9.6 KiB) TX bytes:8038 (7.8 KiB)
Interrupt:22 Base address:0xa000
lo Link encap:Local Loopback
inet addr:127.0.0.1 Mask:255.0.0.0
inet6 addr: ::1/128 Scope:Host
UP LOOPBACK RUNNING MTU:16436 Metric:1
RX packets:8 errors:0 dropped:0 overruns:0 frame:0
TX packets:8 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:560 (560.0 b) TX bytes:560 (560.0 b)
virbr0 Link encap:Ethernet HWaddr 62:6D:75:53:9C:AD
inet addr:192.168.122.1 Bcast:192.168.122.255 Mask:255.255.255.0
inet6 addr: fe80::606d:75ff:fe53:9cad/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:34 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:0 (0.0 b) TX bytes:5277 (5.1 KiB)
[root@server1 ~]#3 Установка virt-viewer или virt-manager на вашем настольном компьютере Ubuntu 8.10
Настольный компьютер Ubuntu 8.10:
Нам нужно средство для подключения к графической консоли наших гостей - мы можем использовать virt-manager (см. Управление гостями KVM с помощью Virt-Manager на Ubuntu 8.10) для этого. Я предполагаю, что вы используете настольный компьютер Ubuntu 8.10.
Запустите
sudo aptitude install virt-managerчтобы установить virt-manager.
(Если вы используете настольный компьютер Fedora 10, вы можете установить virt-manager следующим образом:
Станьте root…
su… и выполните
yum install virt-manager)
4 Создание гостя Debian Lenny (на основе образа)
Хост KVM Fedora 10:
Теперь давайте вернемся к нашему хосту KVM Fedora 10.
Посмотрите на
man virt-installчтобы узнать, как его использовать.
Чтобы создать гостя Debian Lenny (в режиме моста) с именем vm10, 512 МБ ОЗУ, двумя виртуальными процессорами и образом диска ~/vm10.qcow2 (размером 12 ГБ), вставьте CD-диск Debian Lenny Netinstall в CD-привод и выполните
virt-install --connect qemu:///system -n vm10 -r 512 --vcpus=2 -f ~/vm10.qcow2 -s 12 -c /dev/cdrom --vnc --noautoconsole --os-type linux --os-variant debianLenny --accelerate --network=bridge:br0 --hvmКонечно, вы также можете создать ISO-образ CD-диска Debian Lenny Netinstall…
dd if=/dev/cdrom of=~/debian-500-amd64-netinst.iso… и использовать ISO-образ в команде virt-install:
virt-install --connect qemu:///system -n vm10 -r 512 --vcpus=2 -f ~/vm10.qcow2 -s 12 -c ~/debian-500-amd64-netinst.iso --vnc --noautoconsole --os-type linux --os-variant debianLenny --accelerate --network=bridge:br0 --hvmВывод будет следующим:
[root@server1 ~]# virt-install --connect qemu:///system -n vm10 -r 512 --vcpus=2 -f ~/vm10.qcow2 -s 12 -c ~/debian-500-amd64-netinst.iso --vnc --noautoconsole --os-type linux --os-variant debianLenny --accelerate --network=bridge:br0 --hvm
Запуск установки...
Создание файла хранилища... | 12 GB 00:00
Создание домена... | 0 B 00:00
Установка домена все еще в процессе. Вы можете переподключиться к
консоли, чтобы завершить процесс установки.
[root@server1 ~]#Get new posts in your inbox
No spam. Unsubscribe anytime.