[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 06/15] COLO: Add block replication into colo process
From: |
zhanghailiang |
Subject: |
[Qemu-devel] [PATCH 06/15] COLO: Add block replication into colo process |
Date: |
Wed, 22 Feb 2017 11:42:07 +0800 |
Make sure master start block replication after slave's block
replication started.
Signed-off-by: zhanghailiang <address@hidden>
Signed-off-by: Wen Congyang <address@hidden>
Signed-off-by: Li Zhijian <address@hidden>
Cc: Stefan Hajnoczi <address@hidden>
Cc: Kevin Wolf <address@hidden>
Cc: Max Reitz <address@hidden>
Cc: Changlong Xie <address@hidden>
---
migration/colo.c | 56 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 56 insertions(+)
diff --git a/migration/colo.c b/migration/colo.c
index 4626435..1e3e975 100644
--- a/migration/colo.c
+++ b/migration/colo.c
@@ -21,6 +21,9 @@
#include "migration/failover.h"
#include "net/colo-compare.h"
#include "net/colo.h"
+#include "qapi-event.h"
+#include "block/block.h"
+#include "replication.h"
static bool vmstate_loading;
static Notifier packets_compare_notifier;
@@ -55,6 +58,7 @@ static void secondary_vm_do_failover(void)
{
int old_state;
MigrationIncomingState *mis = migration_incoming_get_current();
+ Error *local_err = NULL;
/* Can not do failover during the process of VM's loading VMstate, Or
* it will break the secondary VM.
@@ -72,6 +76,11 @@ static void secondary_vm_do_failover(void)
migrate_set_state(&mis->state, MIGRATION_STATUS_COLO,
MIGRATION_STATUS_COMPLETED);
+ replication_stop_all(true, &local_err);
+ if (local_err) {
+ error_report_err(local_err);
+ }
+
if (!autostart) {
error_report("\"-S\" qemu option will be ignored in secondary side");
/* recover runstate to normal migration finish state */
@@ -109,6 +118,7 @@ static void primary_vm_do_failover(void)
{
MigrationState *s = migrate_get_current();
int old_state;
+ Error *local_err = NULL;
migrate_set_state(&s->state, MIGRATION_STATUS_COLO,
MIGRATION_STATUS_COMPLETED);
@@ -132,6 +142,12 @@ static void primary_vm_do_failover(void)
FailoverStatus_lookup[old_state]);
return;
}
+
+ replication_stop_all(true, &local_err);
+ if (local_err) {
+ error_report_err(local_err);
+ }
+
/* Notify COLO thread that failover work is finished */
qemu_sem_post(&s->colo_exit_sem);
}
@@ -297,6 +313,15 @@ static int colo_do_checkpoint_transaction(MigrationState
*s,
s->params.shared = 0;
qemu_savevm_state_header(fb);
qemu_savevm_state_begin(fb, &s->params);
+
+ /* We call this API although this may do nothing on primary side. */
+ qemu_mutex_lock_iothread();
+ replication_do_checkpoint_all(&local_err);
+ qemu_mutex_unlock_iothread();
+ if (local_err) {
+ goto out;
+ }
+
qemu_mutex_lock_iothread();
qemu_savevm_state_complete_precopy(fb, false);
qemu_mutex_unlock_iothread();
@@ -403,6 +428,12 @@ static void colo_process_checkpoint(MigrationState *s)
object_unref(OBJECT(bioc));
qemu_mutex_lock_iothread();
+ replication_start_all(REPLICATION_MODE_PRIMARY, &local_err);
+ if (local_err) {
+ qemu_mutex_unlock_iothread();
+ goto out;
+ }
+
vm_start();
qemu_mutex_unlock_iothread();
trace_colo_vm_state_change("stop", "run");
@@ -497,6 +528,7 @@ static void colo_wait_handle_message(QEMUFile *f, int
*checkpoint_request,
case COLO_MESSAGE_GUEST_SHUTDOWN:
qemu_mutex_lock_iothread();
vm_stop_force_state(RUN_STATE_COLO);
+ replication_stop_all(false, NULL);
qemu_system_shutdown_request_core();
qemu_mutex_unlock_iothread();
/*
@@ -544,6 +576,18 @@ void *colo_process_incoming_thread(void *opaque)
fb = qemu_fopen_channel_input(QIO_CHANNEL(bioc));
object_unref(OBJECT(bioc));
+ qemu_mutex_lock_iothread();
+ bdrv_invalidate_cache_all(&local_err);
+ if (local_err) {
+ qemu_mutex_unlock_iothread();
+ goto out;
+ }
+ replication_start_all(REPLICATION_MODE_SECONDARY, &local_err);
+ qemu_mutex_unlock_iothread();
+ if (local_err) {
+ goto out;
+ }
+
colo_send_message(mis->to_src_file, COLO_MESSAGE_CHECKPOINT_READY,
&local_err);
if (local_err) {
@@ -620,6 +664,18 @@ void *colo_process_incoming_thread(void *opaque)
goto out;
}
+ replication_get_error_all(&local_err);
+ if (local_err) {
+ qemu_mutex_unlock_iothread();
+ goto out;
+ }
+ /* discard colo disk buffer */
+ replication_do_checkpoint_all(&local_err);
+ if (local_err) {
+ qemu_mutex_unlock_iothread();
+ goto out;
+ }
+
vmstate_loading = false;
vm_start();
trace_colo_vm_state_change("stop", "run");
--
1.8.3.1
- [Qemu-devel] [PATCH 08/15] ram/COLO: Record the dirty pages that SVM received, (continued)
- [Qemu-devel] [PATCH 08/15] ram/COLO: Record the dirty pages that SVM received, zhanghailiang, 2017/02/21
- [Qemu-devel] [PATCH 04/15] COLO: integrate colo compare with colo frame, zhanghailiang, 2017/02/21
- [Qemu-devel] [PATCH 01/15] net/colo: Add notifier/callback related helpers for filter, zhanghailiang, 2017/02/21
- [Qemu-devel] [PATCH 07/15] COLO: Load PVM's dirty pages into SVM's RAM cache temporarily, zhanghailiang, 2017/02/21
- [Qemu-devel] [PATCH 02/15] colo-compare: implement the process of checkpoint, zhanghailiang, 2017/02/21
- [Qemu-devel] [PATCH 05/15] COLO: Handle shutdown command for VM in COLO state, zhanghailiang, 2017/02/21
- [Qemu-devel] [PATCH 06/15] COLO: Add block replication into colo process,
zhanghailiang <=
- [Qemu-devel] [PATCH 14/15] COLO: Split qemu_savevm_state_begin out of checkpoint process, zhanghailiang, 2017/02/21
- [Qemu-devel] [PATCH 12/15] savevm: split the process of different stages for loadvm/savevm, zhanghailiang, 2017/02/21
- [Qemu-devel] [PATCH 15/15] COLO: flush host dirty ram from cache, zhanghailiang, 2017/02/21
- [Qemu-devel] [PATCH 13/15] COLO: Separate the process of saving/loading ram and device state, zhanghailiang, 2017/02/21
- [Qemu-devel] [PATCH 11/15] savevm: split save/find loadvm_handlers entry into two helper functions, zhanghailiang, 2017/02/21
- [Qemu-devel] [PATCH 03/15] colo-compare: use notifier to notify packets comparing result, zhanghailiang, 2017/02/21
- [Qemu-devel] [PATCH 10/15] qmp event: Add COLO_EXIT event to notify users while exited from COLO, zhanghailiang, 2017/02/21