系统&服务管理进阶

搭建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

  1. 安装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 +】 退出

 

操作虚拟机

查看虚拟化信息

• 查看KVM节点(服务器)信息

– virsh nodeinfo

• 列出虚拟机

– virsh list [--all]

• 列出虚拟网络

– virsh net-list [--all]

• 查看挃定虚拟机的信息

– virsh dominfo 虚拟机名称

查看虚拟化信息

• 查看KVM节点(服务器)信息

– virsh nodeinfo

• 列出虚拟机

– virsh list [--all]

• 列出虚拟网络

– virsh net-list [--all]

• 查看挃定虚拟机的信息

– virsh dominfo 虚拟机名称

开关机操作

• 运行|重启|关闭挃定的虚拟机

– 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

.. ..

搭建KVM的更多相关文章

  1. Ubuntu 16.04 搭建KVM环境

      在Ubuntu 16.04下搭建KVM环境过程记录. 1 查看CPU是否支持KVM egrep "(svm|vmx)" /proc/cpuinfo 有结果输出,如下图: 2 安 ...

  2. RedHat7搭建KVM虚拟机

    RedHat7搭建KVM虚拟机 1. 宿主机安装RedHat7.3系统 1.1选择语言 中文.简体中文(中国) 1.2安装位置 1.2.1自定义分区,选择LVM,将分区空间全部分配给根 1.2.2禁用 ...

  3. 搭建KVM环境——07 带GUI的Linux上安装KVM图形界面管理工具

    清空yum源缓存,并查看yun源 [root@CentOS2 ~]# yum clean all Loaded plugins: fastestmirror, langpacks Cleaning r ...

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

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

  5. 在ubuntu18.04下搭建kvm

    前一段时间一直在尝试Ubuntu上搭建xen,一直出现各种问题,各种坑 首先先感谢下面这个公司对我的耐心解答,非常感谢.特别是后面来的电话对我进行了详细的解答,所以选择搭建kvm. 1. 需要检查一下 ...

  6. CloudStack搭建KVM环境

    软件环境:agent:CentOS 6.3,minimal安装,CPU启用VT management server:CentOS 6.3,minimal安装 存储:CentOS 6.3 搭建在mana ...

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

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

  8. 基于centos7搭建kvm

    其他的和安装一般的系统没有差别 安装完成后. 1]使用ping www.baidu.com 2]修改静态ip,也可以不修改 3]下载brctlyum -y install bridge-utils 4 ...

  9. 快速搭建 kvm web 管理工具 WebVirtMgr

    作者:SRE运维博客 博客地址: https://www.cnsre.cn/ 文章地址:https://www.cnsre.cn/posts/211117937177/ 相关话题:https://ww ...

随机推荐

  1. php制作缩略图

    PHP制作缩略图 1.制作缩略图的函数 imagecopyresampled(dest,src,dx,dy,sx,sy,dw,dh,sw,sh) 说明: dest 目标画布 src 原图(要缩略的图片 ...

  2. Vue2.0 【第二季】第8节 Component 父子组件关系

    目录 Vue2.0 [第二季]第8节 Component 父子组件关系 第8节 Component 父子组件关系 一.构造器外部写局部注册组件 二.父子组件的嵌套 Vue2.0 [第二季]第8节 Co ...

  3. Java中请优先使用try-with-resources而非try-finally

    Java中请优先使用try-with-resources而非try-finally Java库包含了很多需要手工调用close方法来关闭的资源.比如说InputStream.OutputStream及 ...

  4. 《面试经典系列》- 从底层理解==和equals的区别

    前言 在我们Java面试中,基础知识基本上比定会考核的点,而“==和equals的区别”则是面试官最喜欢.最经常问的问题. 但我们看了不少的文章.解释,总是一头雾水.一知半解的,往往很容忘记.今天,我 ...

  5. SpringMvc @Validated注解执行原理

    @Validated和@Valid对比 Spring Validation验证框架对参数的验证机制提供了@Validated(Spring's JSR-303规范,是标准JSR-303的一个变种),j ...

  6. Bash语句中的循环语句注意事项

    case #!/bin/bash case $1 in 9) echo "nine" ;; 8) echo "eight" ;; 7) echo "s ...

  7. (翻译) 使用Unity进行AOP对象拦截

    Unity 是一款知名的依赖注入容器( dependency injection container) ,其支持通过自定义扩展来扩充功能. 在Unity软件包内 默认包含了一个对象拦截(Interce ...

  8. 记一次phpstudy应急响应

    某日,销售接了一个电话,突然告诉我有个某单位服务器中了木马被黑,具体情况未知.由于客户那边比较急,于是我火速赶往客户现场.到现场,客户首先给我看了深信服防火墙拦截记录,显示内网三台机器被入侵.通过沟通 ...

  9. 信息收集工具-dimtry

    GitHub地址: kali下也是自带的: -s以及-e 参数需要用到Google搜索 1.获取whois主机ip信息 2.扫描端口,根据banner信息判断服务

  10. Cisco二层交换机命令

    1.二层交换机基本配置 Switch >Switch >enable   # 进入特权模式 Switch#configure terminal   # 进入全局配置模式 Switch(co ...