OpenVZ установка · 3 min read · Nov 28, 2025
Установка и использование OpenVZ на CentOS 5.6
Установка и использование OpenVZ на CentOS 5.6
Версия 1.0
Автор: Фалко Тимме
Следите за мной в Twitter
В этом руководстве я опишу, как подготовить сервер CentOS 5.6 для OpenVZ. С помощью OpenVZ вы можете создать несколько виртуальных частных серверов (VPS) на одном оборудовании, аналогично Xen и проекту Linux Vserver. OpenVZ является открытой версией Virtuozzo, коммерческого решения для виртуализации, используемого многими провайдерами, которые предлагают виртуальные серверы. Патч ядра OpenVZ лицензирован под лицензией GPL, а инструменты уровня пользователя — под лицензией QPL.
Это руководство предназначено как практическое руководство; оно не охватывает теоретические основы. Они рассматриваются во многих других документах в сети.
Этот документ предоставляется без каких-либо гарантий! Я хочу сказать, что это не единственный способ настройки такой системы. Существует много способов достижения этой цели, но это тот путь, который я выбрал. Я не даю никаких гарантий, что это сработает для вас!
1 Установка OpenVZ
Чтобы установить OpenVZ, нам нужно добавить репозиторий OpenVZ в yum:
cd /etc/yum.repos.d
wget http://download.openvz.org/openvz.repo
rpm --import http://download.openvz.org/RPM-GPG-Key-OpenVZРепозиторий содержит несколько различных ядер OpenVZ (вы можете найти больше деталей о них здесь: http://wiki.openvz.org/Kernel_flavors). Команда
yum search ovzkernelпоказывает доступные ядра:
[root@server1 yum.repos.d]# yum search ovzkernel
...
ovzkernel.i686 : Ядро Virtuozzo Linux (ядро операционной системы Linux)
ovzkernel.x86_64 : Ядро Virtuozzo Linux (ядро операционной системы Linux)
ovzkernel-PAE.i686 : Ядро Linux, скомпилированное для машин с поддержкой PAE.
ovzkernel-PAE-debug.i686 : Ядро Linux PAE, скомпилированное с конфигурацией отладки
ovzkernel-PAE-devel.i686 : Пакет разработки для сборки модулей ядра, соответствующих ядру PAE.
ovzkernel-debug.i686 : Ядро Linux, скомпилированное с конфигурацией отладки
ovzkernel-debug.x86_64 : Ядро Linux, скомпилированное с конфигурацией отладки
ovzkernel-devel.i686 : Пакет разработки для сборки модулей ядра, соответствующих ядру.
ovzkernel-devel.x86_64 : Пакет разработки для сборки модулей ядра, соответствующих ядру.
ovzkernel-ent.i686 : Ядро Linux, скомпилированное для машин с большой памятью.
ovzkernel-ent-debug.i686 : Ядро Linux ent, скомпилированное с конфигурацией отладки
ovzkernel-ent-devel.i686 : Пакет разработки для сборки модулей ядра, соответствующих ядру ent.
ovzkernel-xen.i686 : Ядро Linux, скомпилированное для операций с Xen VM
ovzkernel-xen.x86_64 : Ядро Linux, скомпилированное для операций с Xen VM
ovzkernel-xen-devel.i686 : Пакет разработки для сборки модулей ядра, соответствующих ядру.
ovzkernel-xen-devel.x86_64 : Пакет разработки для сборки модулей ядра, соответствующих ядру.
[root@server1 yum.repos.d]#Выберите одно из них и установите его следующим образом:
yum install ovzkernelЭто должно автоматически обновить загрузчик GRUB. В любом случае, мы должны открыть /boot/grub/menu.lst; первая строка ядра теперь должна содержать новое ядро OpenVZ. Заголовок этого ядра просто читается как “CentOS”. Я думаю, что хорошей идеей будет изменить этот заголовок и добавить что-то с “OpenVZ”, чтобы вы знали, что это ядро OpenVZ. Также убедитесь, что значение default равно 0, чтобы первое ядро (ядро OpenVZ) загружалось автоматически вместо ядра по умолчанию CentOS.
vi /boot/grub/menu.lst| # grub.conf сгенерирован anaconda # # Обратите внимание, что вам не нужно повторно запускать grub после внесения изменений в этот файл # УВЕДОМЛЕНИЕ: У вас есть раздел /boot. Это означает, что # все пути к ядру и initrd относительны к /boot/, т.е. # root (hd0,0) # kernel /vmlinuz-version ro root=/dev/VolGroup00/LogVol00 # initrd /initrd-version.img #boot=/dev/sda default=0 timeout=5 splashimage=(hd0,0)/grub/splash.xpm.gz hiddenmenu title CentOS OpenVZ (2.6.18-238.5.1.el5.028stab085.5) root (hd0,0) kernel /vmlinuz-2.6.18-238.5.1.el5.028stab085.5 ro root=/dev/VolGroup00/LogVol00 initrd /initrd-2.6.18-238.5.1.el5.028stab085.5.img title CentOS (2.6.18-238.el5) root (hd0,0) kernel /vmlinuz-2.6.18-238.el5 ro root=/dev/VolGroup00/LogVol00 initrd /initrd-2.6.18-238.el5.img |
Теперь мы установим некоторые инструменты пользователя OpenVZ:
yum install vzctl vzquotaОткройте /etc/sysctl.conf и убедитесь, что у вас есть следующие настройки:
vi /etc/sysctl.conf| [...] net.ipv4.ip_forward = 1 net.ipv4.conf.default.proxy_arp = 0 net.ipv4.conf.all.rp_filter = 1 kernel.sysrq = 1 net.ipv4.conf.default.send_redirects = 1 net.ipv4.conf.all.send_redirects = 0 net.ipv4.icmp_echo_ignore_broadcasts=1 net.ipv4.conf.default.forwarding=1 [...] |
Если вам нужно изменить /etc/sysctl.conf, выполните
sysctl -pпосле этого.
Следующий шаг важен, если IP-адреса ваших виртуальных машин находятся в другом подсети, чем IP-адрес хост-системы. Если вы этого не сделаете, сеть не будет работать в виртуальных машинах!
Откройте /etc/vz/vz.conf и установите NEIGHBOUR_DEVS в all:
vi /etc/vz/vz.conf| [...] NEIGHBOUR_DEVS=all [...] |
SELinux необходимо отключить, если вы хотите использовать OpenVZ. Откройте /etc/sysconfig/selinux и установите значение SELINUX в disabled:
vi /etc/sysconfig/selinux| # Этот файл управляет состоянием SELinux в системе. # SELINUX= может принимать одно из этих трех значений: # enforcing - Политика безопасности SELinux применяется. # permissive - SELinux выводит предупреждения вместо применения. # disabled - SELinux полностью отключен. SELINUX=disabled # SELINUXTYPE= тип политики, используемой. Возможные значения: # targeted - Защищены только целевые сетевые демоны. # strict - Полная защита SELinux. SELINUXTYPE=targeted |
Наконец, перезагрузите систему:
rebootЕсли ваша система перезагрузилась без проблем, значит, все в порядке!
Выполните
uname -rи ваше новое ядро OpenVZ должно появиться:
[root@server1 ~]# uname -r
2.6.18-238.5.1.el5.028stab085.5
[root@server1 ~]#Get new posts in your inbox
No spam. Unsubscribe anytime.