RedOS 7.3 настройка рейд массива, установка KVM + Docker
## операционная система redos 7.3
# проверка обновлений
dnf update -y
dnf install -y setroubleshoot
# подготовка raid массива
mdadm --zero-superblock --force /dev/sd{b,c}
wipefs --all --force /dev/sd{b,c}
yes | mdadm --create --verbose /dev/md0 -l 1 -n 2 /dev/sd{b,c}
# создание файловой системы
mkfs.xfs /dev/md0 -f
# создаем папки для монтирования, получаем UUID
mkdir /data
fdisk -l | grep md0
# получаем UUID от md0 и монтируем раздел в /etc/fstab
echo "`echo "UUID=$(sudo blkid -s UUID -o value /dev/md0)"` /data xfs defaults 0 0" >> /etc/fstab
# проверяем
mount -a
# проверяем поддержку технологии Intel VT и сколько у нас всего ядер в системе
egrep -c '^flags.*\bvmx\b' /proc/cpuinfo
# устанавливаем kvm и запускаем
dnf install qemu-kvm libvirt virt-install -y
systemctl enable libvirtd && systemctl start libvirtd
sudo usermod -a -G libvirt $(whoami)
# добавляем мост ifcfg-bridge_vm
echo 'STP=no
TYPE=Bridge
PROXY_METHOD=none
BROWSER_ONLY=no
BOOTPROTO=dhcp
DEFROUTE=yes
IPV4_FAILURE_FATAL=no
IPV6INIT=no
IPV6_AUTOCONF=yes
IPV6_DEFROUTE=yes
IPV6_FAILURE_FATAL=no
IPV6_ADDR_GEN_MODE=stable-privacy
NAME=bridge_vm
UUID='"$(uuidgen)"'
DEVICE=bridge_vm
ONBOOT=yes
AUTOCONNECT_SLAVES=yes
ZONE=trusted' > /etc/sysconfig/network-scripts/ifcfg-bridge_vm
# меняем конфигурацию сетевого интерфейса ifcfg-enp2s0
echo 'TYPE=Ethernet
NAME=enp2s0
DEVICE=enp2s0
ONBOOT=yes
BRIDGE=bridge_vm' > /etc/sysconfig/network-scripts/ifcfg-enp2s0
# удаляем мост добавленный системой при установке
rm -rf /etc/sysconfig/network-scripts/ifcfg-virbr0
# перезагружаем сеть, смотрим новый адрес в dhcp
systemctl restart NetworkManager
# добавляем директории для пулов, меняем права
mkdir -p /data/kvm/{iso,images}
chown root:root /data/kvm/{iso,images}
chmod 700 /data/kvm/{iso,images}
# добавляем пул для образов операционных систем
virsh list --all
virsh pool-define-as iso dir - - - - "/data/kvm/iso/"
virsh pool-build iso
virsh pool-start iso
virsh pool-autostart iso
virsh pool-info iso
# добавляем пул для виртуальных машин
virsh list --all
virsh pool-define-as images dir - - - - "/data/kvm/images/"
virsh pool-build images
virsh pool-start images
virsh pool-autostart images
virsh pool-info images
# добавляем разрешения в selinux
semanage fcontext -a -t virt_image_t '/data/kvm/{iso,images}/(/.*)?'
restorecon -R /data/kvm/{iso,images}
# или отключаем SELinux
sed -i "s/SELINUX=enforcing/SELINUX=permissive/" /etc/selinux/config
# добавляем доступность VNC
sudo sed -i 's/^#vnc_listen = "0.0.0.0"/vnc_listen = "0.0.0.0"/' /etc/libvirt/qemu.conf
systemctl restart libvirtd
# переносим размещение дисков виртуальных машин
rm -rf /var/lib/libvirt/images && ln -s /data/kvm/images/ /var/lib/libvirt/
# установка docker
dnf install docker-ce docker-compose -y
sudo usermod -a -G docker $(whoami)
# добавление каталогов конфигурации docker
mkdir -p /data/docker/config
# добавление в автозагрузку и запускаем docker
systemctl enable --now docker && systemctl start docker