QEMU live migration 代码简析
代码版本: qemu-1.4.0迁移发起端:迁移函数qmp_migrate1) 判断当前migrate状态是否为active(2) 判断是否有block migrate设备存在(3) 初始化(4) 判断migrate协议:TCP/UNIX/EXEC/FD 开始迁移保存虚拟机状态typedef struct SaveStateEntry {
代码版本: 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不共享的活迁移。
更多推荐
所有评论(0)