在机器上装了一个Centos6.2用来测试KVM,对比Windows下的VMware worstation,KVM功能强大,定制性高,只要入了门,绝对是功能强大。用来作云计算不错。不过就是操作性差了点。没有vmware workstation方便,毕竟,workstation是个人用的,可能不适合企业吧,没接触过vsphere。

kvm的安装比较简单,如果安装Centos的时候没有安装,那么,就需要使用groupinstall了

KVM的主要软件组有如下几个

1。 Virtualization 提供虚拟机的环境,主要包含qumu-kvm

2。 Virtualization Client 管理和安装虚拟机实例的客户端,主要有python-virtinst,virt-manager,virt-viewer

3。 Virtualization Platform 提供访问和控制虚拟客户端的接口,主要有libvirt,libvirt-client

4。 Virtualization Tools 管理离线虚拟机镜像的工具,主要有libguestfs

根据需求选择软件包,一般都安装1,2,3

yum groupinstall "Virtualization" "Virtualization Client" "Virtualization Platform"

安装完组件后,就需要创建虚拟机了

一般在创建虚拟机前,如果需要桥接虚拟机,就需要创建桥接网口,具体看自己的需求

创建一个虚拟机,可以通过virt-manager来完成,图形化界面,但是这个功能不全,不能随心所欲,例如,需要将虚拟机创建在不同的位置上,毕竟,默认的存储是在/var/lib/libvirt/images下,无法进行存储的管理

所以,在创建虚拟机之前,需要先创建一个存储池

存储池(Storage pools)是放置虚拟机的存储位置,可以是本地的,也可以是网络存储,具体的虚拟机实例放置在卷(Volume)上。

操作存储卷的命令行是virsh

主要有以下操作

查看卷的信息

[root@centos6 ~]# virsh vol-info --pool kvm_images guest1-rhel6.1
名称:       guest1-rhel6.1
类型:       文件
容量:       16.00 GB
分配:       1.97 GB

或者直接使用存储卷的绝对路径

virsh vol-info /kvm/images/guest1-rhel6.1

在创建卷之前,先要创建存储池,存储池可以建立在好几种方式的存储上,现在主要建立一个基于目录的存储池。

首先创建了一个LVM,并将这个LVM挂载到一个目录下,例如/kvm

然后开始创建存储池

1。 建立存储池的目录

mkdir /kvm/images

2。 为了安全性,更改目录的所有者,并设置权限

chown root:root /kvm/images

chmod 700 /kvm/images

验证一下

ls -a /kvm/images

3。 配置SELinux文件上下文

semanage fcontext -a -t virt_image_t /kvm/images

这个主要是打开SELinux设定,不然虚拟机无法访问存储文件

如果没有semanage,那么安装policycoreutils-python

yum install policycoreutils-python

4。创建基于文件夹的存储池

1) 定义一个存储池

virsh pool-define-as kvm_images dir - - - - "/kvm/images"

2) 查看创建的存储池信息

virsh pool-list --all

3) 建立基于文件夹的存储池

virsh pool-build kvm_images

4) 使存储池生效

virsh pool-start kvm_images

5) 这时候,存储池还不是自动运行,使用virsh pool-autostart

virsh pool-autostart kvm_images

6) 验证存储池

[root@centos6 ~]# virsh pool-info kvm_images
名称:       kvm_images
UUID:           89a6434f-2106-4a98-d34c-d6b32bef6a0c
状态:       running
Persistent:     yes
自动启动: yes
容量:       170.84 GB
分配:       187.38 MB
可用:       170.66 GB

创建了存储池后,就可以创建一个卷,这个卷是用来做虚拟机的硬盘

1。创建卷

virsh vol-create-as kvm_images guest2-rhel6.1.img 8G --format qcow2

2。查看存储池里面的卷信息

virsh vol-list kvm_images

名称               路径                                 
-----------------------------------------
guest1-rhel6.1       /kvm/images/guest1-rhel6.1             
guest2-rhel6.1.img   /kvm/images/guest2-rhel6.1.img

3。查看某个卷的信息

virsh vol-info guest2-rhel6.1.img kvm_images

名称:       guest2-rhel6.1.img
类型:       文件
容量:       8.00 GB
分配:       136.00 K

更详细的

virsh vol-dumpxml guest2-rhel6.1.img kvm_images

<volume>
  <name>guest2-rhel6.1.img</name>
  <key>/kvm/images/guest2-rhel6.1.img</key>
  <source>
  </source>
  <capacity>8589934592</capacity>
  <allocation>139264</allocation>
  <target>
    <path>/kvm/images/guest2-rhel6.1.img</path>
    <format type='qcow2'/>
    <permissions>
      <mode>0600</mode>
      <owner>0</owner>
      <group>0</group>
      <label>system_u:object_r:file_t:s0</label>
    </permissions>
  </target>
</volume>

可以从xml配置文件看出,这个卷是qcow2类型的

4。现在开始创建虚拟机,使用virt-install来创建

创建的虚拟机名字为guest2-rhel6.1 这个名字很重要,就是在KVM中的域名,可以做各种操作

cpu使用1个,内存化为512M,硬盘文件使用新创建的硬盘文件,格式为qcow2,大小为8G,使用ISO镜像安装,安装的操作系统类型为linux,类别为rhel6。网络挂载桥接网卡br0

virt-install --connect qemu:///system -n guest2-rhel6.1 -r 512 -f /kvm/images/guest2-rhel6.1.img -s 8 --vnc --os-type=linux --os-variant=rhel6  --vcpus=1 --network bridge=br0 -c /mnt/rhel-server-6.1-x86_64-dvd.iso

回车后,控制台显示

开始安装......
创建域......                                          |    0 B     00:00

会弹出一个窗口,如果定义了自动安装,那么,可以关闭安装窗口

5。启动一个窗口监测安装进程

virt-viewer guest2-rhel6.1来查看安装进程

有时候会碰到虚拟机无法正常安装,这时候如果没有启动acpid进程的话,那么使用virsh shutdown guest2-rhel6.1无法关闭虚拟机,这时候就需要使用命令 destroy guest2-rhel6.1来强制关闭了。

6。安装完毕后,要记的在虚拟机上安装acpid进程,以方便远程关闭机器

yum install acpid -y

chkconfig acpid on 345

service acpid start

7。 等做完虚拟机的配置后,就需要对虚拟机做一个快照了。

快照的制作有两种方法,一种是直接在virsh 里面使用snapshot来制作。另外一种是使用qemu-img来创建快照

virsh snapshot-create-as guest2-rhel6.1

快照创建的很快,其实,就是生成了一个XML的配置文件,记录下当前的信息。

查看快照

virsh snapshot-list guest2-rhel6.1

名称               Creation Time             状态
------------------------------------------------------------
 1330937069           2012-03-05 16:44:29 +0800 shutoff

查看快照的配置文件

virsh snapshot-current guest2-rhel6.1

那么,快照文件存在什么地方呢,在/var/lib/libvirt/qemu/snapshot目录下,有以虚拟机的域名为名称的文件夹,就在里面哪

使用qemu-img创建快照也很方便,这个镜像是直接对硬盘文件进行操作,硬盘文件的格式必须为qcow2格式的,记的貌似物理硬盘的格式为LVM才能创建快照,还是格式为LVM,qemu-img的格式不必为qcow2格式就能创建快照,还没整明白

qemu-img snapshot -c 2012-3-5 /kvm/images/guest2-rhel6.1.img

创建完毕后,查看一下

qemu-img snapshot -l /kvm/images/guest2-rhel6.1.img
Snapshot list:
ID        TAG                 VM SIZE                DATE       VM CLOCK
1         1330937069                0 2012-03-05 16:44:29   00:00:00.000
2         2012-3-5                  0 2012-03-05 16:51:39  00:00:00.000

可以看到有两个快照,ID=1为virsh创建的,ID=2为qemu-img创建的,这两个之间有什么关系,还没有想明白。

好了,基本上创建完了,如果能做到PXE启动,然后使用自动部署,那就爽多了。

还有一个问题,就是做完网卡的桥接后,竟然无法上网了,真奇怪啊。

刚才找到原因了,是我将br0的ip设置成与eth0相同的ip地址了,导致冲突无法上网,后来设置成不同的ip地址就ok了

KVM初探之一--存储池与存储卷,使用virt-install创建虚拟机的更多相关文章

  1. 存储池与存储卷,使用virt-install创建虚拟机

    原文链接:https://www.cnblogs.com/zknublx/p/9199658.html 创建存储池 1.建立存储池的目录 mkdir /kvm/images 2.为了安全性,更改目录的 ...

  2. k8s系列---存储卷pv/pvc。configMap/secert

    因为pod是有生命周期的,pod一重启,里面的数据就没了.所以我们需要数据持久化存储. 在k8s中,存储卷不属于容器,而是属于pod.也就是说同一个pod中的容器可以共享一个存储卷. 存储卷可以是宿主 ...

  3. centos7安装kvm环境采用网桥模式并创建虚拟机制作openstack需要的镜像

    初始环境的安装:centos7 mini iso镜像进行安装的系统 采用的环境是vm该软件,联网方式NAT模式下配置的静态ip(如何在NAT模式下配置静态ip参考之前的文章) 1.由于要安装kvm环境 ...

  4. 理解 QEMU/KVM 和 Ceph(3):存储卷挂接和设备名称

    本系列文章会总结 QEMU/KVM 和 Ceph 之间的整合: (1)QEMU-KVM 和 Ceph RBD 的 缓存机制总结 (2)QEMU 的 RBD 块驱动(block driver) (3)存 ...

  5. 让 FreeBSD 和 Gentoo Linux 在 ZFS 存储卷上共存

    自我回归到 Librem 15 已经有段时间了.我一般会选择 FreeBSD 来处理所有的事情,但有时会要访问一个运行在 Librem 平台上的 Linux OS,以便用它来帮助我对一些遗留的设备驱动 ...

  6. 如何在KVM中管理存储池

    来自:http://blog.csdn.net/my2005lb/article/details/8635661 KVM平台以存储池的形式对存储进行统一管理,所谓存储池可以理解为本地目录.通过远端磁盘 ...

  7. k8s存储卷概述

    pod本身具有生命周期,故其内部运行的容器及其相关数据自身均无法持久存在.docker支持配置容器使用存储卷将数据持久存储于容器自身文件系统之外的存储空间中,它们可以是节点文件系统或网络文件系统之上的 ...

  8. kubernetes 存储卷

    kubernetes 存储卷    数据卷用于实现容器持久化数据,Kubernetes对于数据卷重新定义,提供了丰富强大的功能.在Kubernetes系统中,当Pod重建的时候,数据卷会丢失,Kube ...

  9. kubernetes系列12—二个特色的存储卷configmap和secret

    本文收录在容器技术学习系列文章总目录 1.configmap 1.1 认识configmap ConfigMap用于保存配置数据的键值对,可以用来保存单个属性,也可以用来保存配置文件.ConfigMa ...

随机推荐

  1. Fedora下安装deb包方法

    Linux系统提供一个软件alien, 使用它能够把deb包转换成各种格式. 1. 使用yum install alien 2. 安装完成后,执行 alien -r XXXXX.deb, 即可转换成对 ...

  2. activiti实战--第一章--认识Activiti

    学习资料:<Activiti实战> 第一章 认识Activiti 内容概览:讲解activiti的特点.接口概览.架构等基本信息. 1.3 Activiti的特点 1.使用mybatis ...

  3. 【Struts2】如何查看Struts2框架的源码

    学习三大框架时难免遇到不太理解的地方需要去研究框架源码,这里总结一下查看struts2源码的两种方式. 1.直接解压struts2.X.X-all.zip,在的到的解压文件中看到如下目录: 打开图中蓝 ...

  4. 【MAVEN】搜索错误“Index downloads are disabled,search results may be incomplete”

    出现上面这个错误,需要将Maven的索引下载到本地. 应用后,在Window -> Show View -> Other -> Maven -> Maven Repositor ...

  5. SharePoint 2013 Troubleshooting——启用 Developer Dashboard

    SharePoint 2010的管理员和开发者可能对SharePoint Developer Dashboard(开发人员仪表盘)很熟悉.在SharePoint 2013这个工具已经被大范围的改写了, ...

  6. pyspark dataframe 常用操作

    spark dataframe派生于RDD类,但是提供了非常强大的数据操作功能.当然主要对类SQL的支持.   在实际工作中会遇到这样的情况,主要是会进行两个数据集的筛选.合并,重新入库.   首先加 ...

  7. fiddler 抓取iphone发出的http和https包

    1.清理iphone的描述文件,在通用里面设置.这一步目的防止手机里面已经存在了DO_NOT_TRUST_FiddlerRoot证书,导致后面抓不了包,所以先清理下 2.下载安装fiddler,百度或 ...

  8. 修改hadoop FileUtil.java,解决权限检查的问题

        在Hadoop Eclipse开发环境搭建这篇文章中,第15.)中提到权限相关的异常,如下: 15/01/30 10:08:17 WARN util.NativeCodeLoader: Una ...

  9. MySql(十二):MySql架构设计——可扩展设计的基本原则

    一.前言 科技在发展,硬件设备的发展渐渐无法满足应用系统对处理能力的要求.不过,我们还是可以通过改造系统的架构体系,提升系统的扩展能力,通过组合多个低处理能力的硬件设备来达到一个高处理能力的系统,也就 ...

  10. Atitit 找人软福利建设 技术团队建设大概流程

    Atitit 找人软福利建设 技术团队建设大概流程 火车公司有免费车座,餐馆有免费饭吃.. 软件公司嘛,就是软件资源,知识了...技术... 培训体系 大概的知识库体系..让他知道来到我们团队有着很高 ...