virsh 虚拟机迁移目录_虚拟机迁移的六个步骤

virsh 虚拟机迁移目录_虚拟机迁移的六个步骤简介虚拟机迁移主要分为两种:静态迁移和动态迁移静态迁移是指在虚拟机关闭或暂停的情况下,将源宿主机上虚拟机的磁盘文件和配置文件拷贝到目标宿主机上。这种方式需要显式的停止虚拟机运行,对服务可用性要求高的需求不合适。动态迁移无需拷贝虚拟机配置文件和磁盘文件,但是需要迁移的主机之间有相同的目录结构放置虚拟机磁盘文件,可以通过多种方式实现,本例采用基于共享存储动态迁移,通过NFS来实现。操作环境服

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺


简介

虚拟机迁移主要分为两种:静态迁移和动态迁移

  • 静态迁移是指在虚拟机关闭或暂停的情况下,将源宿主机上虚拟机的磁盘文件和配置文件拷贝到目标宿主机上。这种方式需要显式的停止虚拟机运行,对服务可用性要求高的需求不合适。
  • 动态迁移无需拷贝虚拟机配置文件和磁盘文件,但是需要迁移的主机之间有相同的目录结构放置虚拟机磁盘文件,可以通过多种方式实现,本例采用基于共享存储动态迁移,通过NFS来实现。

操作环境

服务器操作系统:Ubuntu14.04版本。

源宿主机为节点1:主机名xjy-pc,桥接IP为192.168.10.221,NFS挂载目录/home/kvm。

目标宿主机为节点2:主机名为lib,桥接IP为192.168.10.215,NFS挂载目录/home/kvm。

静态迁移测试虚拟机:demo,IP为192.168.10.210,虚拟磁盘文件为ubuntu.raw。

动态迁移测试虚拟机:demo3,IP为192.168.10.210,虚拟磁盘文件为ubuntu.raw。

NFS服务器:操作系统版本:Ubuntu14.04,桥接IP为192.168.10.161,服务目录为/mnt/vg/。


虚拟机的创建以及操作请参考:http://blog.csdn.net/leoe_/article/details/78765688


迁移步骤:

虚拟机静态迁移: 静态迁移也叫做常规迁移、离线迁移(Offline Migration)。是在虚拟机关机或暂停的情况下,拷贝虚拟机磁盘文件与配置文件到目标虚拟主机中,实现的从一台物理机到另一台物理机的迁移。因为虚拟机的文件系统建立在虚拟机镜像文件上面,所以在虚拟机关机的情况下,只需要简单的迁移虚拟机镜像和相应的配置文件到另外一台物理主机上即可。如果需要保存虚拟机迁移之前的状态,那么应该在迁移之前将虚拟机暂停,然后拷贝状态至目的主机,最后在目的主机重建虚拟机状态,恢复执行。这种方式的迁移过程需要显式的停止虚拟机的运行。从用户角度看,有明确的一段停机时间,虚拟机上的服务不可用。这种迁移方式简单易行,适用于对服务可用性要求不严格的场合。


1、首先在节点1上进行操作,首先确定demo虚拟机的状态为关闭

这里写图片描述


2、准备迁移demo虚拟机,使用命令virsh domblklist demo 查看demo虚拟机的磁盘文件

这里写图片描述


3、导出虚拟机配置文件

这里写图片描述


4、拷贝配置文件到目标宿主机上,目标宿主机的IP地址为192.168.10.215

这里写图片描述


5、将虚拟机磁盘文件也拷贝到目标宿主及上,虚拟机demo的磁盘文件为ubuntu.raw

这里写图片描述


6、此时,已经将原宿主机节点1上的demo虚拟机的磁盘文件和配置文件豆腐知道目标宿主机节点2上,下面开始在目标宿主机节点2上进行虚拟机的配置和启动


7、在目标宿主机借点2上操作,首先查看节点2环境,如下图,demo虚拟机的配置文件已经拷贝过来

这里写图片描述


8、查看虚拟机磁盘文件,如下图,ubuntu.raw磁盘文件已经拷贝过来,目录结构与原宿主机一致

这里写图片描述


9、使用virsh的子命令define定义并注册demo虚拟机

这里写图片描述


10、启动迁移后的demo虚拟机,通过virsh console demo 登录到迁移后的虚拟机进行确定

这里写图片描述


动态迁移

1、KVM虚拟机动态迁移无需拷贝虚拟机配置文件和磁盘文件,但是需要迁移的主机之间有相同的目录结构放置虚拟机磁盘文件(本例为“/home/kvm”目录),这里的动态迁移是基于共享存储动态迁移,通过NFS来实现,需要qemu-kvm-0.12.2以上版本支持。


2、在NFS服务器上,下载安装NFS,kernel-server相当于server端,common是client端,使用命令“sudo apt-get install nfs-kernel-server nfs-common portmap”安装NFS。

在节点1和节点2中 使用 sudo apt-get install nfs-common 安装client端


3、配置NFS服务器,IP为192.168.10.161,将NFS服务器上的“/mnt/vg”目录设为服务目录。首先使用命令“sudo mkdir /mnt/vg”创建该目录,然后使用命令“sudo chmod 777 /mnt/vg”修改该目录权限,接下来使用vim修改“/etc/exports”文件添加共享目录,在该文件中添加

/mnt/vg *(rw,sync)

即可。*(rw,sync)是命令参数,表示包括读写权限。


4、“/etc/exports”文件修改后,使用命令“sudo exportfs –r”刷新。然后启动NFS服务,命令如下:

sudo /etc/init.d/rpcbind start
sudo /etc/init.d/nfs-kernel-server restart

5、NFS服务启动后,在节点1上使用命令“showmount –e 192.168.10.161”查看共享目录

这里写图片描述


6、在节点1或节点2上使用命令“scp ubuntu.raw 192.168.10.161:/mnt/vg”,将demo3虚拟机的虚拟磁盘文件ubuntu.raw。拷贝到NFS服务的共享目录

这里需要在nfs服务器允许ssh连接,以及对/mnt/vg 开启读写权限

编辑sshd_config文件,输入:vim /etc/ssh/sshd_config

进行相应设置,替换为如下:

# Authentication:
LoginGraceTime 120
#PermitRootLogin without-password
PermitRootLogin yes
StrictModes yes

接下来,重启ssh服务,输入: /etc/init.d/ssh restart

开启文件权限:

shmod 777 /mnt/vg/

7、在节点1和节点2的“/home/kvm”目录上,分别使用命令“mount -t nfs 192.168.10.161:/mnt/vg /home/kvm -o rw”进行挂载

这里写图片描述


8、挂载完成后两节点都有相同的虚拟机磁盘文件存储目录,下图为节点1挂载后的“/home/kvm”目录结构

这里写图片描述


9、查看节点1上虚拟机状态,demo3虚拟机处于运行状态,(如果demo3未运行将其启动运行)

这里写图片描述


10、查看节点2上虚拟机状态,无虚拟机运行

这里写图片描述


11、在节点1上执行“virsh migrate”迁移命令,从下图可以看出虚拟机demo3在迁移出去的过程中,状态有从“running”到“shut off”的一个改变。

完整命令为“virsh migrate --live --verbose demo3 qemu+ssh://192.168.10.215/system tcp://192.168.10. 215 --unsafe

–verbose 指迁移demo3虚拟机,192.168.10.215为节点2的IP地址,使用tcp协议连接
–unsafe参数表示跳过安全检测

代码执行如图所示:

这里写图片描述


12、在节点2上,查看虚拟机demo3虚拟机状态

这里写图片描述


13、在迁移过程中,可以通过另外一台客户机一直ping虚拟机demo3,查看demo3前一过程中的可连接性,实际上迁移过程中偶尔有几个包的中断,基本上没有太大的影响


14、此时虽然demo3虚拟机已经在节点2上启动了,但是节点2上还没有demo3虚拟机的配置文件。这时需要创建配置文件并定义该虚拟机,可以通过迁移过来的虚拟机内存状态创建虚拟机配置文件
命令为“virsh dumpxml demo3 > /etc/libvirt/qemu/demo3.xml

然后通过xml配置文件定义虚拟机,命令为“virsh define /etc/libvirt/qemu/demo3.xml”。

这里写图片描述


15、使用命令“virsh console demo3”连接节点2上的demo3虚拟机

这里写图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/169801.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 1s看懂555定时器,以及应用?

    1s看懂555定时器,以及应用?555定时器是美国Signetics公司1972年研制的用于取代机械式定时器的中规模集成电路,因输入端设计有三个5kΩ的电阻而得名。此电路后来竟风靡世界。目前,流行的产品主要有4个:BJT两个:555,556(含有两个555);CMOS两个:7555,7556(含有两个7555)。555定时器是一种模拟和数字功能相结合的中规模集成器件。一般用双极型(TTL)工艺…

    2022年6月23日
    35
  • linux下编译jrtplib-3.9.1

    一、下载jrtplib、jthreadjrtplib:http://research.edm.uhasselt.be/jori/jrtplib/jrtplib-3.9.1.zipjthread:http://research.edm.uhasselt.be/jori/jthread/jthread-1.3.1.zipCMake:https://cmake.org/downl

    2022年4月8日
    41
  • C语言浮点数表示法 / float表示法(浮点数表示方法)

    C语言浮点数表示法 / float表示法(浮点数表示方法)一直不太清楚C语言中浮点数是怎么表示的,这篇文章能回答我的问题?浮点表示法float共计32位(4字节)由最高到最低位分别是第31、30、29、……、0位31位是符号位,1表示该数为负,0反之30~23位,一共8位是指数位(-128~127)22~0位,一共23位是尾数位后更。。…

    2022年6月28日
    29
  • SpringBoot使用@Mapper和@MapperScan注解无效的解决方法

    SpringBoot使用@Mapper和@MapperScan注解无效的解决方法在使用@Mapper注解时,注解无效,service层,dao层该添加的注解都添加了,最后发现是少加了一个jar包<!–缺少此jar包,导致@Mapper注解无效–><dependency><groupId>org.mybatis.spring.boot</groupId>

    2022年6月10日
    56
  • try catch 对性能影响

    try catch 对性能影响引言之前一直没有去研究trycatch的内部机制,只是一直停留在了感觉上,正好这周五开会交流学习的时候,有人提出了相关的问题。借着周末,正好研究一番。讨论的问题当时讨论的是这样的问题:比较下面两种trycatch写法,哪一种性能更好。for(inti=0;i<1000000;i++){try{Ma

    2022年6月16日
    53
  • 用idea配置c3p0连接池「建议收藏」

    用idea配置c3p0连接池「建议收藏」文章目录前言1.准备2.c3p0连接池配置添加依赖创建c3p0-config.xml3.JDBC连接4.测试5.小结前言上次利用c3p0封装了数据库操作工具类,但没有用到连接池,在处理大数据量访问的时候那种方法事不好的,最好使用连接池,本文将配置连接池的源码贴出。1.准备下载的包均是此时最新包c3p0-0.9.5.2包的下载JDBC-Connector8.0驱动包下载…

    2022年6月9日
    217

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号