RedHat7搭建KVM虚拟机

1. 宿主机安装RedHat7.3系统

1.1选择语言

中文、简体中文(中国)

1.2安装位置

1.2.1自定义分区,选择LVM,将分区空间全部分配给根

1.2.2禁用Kdump

2.安装KVM

2.1安装前准备

2.1.1配置yum源

2.1.2防火墙处理

setenforce 0

sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/sysconfig/selinux

systemctl disable firewalld

systemctl stop firewalld

2.2安装GNOME桌面环境

yum -y groupinstall "X Window System"

yum install gnome-classic-session gnome-terminal nautilus-open-terminal control-center liberation-mono-fonts –y

2.2.1设置默认以桌面启动

将/etc/inittab中的

#graphical.target: analogous to runlevel 5

修改为

graphical.target: analogous to runlevel 5

systemctl set-default graphical.target

2.3安装vncserver

2.3.2安装vncserver

yum -y install vnc *vnc-server*

2.3.3设置密码

[root@KVM2 ~]# vncserver

You will require a password to access your desktops.

Password:*****   ###输入密码

Verify:*****      ###确认密码

2.3.4启动服务

vncserver :1

2.3.5停止服务

vncserver –kill :1

2.4安装KVM

2.4.1查看主机是否支持VT

cat /proc/cpuinfo |grep vmx  #intel cpu
cat /proc/cpuinfo |grep svm  # amd cpu

#如果flags: 里有vmx 或者svm就说明支持VT;如果没有任何的输出,说明你的cpu不支持,将无法使用KVM虚拟机

2.4.2确保BIOS里开启VT:  Intel(R) Virtualization Tech [Enabled]  使用如下命令

[root@KVM2 ~]# lsmod | grep kvm

kvm_intel             170181  0

kvm                   554609  1 kvm_intel

irqbypass              13503  1 kvm

2.4.3桥接网络

安装bridge-utils ,用来管理网桥的工具brctl

yum -y install bridge-utils

2.4.4安装qemu-kvm libvirt virt-install virt-manager

yum -y install qemu-kvm libvirt virt-install virt-manager openssh-askpass

2.4.5配置修改

/etc/libvirt/qemu.conf

dynamic_ownership=1

#user = "root"

#group = "root"

修改为

dynamic_ownership=0

user = "root"

group = "root"

2.4.6重启服务设置开机自启动

systemctl restart libvirtd

systemctl enable libvirtd

2.4.7修改网络配置文件

nmcli c add type bridge autoconnect yes con-name br0 ifname br0

cd /etc/sysconfig/network-scripts/

[root@KVM2 network-scripts]# cat ifcfg-br0

DEVICE=br0

STP=yes

BRIDGING_OPTS=priority=32768

TYPE=Bridge

BOOTPROTO=none

DEFROUTE=yes

PEERDNS=yes

PEERROUTES=yes

NAME=br0

ONBOOT=yes

IPADDR=192.161.14.247

NETMASK=255.255.255.0

GATEWAY=192.161.14.1

[root@KVM2 network-scripts]# cat ifcfg-ens192

TYPE=Ethernet

BOOTPROTO=none

BRIDGE=br0

DEFROUTE=yes

PEERDNS=yes

PEERROUTES=yes

NAME=ens192

UUID=89e79501-94d5-4e32-a215-dad967527107

DEVICE=ens192

ONBOOT=yes

重启网络systemctl restart network

查看网络

[root@KVM2 network-scripts]# ip addr

1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN qlen 1

link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00

inet 127.0.0.1/8 scope host lo

valid_lft forever preferred_lft forever

inet6 ::1/128 scope host

valid_lft forever preferred_lft forever

2: ens192: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast master br0 state UP qlen 1000

link/ether 00:50:56:83:03:6a brd ff:ff:ff:ff:ff:ff

3: virbr0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN qlen 1000

link/ether 52:54:00:26:16:70 brd ff:ff:ff:ff:ff:ff

inet 192.168.122.1/24 brd 192.168.122.255 scope global virbr0

valid_lft forever preferred_lft forever

4: virbr0-nic: <BROADCAST,MULTICAST> mtu 1500 qdisc pfifo_fast master virbr0 state DOWN qlen 1000

link/ether 52:54:00:26:16:70 brd ff:ff:ff:ff:ff:ff

7: br0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP qlen 1000

link/ether 00:50:56:83:03:6a brd ff:ff:ff:ff:ff:ff

inet 192.161.14.247/24 brd 192.161.14.255 scope global br0

valid_lft forever preferred_lft forever

inet6 fd3c:dfbd:20c3:d000:250:56ff:fe83:36a/64 scope global mngtmpaddr dynamic

valid_lft 7094sec preferred_lft 3494sec

inet6 fe80::250:56ff:fe83:36a/64 scope link

valid_lft forever preferred_lft forever

2.5各宿主机实现双机互信

a)

ssh-keygen -t rsa

#生产公钥、私钥

b)同步各宿主机/root/.ssh/authorized_keys配置文件

2.6配置vlan

2.6.1设置开机启动加载8021q模块

echo ‘/usr/sbin/modprobe 8021q’ >> /etc/rc.local

chmod +x /etc/rc.local

2.6.2上传vconfig-1.9-8.1.el6.x86_64.rpm用于创建vlan

rpm -ivh vonfig-1.9-8.1.el6.x86_64.rpm

2.6.3创建vlan140

a)

[root@KVM1 network-scripts]# vconfig add eno1 140

Added VLAN with VID == 140 to IF -:eno1:

命令格式如下:

vconfig add 物理网卡名 vlanid

b)

[root@KVM1 network-scripts]# ip addr

1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN

link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00

inet 127.0.0.1/8 scope host lo

valid_lft forever preferred_lft forever

inet6 ::1/128 scope host

valid_lft forever preferred_lft forever

2: eno1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq master br0 state UP qlen 1000

link/ether 30:e1:71:55:a8:f4 brd ff:ff:ff:ff:ff:ff

inet6 fe80::32e1:71ff:fe55:a8f4/64 scope link

valid_lft forever preferred_lft forever

3: eno2: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc mq state DOWN qlen 1000

link/ether 30:e1:71:55:a8:f5 brd ff:ff:ff:ff:ff:ff

4: eno3: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc mq state DOWN qlen 1000

link/ether 30:e1:71:55:a8:f6 brd ff:ff:ff:ff:ff:ff

5: eno4: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc mq state DOWN qlen 1000

link/ether 30:e1:71:55:a8:f7 brd ff:ff:ff:ff:ff:ff

45: eno1.140@eno1: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN

link/ether 30:e1:71:55:a8:f4 brd ff:ff:ff:ff:ff:ff

#多了一个eno1.140的虚拟网卡

c)创建相应虚拟网卡配置文件和桥接配置文件

d)重启网卡

[root@KVM1 network-scripts]# service network restart

Restarting network (via systemctl):  [  OK  ]

e)查看网桥绑定情况

[root@KVM1 network-scripts]# brctl show

bridge name     bridge id               STP enabled     interfaces

br0             8000.30e17155a8f4       yes             eno1

br140           8000.30e17155a8f4       yes             eno1.140

br20            8000.30e17155a8f4       yes             eno1.20

vnet1

virbr0          8000.5254009c7586       yes             virbr0-nic

#网桥绑定成功

f)查看网桥是否运行正常

[root@KVM1 network-scripts]# ip addr

1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN

link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00

inet 127.0.0.1/8 scope host lo

valid_lft forever preferred_lft forever

inet6 ::1/128 scope host

valid_lft forever preferred_lft forever

2: eno1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq master br0 state UP qlen 1000

link/ether 30:e1:71:55:a8:f4 brd ff:ff:ff:ff:ff:ff

inet6 fe80::32e1:71ff:fe55:a8f4/64 scope link

valid_lft forever preferred_lft forever

3: eno2: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc mq state DOWN qlen 1000

link/ether 30:e1:71:55:a8:f5 brd ff:ff:ff:ff:ff:ff

4: eno3: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc mq state DOWN qlen 1000

link/ether 30:e1:71:55:a8:f6 brd ff:ff:ff:ff:ff:ff

5: eno4: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc mq state DOWN qlen 1000

link/ether 30:e1:71:55:a8:f7 brd ff:ff:ff:ff:ff:ff

8: br20: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP

link/ether 30:e1:71:55:a8:f4 brd ff:ff:ff:ff:ff:ff

inet 172.16.4.100/24 brd 172.16.4.255 scope global br20

valid_lft forever preferred_lft forever

inet6 fe80::32e1:71ff:fe55:a8f4/64 scope link

valid_lft forever preferred_lft forever

9: virbr0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN

link/ether 52:54:00:9c:75:86 brd ff:ff:ff:ff:ff:ff

inet 192.168.122.1/24 brd 192.168.122.255 scope global virbr0

valid_lft forever preferred_lft forever

10: virbr0-nic: <BROADCAST,MULTICAST> mtu 1500 qdisc pfifo_fast master virbr0 state DOWN qlen 500

link/ether 52:54:00:9c:75:86 brd ff:ff:ff:ff:ff:ff

40: vnet1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast master br20 state UNKNOWN qlen 500

link/ether fe:54:00:f3:1a:6a brd ff:ff:ff:ff:ff:ff

inet6 fe80::fc54:ff:fef3:1a6a/64 scope link

valid_lft forever preferred_lft forever

45: eno1.140@eno1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br140 state UP

link/ether 30:e1:71:55:a8:f4 brd ff:ff:ff:ff:ff:ff

inet6 fe80::32e1:71ff:fe55:a8f4/64 scope link

valid_lft forever preferred_lft forever

46: br0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP

link/ether 30:e1:71:55:a8:f4 brd ff:ff:ff:ff:ff:ff

inet 192.161.14.247/24 brd 192.161.14.255 scope global br0

valid_lft forever preferred_lft forever

inet6 fd3c:dfbd:20c3:d000:32e1:71ff:fe55:a8f4/64 scope global mngtmpaddr dynamic

valid_lft 7004sec preferred_lft 3404sec

inet6 fd51:8056:6705:0:32e1:71ff:fe55:a8f4/64 scope global mngtmpaddr dynamic

valid_lft 7200sec preferred_lft 1800sec

inet6 fd51:8056:6705:4:32e1:71ff:fe55:a8f4/64 scope global mngtmpaddr dynamic

valid_lft 7200sec preferred_lft 1800sec

inet6 fe80::32e1:71ff:fe55:a8f4/64 scope link

valid_lft forever preferred_lft forever

47: br140: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP

link/ether 30:e1:71:55:a8:f4 brd ff:ff:ff:ff:ff:ff

inet 172.16.4.40/24 brd 172.16.4.255 scope global br140

valid_lft forever preferred_lft forever

inet6 fe80::32e1:71ff:fe55:a8f4/64 scope link

valid_lft forever preferred_lft forever

48: eno1.20@eno1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master br20 state UP

link/ether 30:e1:71:55:a8:f4 brd ff:ff:ff:ff:ff:ff

inet6 fe80::32e1:71ff:fe55:a8f4/64 scope link

valid_lft forever preferred_lft forever

#运行正常

3.虚机迁移

virsh migrate --live rhel7.3  qemu+ssh://192.161.14.250/system

3.1查看虚拟机磁盘格式

[root@KVM1 images]# qemu-img info redhat7.3

image: redhat7.3

file format: qcow2

virtual size: 60G (64424509440 bytes)

disk size: 1.3G

cluster_size: 65536

Format specific information:

compat: 1.1

lazy refcounts: true

3.2克隆模板的磁盘文件

[root@KVM1 images]# qemu-img create -f qcow2 -b redhat7.3 KVM2-VM1

###克隆格式为qcow2

Formatting 'KVM2-VM1', fmt=qcow2 size=64424509440 backing_file='redhat7.3' encryption=off cluster_size=65536 lazy_refcounts=off

3.3克隆模板的配置文件

virsh dumpxml rhel7.3 > /etc/libvirt/qemu/KVM2-VM1.xml

###其中rhel7.3为模板文件的名字,KVM2-VM1为要生成模板文件名字,注意跟前面的磁盘文件名保持一致

3.4删除网卡的MAC、模板虚拟机的UUID

<mac address='52:54:00:f3:1a:6a'/>

<uuid>18f4b3eb-4d0f-4cac-bc3f-e3798fa4746c</uuid>

3.5修改磁盘名称

<source file='/var/lib/libvirt/images/redhat7.3'/>

3.6修改虚拟机name

<name>rhel7.3</name>

3.7重新定义一个虚拟机

[root@KVM1 qemu]# virsh  define /etc/libvirt/qemu/KVM2-VM1.xml

Domain KVM2-VM1 defined from /etc/libvirt/qemu/KVM2-VM1.xml

3.8迁移报错

Error starting domain: internal error: process exited while connecting to monitor: 2017-08-29T05:09:58.146446Z qemu-kvm: -chardev socket,id=charchannel0,path=/var/lib/libvirt/qemu/channel/target/domain-rhel7.3/org.qemu.guest_agent.0,server,nowait: Failed to bind socket: No such file or directory

2017-08-29T05:09:58.146488Z qemu-kvm: -chardev socket,id=charchannel0,path=/var/lib/libvirt/qemu/channel/target/domain-rhel7.3/org.qemu.guest_agent.0,server,nowait: chardev: opening backend "socket" failed

创建该目录/var/lib/libvirt/qemu/channel/target/下相应目录问题就可解决

3.9虚拟克隆到迁移步骤

3.9.1利用virt-mangaer克隆

a)

#选择要克隆的主机(该主机必须是关闭或Pause状态)

b)

#设置要克隆的虚机名称,Storage,选择Details(这里不要选择默认的,否则会导致主机名跟磁盘名不一致,不便于管理)

c)

#设置虚机机磁盘位置、名称,这里要求跟虚拟机名字一致

d)

#选择克隆即可

e)

#克隆完毕之后,即可看到虚拟机列表

3.9.2virt-clone命令克隆

a)克隆命令格式

virt-clone -o 源虚机名 -n 目标虚机名 -f /var/lib/libvirt/images/目标虚拟机名

b)列出宿主机所有虚拟机

[root@KVM1 qemu]# virsh list --all

Id    Name                           State

----------------------------------------------------

16    rhel7.3                        paused

-     KVM2-VM1                       shut off

-     KVM2-VM2                       shut off

-     KVM2-VM3                       shut off

-     KVM2-VM5                       shut off

-     KVM2-VM6                       shut off

-     KVM2-VM7                       shut off

c)克隆虚机KVM2-VM8

[root@KVM1 qemu]# virt-clone -o rhel7.3 -n KVM2-VM8 -f /var/lib/libvirt/images/KVM2-Vm8

WARNING  Setting the graphics device port to autoport, in order to avoid conflicting.

Allocating 'KVM2-Vm8'                                                                                                                                 |  60 GB  00:00:02

Clone 'KVM2-VM8' created successfully.

d)检查是否创建成功

[root@KVM1 target]# virsh list --all

Id    Name                           State

----------------------------------------------------

16    rhel7.3                        paused

-     KVM2-VM1                       shut off

-     KVM2-VM2                       shut off

-     KVM2-VM3                       shut off

-     KVM2-VM5                       shut off

-     KVM2-VM6                       shut off

-     KVM2-VM7                       shut off

-     KVM2-VM8                       shut off

3.9.3虚拟机静态迁移

a)将虚拟机KVM2-VM8迁移到宿主机KVM2上

b)迁移配置文件

[root@KVM1 target]# scp /etc/libvirt/qemu/KVM2-VM8.xml root@KVM2:/etc/libvirt/qemu/

KVM2-VM8.xml

c)迁移镜像文件

[root@KVM1 target]# scp /var/lib/libvirt/images/KVM2-VM  root@KVM2:/var/lib/libvirt/images/

d)激活配置文件

[root@KVM2 target]# virsh define /etc/libvirt/qemu/KVM2-VM8.xml

e)查看宿主机虚机情况

[root@KVM2 target]# virsh list --all

Id    Name                           State

----------------------------------------------------

-     KVM2-VM1                       shut off

-     KVM2-VM2                       shut off

-     KVM2-VM3                       shut off

-     KVM2-VM5                       shut off

-     KVM2-VM6                       shut off

-     KVM2-VM8                       shut off

#迁移成功

参考

http://www.linuxidc.com/Linux/2015-12/126690.htm ###安装桌面

http://www.linuxidc.com/Linux/2016-07/132835.htm ###vnc安装

http://blog.csdn.net/skykingf/article/details/51944455 ###安装kvm1

http://www.cnblogs.com/lvxiaobo616/p/5704646.html ###安装kvm2

http://blog.csdn.net/qq_19646075/article/details/51780530 ###虚机迁移1

http://www.cnblogs.com/sammyliu/p/4572287.html  ###虚机迁移2

备注

如在虚拟机中测试,网卡一定选择成混杂模式,否则,在虚机获取桥接网络时,会获取不到

RedHat7搭建KVM虚拟机的更多相关文章

  1. ubuntu18.04上搭建KVM虚拟机环境超完整过程

    看标题这是篇纯运维的文章.在中小型企业中,一般很少配置专业的运维人员,都是由开发人员兼着.同时,对有志于技术管理的开发人员来说,多了解一些运维及整个软件生命周期的知识,是很有帮助的,因为带团队不仅仅是 ...

  2. Centos7下搭建KVM虚拟机

    PRE-INSTALL ============================================================= kvm相关安装包及其作用 qemu-kvm 主要的K ...

  3. Centos7利用kvm搭建Windows虚拟机

    这几天玩了一下kvm虚拟化,真的很有意思,我把这几天踩的坑,还有收获,都记录下来,作为以后的复习和检查. 首先说一下我的基本逻辑,我有一台win7的笔记本,我的底层虚拟化是使用VMWare构建的Cen ...

  4. CENTOS6.4上KVM虚拟机环境搭建

    CENTOS6.4上KVM虚拟机环境搭建   关键词: KVM,虚拟机,windows7, VNC, 桥接网络,br0, SCSI, IDE   环境: host: CENTOS6.4 guest: ...

  5. 搭建KVM环境——06 创建虚拟机

    若转载请于明显处标明出处:https://www.cnblogs.com/kelamoyujuzhen/p/9071181.html 虚拟机磁盘格式 创建一个raw格式的虚拟机磁盘 [root@Cen ...

  6. linux kvm虚拟机使用

    安装配置kvm 1.安装kvm软件包 [root@kvm ~]# yum install kvm python-virtinst libvirt tunctl bridge-utils virt-ma ...

  7. CentOS 7.5 安装KVM虚拟机(Windows)

    一.KVM环境搭建1.检测系统是否支持cat /proc/cpuinfo | egrep 'vmx|svm' KVM是基于x86虚拟化扩展(Intel VT 或者 AMD-V)技术的虚拟机软件,所以查 ...

  8. CentOS 6.9下KVM虚拟机网络Bridge(网桥)方式与NAT方式详解(转)

    摘要:KVM虚拟机网络配置的两种方式:NAT方式和Bridge方式.Bridge方式的配置原理和步骤.Bridge方式适用于服务器主机的虚拟化.NAT方式适用于桌面主机的虚拟化. NAT的网络结构图: ...

  9. kvm虚拟化学习笔记(四)之kvm虚拟机日常管理与配置

    KVM虚拟化学习笔记系列文章列表----------------------------------------kvm虚拟化学习笔记(一)之kvm虚拟化环境安装http://koumm.blog.51 ...

随机推荐

  1. Oculus Rift, HTC Vive, SONY PSVR的全面对比

    http://blog.csdn.net/xoyojank/article/details/50927572 这次有幸参加了GDC 2016, 终于把三大设备体验了个遍, 也试玩了很多不错的VR游戏. ...

  2. 集中化管理平台 — Ansible 详解

    # Ansible 简介 Ansible 类似于Saltstack,是一种集成IT系统的配置管理.应用部署.执行特定任务的开源平台.Ansible基于Python语言实现,由Paramiko和PyYA ...

  3. Spring Cloud:使用Ribbon实现负载均衡详解(下)

    在上一篇文章(Spring Cloud:使用Ribbon实现负载均衡详解(上))中,我对 Ribbon 做了一个介绍,Ribbon 可以实现直接通过服务名称对服务进行访问.这一篇文章我详细分析一下如何 ...

  4. 怎么解决UIScrollView把uitableviewcell的点击事件屏蔽了

    [self.contentView addSubview:self.scrollView]; self.scrollView.userInteractionEnabled = NO; [self.co ...

  5. Ubuntu终端查看系统时间,以及日历

    时间:  date 日历: cal https://blog.csdn.net/zhengchaooo/article/details/79500032 修改时区以及时间 查看时区 date -R 修 ...

  6. bzoj2740 串 && bzoj2176 strange string(最小表示法模板)

    https://konnyakuxzy.github.io/BZPRO/JudgeOnline/2740.html 题解讲的很清楚了 (好像等于的情况应该归入case2而不是case1?并不确定) 具 ...

  7. csu 1552: Friends 二分图 + Miller_Rabin

    http://acm.csu.edu.cn/csuoj/problemset/problem?pid=1552 把那n个数写两次,分成相同的两堆,判断相加是质数的,连一条边,然后找最大匹配,ans = ...

  8. Spring Boot启动过程源码分析--转

    https://blog.csdn.net/dm_vincent/article/details/76735888 关于Spring Boot,已经有很多介绍其如何使用的文章了,本文从源代码(基于Sp ...

  9. 响应式Spring Cloud初探

    响应式Spring Cloud初探 分类:工程原文链接:The Road to Reactive Spring Cloud作者:  JOSH LONG译者: helloworldtang日期:JUNE ...

  10. MVC 下载相关

    前台: location.href = "/Flow/SB1SP?clxxid=8099b23c-aa5a-44a3-97ef-85eed78145ba"; 后台: publci ...