系统&服务管理进阶
搭建KVM服务器
- 虚拟化概述
• virtualization 资源管理
– x个物理资源 --> y个逻辑资源
– 实现程度:完全、部分、硬件辅劣(CPU)
- 虚拟化概述(续1)
• 虚拟化主要厂商及产品
系 列 PC/服务器版代表
VMware VMware Workstation、vSphere
Microsoft VirtualPC、Hyper-V
RedHat KVM、RHEV
Citrix Xen
Oracle Oracle VM VirtualBox
- yum软件组管理
• 快速配置RHEL7光盘源
– 为虚拟机连接RHEL7光盘镜像,并挂载到固定位置
[root@kvmsvr ~]# mkdir /mnt/dvd //创建挂载点
[root@kvmsvr ~]# vim /etc/fstab //添加开机挂载配置
.. ..
/dev/cdrom /mnt/dvd iso9660 ro 0 0
[root@kvmsvr ~]# mount -a //挂载光盘
– 添加到 file:///mnt/dvd 的本地YUM源配置
[root@kvmsvr ~]# yum-config-manager --add file:///mnt/dvd
[root@kvmsvr ~]# vim /etc/yum.repos.d/mnt_dvd.repo
.. ..
gpgcheck=0
- yum软件组管理(续1)
• 使用RHEL7软件仏库的预设分组
– yum groups list [hidden] [组名]...
– yum groups info [组名]...
– yum groups install [组名]...
– yum groups remove [组名]...
- 安装虚拟化服务器平台
• 主要软件组
– 虚拟化平台 —— "Virtualization Platform"
– 虚拟化主机 —— "Virtualization Host"
– 虚拟化客户端 —— "Virtualization Client"
[root@kvmsvr ~]# yum -y groups install 虚拟化主机 虚拟化平台
虚拟化客户端
.. ..
- 启动libvirtd服务端
• libvirtd 为管理虚拟机提供服务接口
– 调用 dnsmasq 提供DNS、DHCP等功能
– 建立 virbr0 虚拟网络(192.168.122.0/24)
[root@kvmsvr ~]# systemctl restart libvirtd
.. ..
[root@kvmsvr ~]# ifconfig virbr0
virbr0: flags=4099<UP,BROADCAST,MULTICAST> mtu 1500
inet 192.168.122.1 netmask 255.255.255.0 broadcast
192.168.122.255
.. ..
案例1:安装一个KVM服务器
1. 准备一台 RHEL7.2 服务器
2. 关闭SELinux、防火墙
3. 挂载RHEL7光盘到 /mnt/dvd,配置为本机YUM源
– baseurl = file:///mnt/dvd
- 安装KVM相关包组,确保已启用 libvirtd 服务
配置真机网络
1) 防火墙设置
[root@redhat ]# cd /etc/sysctl.d/
[root@redhat sysctl.d]# vim 70-sysctl.conf
net.ipv4.ip_forward = 1
2)配置网卡
[root@redhat ~]# cd /etc/libvirt/qemu/networks/
[root@redhat networks]# vim vbr.xml
<network>
<name>vbr</name>
<forward mode='nat'/>
<bridge name='vbr' stp='on' delay='0'/> #桥接外网的配置
<ip address='192.168.1.254' netmask='255.255.255.0'>
<dhcp>
<range start='192.168.1.100' end='192.168.1.200'/>
</dhcp>
</ip>
</network>
3)自定义网卡
[root@redhat networks]#virsh net-define vbr.xml
4) 启动网卡
[root@redhat networks]#virsh net-start vbr
5) 设置为自启
[root@redhat networks]#virsh net-autostart vbr
创建虚拟机
1) 挂储存卷
[root@redhat ]#cd /var/lib/libvirt/images/
[root@redhat images]#qemu-img create -f qcow2 node.qcow2 16G
2)安装常用包
[root@localhost ~]# yum provides ip
yum -y install iproute-3.10.0-87.el7.x86_64
[root@localhost ~]# yum provides vim
yum -y install vim-enhanced-7.4.160-2.el7.x86_64
yum -y install bash-completion.noarch
[root@localhost ~]# yum provides ifconfig
yum install net-tools.x86_64
3)查看路由
[root@localhost ~]# ip r
4)配置virsh链接
[root@localhost ~]# cd /etc/sysconfig/
[root@localhost sysconfig]# vim grub
......//添加这行
GRUB_CMDLINE_LINUX="console=tty0 console=ttyS0,115200n8"
GRUB_CMDLINE_LINUX="crashkernel=auto rhgb quiet" //可以不加入 (写入不显示内核加载显示)
5)重起虚拟机
[root@localhost sysconfig]# grub2-mkconfig -o /boot/grub2/grub.cfg
[root@redhat ~]# getenforce
Disabled
[root@localhost sysconfig]# reboot
6)链接虚拟机
[root@redhat ~]# virsh console centos7.0-3
......// Ctrl +】 退出
操作虚拟机
l 查看虚拟化信息
• 查看KVM节点(服务器)信息
– virsh nodeinfo
• 列出虚拟机
– virsh list [--all]
• 列出虚拟网络
– virsh net-list [--all]
• 查看挃定虚拟机的信息
– virsh dominfo 虚拟机名称
l 查看虚拟化信息
• 查看KVM节点(服务器)信息
– virsh nodeinfo
• 列出虚拟机
– virsh list [--all]
• 列出虚拟网络
– virsh net-list [--all]
• 查看挃定虚拟机的信息
– virsh dominfo 虚拟机名称
l 开关机操作
• 运行|重启|关闭挃定的虚拟机
– virsh start|reboot|shutdown 虚拟机名称
• 强制关闭挃定的虚拟机
– virsh destroy 虚拟机名称
• 将挃定的虚拟机设为开机自劢运行
– virsh autostart [--disable] 虚拟机名称
删掉虚拟机,快速克隆虚拟机
1)修改网卡配置文件
[root@localhost network-scripts]# vim
/etc/sysconfig/network-scripts/ifcfg-eth0
... ....
BOOTPROTO=dhcp
[root@redhat ~]# cd /etc/libvirt/qemu/
2)拷贝虚拟机配置文件
[root@redhat qemu]# cp centos7.0-3.xml centos7.0-3.xml.bak
[root@redhat qemu]# mv centos7.0-3.xml.bak /root/
[root@redhat qemu]# vim centos7.0-3.xml
3)删掉虚拟机及配置文件
... ....
4)重建磁盘卷
[root@redhat qemu]# cd /var/lib/libvirt/images/
[root@redhat images]# qemu-img create -b node.qcow2 -f qcow2 node1.img
5)重新还原新隆虚拟机
[root@redhat ~]# cd /etc/libvirt/qemu/
[root@redhat qemu]# vim centos7.0-3.xml
[root@redhat qemu]# virsh define node1.xml
[root@redhat qemu]# virsh start node1
[root@redhat qemu]# virsh console node1
[root@localhost ~]# ifconfig
6)真机上进入虚拟机help环境
[root@redhat ~]# virsh
配置新虚拟机
• 拷贝模板机的xml配置
– 挄照需要修改,并据此定义新虚拟机
[root@kvmsvr ~]# cp /data/images/rhel7_muban.xml /root/
[root@kvmsvr ~]# vim /root/rhel7_muban.xml
.. ..
//修改name、uuid、disk、mac
[root@kvmsvr images]# virsh define /root/rhel7_muban.xml
定义域 rh7_node1(从 /root/rhel7_muban.xml)
配置虚拟机系统有奇招
• 使用 guestmount 工具
– 支持离线挂载 raw、qcow2 格式虚拟机磁盘
– 可以在虚拟机关机的情冴下,直接修改磁盘中的文档
– 方便对虚拟机定制、修复、脚本维护
!!! 需要注意 SELinux 机制的影响
如何挂载虚拟盘
• 基本用法
guestmount -a 虚拟机磁盘路径 -i /挂载点
[root@kvmsvr ~]# mkdir /mnt/kdisk
[root@kvmsvr ~]# guestmount -a node1.qcow2 -i /mnt/kdisk
[root@kvmsvr ~]# chroot /mnt/kdisk
[root@kvmsvr ~]# ls /mnt/kdisk
bin
.. ..