代码版本: qemu-1.4.0

迁移发起端:

迁移函数

qmp_migrate

1) 判断当前migrate状态是否为active

(2) 判断是否有block migrate设备存在

(3) 初始化

(4) 判断migrate协议:TCP/UNIX/EXEC/FD 开始迁移

保存虚拟机状态

typedef struct SaveStateEntry {
    QTAILQ_ENTRY(SaveStateEntry) entry;
    char idstr[256];
    int instance_id;
    int alias_id;
    int version_id;
    int section_id;
    SaveVMHandlers *ops;
    const VMStateDescription *vmsd;
    void *opaque;
    CompatEntry *compat;
    int no_migrate;
    int is_ram;
} SaveStateEntry;

函数调用以TCP协议例:

函数调用过程

tcp_start_outgoing_migration()

 inet_nonblocking_connect()    // 连接监听目的虚拟机

          migrate_fd_connect()    //创建迁移处理线程
                  buffered_file_thread() //线程处理函数
                     qemu_savevm_state_begin() //初始化 se->ops->save_live_setup (block_save_setup,ram_save_setup)
                     qemu_savevm_state_iterate() //遍历实现设备内存状态保存
                              se->ops->save_live_iterate //真正处理的函数(block_save_iterate,ram_save_iterate)

                     vm_stop()   //停止虚拟机,不会有新的数据产生

                    qemu_savevm_state_complete //保存新的数据

                     vm_start() //若迁移失败,恢复虚拟机

                     buffered_flush() //发送数据

  目的端: 

qemu_start_incoming_migration


函数调用以TCP协议例:

tcp_start_incoming_migration ()
      inet_listen() //开监听
      tcp_accept_incoming_migration()       //接受连接
            process_incoming_migration()   // 接受数据
                     qemu_loadvm_state()    //导入状态  se->ops->load_state()
                     vm_start()             //若成功 启动虚拟机
                     runstate_set()         //若失败,停止

注:所有支持虚拟机活迁移的虚拟设备,都需要调用register_savevm_live方法,提供保存状态的SaveVMHandlers*save_live_iterate函数,供活迁移开始时被调用正是因为块设备注册了SaveStateEntry对象,才使KVM能够支持image不共享的活迁移。

                


                                                  



Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐