kingforce 发表于 2017-6-24 12:50:57

2 云计算系列之KVM的安装与使用

preface
  在上篇博客中,我们讲了云的概念,分类,以及虚拟化技术。我们知道Openstack的虚拟化技术是基于KVM的,所以下面就开始说说如何部署和使用KVM。
  
下面的讲解包含以下知识点:


[*]安装KVM
[*]创建虚拟机与启动,停止虚拟机
[*]修改虚拟机的配置
[*]KVM-虚拟机的网络桥接
  环境准备
  
我这里的服务器角色是:

IP
hostname
192.168.56.11
linux-node1.example.com
192.168.56.12
linux-node2.example.com

[*]以上系统都是CentOs 7的系统,内核版本是3.10.0-123.el7.x86_64
[*]所有hosts文件都能够互相解析对方的主机名
[*]关闭selinux和防火墙。
[*]我这里使用的是VMware,使用时必须开启cpu虚拟化功能。
[*]网卡命名为eth0
动手操作,准备基础环境,两台机器同样操作

安装yum仓库
  

# rpm -ivh http://mirrors.aliyun.com/epel/epel-release-latest-7.noarch.rpm  

  

关闭Network和防火墙,selinux
  

# systemctl disable firewalld  
# systemctl disable NetworkManager
  
# grep -v ^# /etc/selinux/config
  
SELINUX=disabled
  

  

更新系统并且重启
  花的时间比较长,耐心等待
  

# yum update -y && reboot     

安装KVM


[*]qemu-kvm: kvm用户态的管理工具,和ipvsadm一样的。  


[*]libvirt:用来管理kvm虚拟机的
[*]  virt-install: 用来安装虚拟机用的。
  

# yum -y install qemu-kvm libvirt virt-install  
# systemctl enable libvirtd
  
# systemctl start libvirtd
  
安装好以后,我们创建一个硬盘,这里解释下参数:



[*]-f raw 表示使用raw格式,指定把硬盘放在哪里。
[*]  10G 表示这个硬盘有多大的空间。
  
qcow2是用多少就占用多大的空间,raw是一开始就占用了10G的空间即使你没有使用
  

# qemu-img create -f raw /opt/CentOs-7-x86.64.raw 10G
  
Formatting '/opt/CentOs-7-x86.64.raw', fmt=raw>  
# qemu-img create -f qcow2 /opt/CentOs-7-x86.64.qcow2 10G   # 这里仅供参考,不需要执行这步
  
然后再创建一个虚拟机,参数解释下:

[*]-virt-type kvm 虚拟机类型为KVM
[*]--name 为虚拟机娶一个名字
[*]--ram 分配内存大小
[*]--cdrom 使用哪个光盘镜像
[*]-disk path=。。。 使用刚才创建的row硬盘, 如果是--disk,那么就是这样写 --disk /opt/CentOs-7-x86.64.qcow2,format=qcow2
[*]-network network=default 使用默认的网络
[*]  --graphics vnc,listen=0.0.0.0 使用vnc,默认第一台虚拟机监听在5601,第二台监听在5602,依此类推。
  

# virt-install --virt-type kvm --name CentOs-7-x86_64 --ram 1024 --cdrom=/root/CentOS-7.0-1406-x86_64-DVD.iso--disk path=opt/CentOs-7-x86.64.raw --networknetwork=default --graphics vnc,listen=0.0.0.0 --noautoconsole  

  此时,我们回车下去后,就开始创建虚拟机了,我们用vnc进行连接192.168.56.11就可以了,如果有开启了两台虚拟机,那么vnc客户端输入IP回车后,默认是进入第一个创建的虚拟机图形界面,要想进入第二台虚拟机图形界面,那么就输入IP:1进入第二个创建好的虚拟机,依次类推。 进入图形界面下安装系统就不再赘述。

  如果像我一样出现这样的报错:
  

# virt-install --virt-type kvm --name CentOs-7-x86.64--ram 1024 --cdrom=/root/CentOS-7-x86_64-Everything-1511.iso   --disk path=/opt/CentOs7-x86.64.raw --networknetwork=default --graphics vnc,listen=0.0.0.0 --noautoconsole  

  
开始安装......
  
ERROR    internal error: process exited while connecting to monitor: 2017-01-27T06:41:52.514390Z qemu-kvm: -drive file=/root/CentOS-7-x86_64-Everything-1511.iso,format=raw,if=none,id=drive-ide0-0-0,readonly=on: could not open disk image /root/CentOS-7-x86_64-Everything-1511.iso: Could not open '/root/CentOS-7-x86_64-Everything-1511.iso': Permission denied   # 权限被拒绝
  
域安装好像没有成功。
  
如果是这样,可以运行下列命令重启您的域:
  virsh --connect qemu:///system start CentOs-7-x86.64
  
否则,请重新开始安装。
  

  

  
# systemctl status libvirtd
  
........
  
1月 27 14:46:48 linux-node1.example.com libvirtd: 无法连接到监控程序插槽: 没有那个进程
  
1月 27 14:46:48 linux-node1.example.com libvirtd: internal error: process exited while connecting to monitor: 2017-01-...
  

  那么就这样处理,把用户和组设置为root,还有动态属主:
  

# grep ^ /etc/libvirt/qemu.conf  
user = "root"
  
group = "root"
  
dynamic_ownership = 0
  

  
# ll /root/
  
总用量 12111876
  
-rw-------. 1 root root       1062 1月27 09:20 anaconda-ks.cfg
  
-rwxrwxrwx1 qemu qemu 4632608768 1月27 10:22 CentOS-6.6-x86_64-bin-DVD1.iso
  
-rwxrwxrwx1 qemu qemu 7769948160 1月27 11:59 CentOS-7-x86_64-Everything-1511.iso    # 为保险起见,同时赋予777的权限
  

  此时再次敲下刚才创建虚拟机的命令,就发现没有任何问题了。。。
  安装完成后,我们可以使用下面这个命令来查看虚拟机的状态:
  

# virsh list --all  Id    Name                           State
  
----------------------------------------------------
  -   CentOs-7-x86_64                shut off
  

  

  virsh是用来控制虚拟机的命令,下面可以使用这个命令来启动虚拟机
  

# virsh start CentOs-7-x86_64  
Domain CentOs-7-x86_64 started
  

  下面说说虚拟机的IP,我们查看下宿主机的网卡virbr0,这个virbr0是虚拟机通过它来连接外网的,且虚拟机和这个virbr0是处在同一个网段内。
  

# ifconfig  
....
  
virbr0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>mtu 1500
  inet 192.168.122.1netmask 255.255.255.0broadcast 192.168.122.255    #
  ether 52:54:00:ba:bd:e7txqueuelen 1000(Ethernet)
  RX packets 0bytes 0 (0.0 B)
  RX errors 0dropped 0overruns 0frame 0
  TX packets 0bytes 0 (0.0 B)
  TX errors 0dropped 0 overruns 0carrier 0collisions 0
  

  
vnet0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>mtu 1500
  inet6 fe80::fc54:ff:fefb:5cb5prefixlen 64scopeid 0x20<link>
  ether fe:54:00:fb:5c:b5txqueuelen 1000(Ethernet)
  RX packets 0bytes 0 (0.0 B)
  RX errors 0dropped 0overruns 0frame 0
  TX packets 31bytes 1844 (1.8 KiB)
  TX errors 0dropped 0 overruns 0carrier 0collisions 0
  

  

  我们进入到虚拟机界面下,使用ip a|grep 'inet '就可以看到虚拟机和virbr0处在同一网段。

关于libvirt
  说道virsh这个命令,其实是由libvirt-client安装的。
  
libvirt是一个用户空间的管理工具,可以管理Xen,kvm,VMware等等虚拟化软件。
  
它们之间的关系如下图下所示:
  

  
需要注意的是,我们把libvirtd停止后,虚拟机也还是正常运行的,只是无法查看虚拟机的状态。

虚拟机的配置文件与修改虚拟机的配置
  每一个虚拟机都有一个配置文件,那么下面就说说如何修改虚拟机配置
  

# pwd  
/etc/libvirt/qemu
  
# ll -rt
  
total 4
  
drwx------. 3 root root   40 Dec 17 03:21 networks
  
-rw-------1 root root 3840 Dec 17 04:06 CentOs-7-x86_64.xml    #每个虚拟机配置都是以虚拟机名字命名
  

  如果我们需要修改虚拟机配置,那么使用下面的命令
  

# virsh edit CentOs-7-x86_64    # CentOs-7-x86_64为名字  

  在宿主机是CentOs7和虚拟机也是CentOs7的情况下,虚拟机是可以热添加CPU的,所谓热添加就是说能够在虚拟机开机运行状态下添加CPU,下面说说如何添加:
  

# virsh edit CentOs-7-x86_64    # 打开配置文件  <vcpu placement='static'>1</vcpu>    # 找到这行,把这行改成下面一行
  <vcpu placement='auto' current='1'>4</vcpu>    # 改成这行,current表示当前是1颗cpu核心,4表示需要4颗cpu,不是CPU核心
  

  保存后退出,然后启用刚才添加的CPU
  

# virsh setvcpus CentOs-7-x86_64 2 --live    #2表示2颗CPU  

  

  在Openstack下生成的虚拟机,每一个虚拟机对应的XML格式配置文件是不允许手动改的,只能通过代码改动。

d动态修改内存的信息
  

# virsh qemu-monitor-command CentOs-7-x86_64 --hmp --cmd info balloon   # 查看内存信息  
balloon: actual=1024   
  
# virsh qemu-monitor-command CentOs-7-x86_64 --hmp --cmd   balloon 512      # 修改内存的大小
  

  
# virsh qemu-monitor-command CentOs-7-x86_64 --hmp --cmd info balloon      # 修改后内存的信息。
  
balloon: actual=512
  

  如果要修改大于XML(这一行<memory unit='KiB'>1048576</memory>)配置的内存,那么通过virsh qemu-monitor-command命令修改完以后需要重启虚拟机

KVM-虚拟机的网络桥接
  我们把虚拟机的网络桥接到宿主机上的网段,这样就可以通过xshell连接虚拟机了。首先要做的就是添加一个br0接口,然后在把br0接口桥接到eth0上。步骤如下
  

# brctl show
  
bridge name bridge>  
virbr0      8000.525400babde7   yes   virbr0-nic
  vnet0
  
# brctl addbr br0
  
# brctl show

  
bridge name bridge>  
br0   8000.000000000000   no
  
virbr0      8000.525400babde7   yes   virbr0-nic
  vnet0
  
# brctl addif br0 eth0    # 执行到这一步的时候xshell网络会断掉的。
  

  
# brctl show# 可以查看下当前的连接
  
#ip addr del dev eth0 192.168.56.11/24#在vmware 下面使用console继续操作。删除eth0的ip,让这个IP放在br0上使用
  
# ifconfig br0 192.168.56.11/24   # 在br0添加这个IP
  
# route add default gw 192.168.56.2# 添加网关,这回xshell可以连接上linux-node1了
  

  接下来我们继续修改虚拟机的配置文件,更改其网络类型。
  

# virsh edit CentOs-7-x86_64  <interface type='network'>
  <source network='default'/>
  #找到上面2行,修改成下面2行
  <interface type='bridge'>
  <source bridge='br0'/>   # 注意这里的source 后面接的是bridge
  

  修改完成后确认无误,重启虚拟机
  

# virsh shutdown CentOs-7-x86_64  
# virsh start CentOs-7-x86_64
  

  然后我们查看虚拟机的IP,就可以看到是56.0的网段了。我们手动修改IP为192.168.56.111。
页: [1]
查看完整版本: 2 云计算系列之KVM的安装与使用