linux系统在虚拟机迁移中的技术难点

    通常我们期望虚拟机的迁移能够全部自动化或者部分自动化完成,但实际上Linux系统在P2V(Physical to virtual 物理到虚拟)和V2V(virtual to virtual)的迁移中可能遇到一些困难。

    1.磁盘分区名被硬编码。

    当我们做磁盘虚拟化时,可能会使用不同类型的虚拟磁盘设备,这将会导致磁盘名字的变化。比如Xen虚拟机中的半虚拟化设备使用/dev/xvda,而标准的Liunx半虚拟化设备使用/dev/vda。准备迁移的Linux系统中存在对/dev/hd*和/dev/sd*磁盘分区名反三的关联,比如/etc/fstab文件,启动初始化文件系统ramfs和一些解析磁盘设备的开机启动脚本文件中。v2v迁移工具需要在整个磁盘上查找并修改这些关联。有一个I安单的方法来避免这种情况:Linux系统上主流的文件系统和分区类型可以使用Lables或UUID作为分区名。迁移时这些信息是被重点保护的。系统应该小心使用这些信息,一定不要使用设作为分区名。另外,LVM分区名和设备无关,在前一种也不受影响。

    2.网络硬件设备的改变。

    当系统迁移时,网络设备很可能产生变化。比如虚拟网络设备和物理网络设备的转化或者不同类型的网络设备之间的转变。但是是他们的MAC地址没有变化。MAC地址是IEEE分配给物理设备制造商的,两个物理设备不会有相同的MAC地址;然而细腻网络设备可能出现这种情况。所以在做吸泥机迁移时,必须记录每一个网络设备的MAC地址,保证MAC地址和网络设备的对应关系。

    3.内核不支持某些虚拟设备。

    某些Linux发行版没有virtio虚拟设备的驱动,可能是因为Linux发行版遭遇虚拟设备发布了;或者虚拟设备的驱动不是开源的;或者是在系统编译时去掉了。因此,有事我们另外需要一个完全不同的内核(比如Xen早起的版本就是这样的)。无论如何,在客户机上安装一个新的内核并且使之可以启动是一个很大的冒险,最好避免这样做。

    4.Xwindow需要重新配置。

    与磁盘、网络设备一样,系统迁移后显示设备也会变化。理想的情况是Xwindow会自动处理这个的变化,探测所有的显示设备并且使用它发现的第一个设备。但是这不意味着所有的Linux发行版都会以这种方式工作。

    5.网络环境的变化。静态IP地址和静态DNS解析在虚拟机迁移中是一个麻烦的事情。尽管不是必须的,但是最好配置系统从DHCP服务器自动获得所有的网络配置信息。

    6.CPU的扩展指令集发生变化。

    迁移后的系统中,新的虚拟CPU火主板和旧的会有一些不同。CPU的扩展指令集茹SSE,Vectors,NX可能被加入或去掉。CPU的型号和制造商信息可能被改变。因此,如果你想要优化虚拟系统上的软件,这可能是浪费时间并且导致系统崩溃。最好是使用通用的软件,让程序在每次启动的时候检查运行环境是否需要优化。

    实际上,实时迁移的状况比这个还要复杂,因为处理器可能在程序的运行的过程中被改变,。目前为止还没有一个方案能很好的解决这个问题。

    P2V和V2V最大的问题在于硬件的改变。Linux发行版本身应该可以处理所有的硬件变化:正在系统启动的时候去检查所有的硬件,操作系统内核识别新的设备并寻找新的驱动处理他们,所有应用软件都不要和硬件绑定,设计一个很好的模式来应对突然的环境变化。


转载于:https://blog.51cto.com/toubicongrong/1619902