qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Wen Congyang <wency@cn.fujitsu.com>
To: qemu devel <qemu-devel@nongnu.org>, Fam Zheng <famz@redhat.com>,
	Max Reitz <mreitz@redhat.com>,
	Paolo Bonzini <pbonzini@redhat.com>,
	Stefan Hajnoczi <stefanha@redhat.com>
Cc: Kevin Wolf <kwolf@redhat.com>, qemu block <qemu-block@nongnu.org>,
	Jiang Yunhong <yunhong.jiang@intel.com>,
	Dong Eddie <eddie.dong@intel.com>,
	"Dr. David Alan Gilbert" <dgilbert@redhat.com>,
	"Michael R. Hines" <mrhines@linux.vnet.ibm.com>,
	Yang Hongyang <yanghy@cn.fujitsu.com>
Subject: [Qemu-devel] [PATCH COLO-BLOCK v8 00/18] Block replication for continuous checkpoints
Date: Tue, 7 Jul 2015 16:42:58 +0800	[thread overview]
Message-ID: <1436258596-1253-1-git-send-email-wency@cn.fujitsu.com> (raw)

Block replication is a very important feature which is used for
continuous checkpoints(for example: COLO).

You can the detailed information about block replication from here:
http://wiki.qemu.org/Features/BlockReplication

Usage:
Please refer to docs/block-replication.txt

You can get the patch here:
https://github.com/coloft/qemu/tree/wency/block-replication-v8

You can get the patch with framework here:
https://github.com/coloft/qemu/tree/wency/colo_framework_v8

TODO:
1. Continuous block replication. It will be started after basic functions
   are accepted.

Wen Congyang (18):
  Add new block driver interface to add/delete a BDS's child
  quorum: implement block driver interfaces add/delete a BDS's child
  hmp: add monitor command to add/remove a child
  introduce a new API qemu_opts_absorb_qdict_by_index()
  quorum: allow ignoring child errors
  introduce a new API to enable/disable attach device model
  introduce a new API to check if blk is attached
  block: make bdrv_put_ref_bh_schedule() as a public API
  Backup: clear all bitmap when doing block checkpoint
  allow writing to the backing file
  Allow creating backup jobs when opening BDS
  block: Allow references for backing files
  docs: block replication's description
  Add new block driver interfaces to control block replication
  skip nbd_target when starting block replication
  quorum: implement block driver interfaces for block replication
  Implement new driver for block replication
  Add a new API to start/stop replication, do checkpoint to all BDSes

 block.c                        | 266 ++++++++++++++++++++++++-
 block/Makefile.objs            |   3 +-
 block/backup.c                 |  13 ++
 block/block-backend.c          |  33 +++
 block/quorum.c                 | 244 ++++++++++++++++++++++-
 block/replication.c            | 443 +++++++++++++++++++++++++++++++++++++++++
 blockdev.c                     |  90 ++++++---
 blockjob.c                     |  10 +
 docs/block-replication.txt     | 182 +++++++++++++++++
 hmp-commands.hx                |  28 +++
 include/block/block.h          |  15 ++
 include/block/block_int.h      |  19 ++
 include/block/blockjob.h       |  12 ++
 include/qemu/option.h          |   2 +
 include/sysemu/block-backend.h |   3 +
 include/sysemu/blockdev.h      |   2 +
 qapi/block.json                |  16 ++
 util/qemu-option.c             |  44 ++++
 18 files changed, 1378 insertions(+), 47 deletions(-)
 create mode 100644 block/replication.c
 create mode 100644 docs/block-replication.txt

-- 
2.4.3

             reply	other threads:[~2015-07-07  8:39 UTC|newest]

Thread overview: 24+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-07-07  8:42 Wen Congyang [this message]
2015-07-07  8:42 ` [Qemu-devel] [PATCH COLO-BLOCK v8 01/18] Add new block driver interface to add/delete a BDS's child Wen Congyang
2015-07-07  8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 02/18] quorum: implement block driver interfaces " Wen Congyang
2015-08-05 12:19   ` Alberto Garcia
2015-08-06  3:15     ` Wen Congyang
2015-07-07  8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 03/18] hmp: add monitor command to add/remove a child Wen Congyang
2015-07-07  8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 04/18] introduce a new API qemu_opts_absorb_qdict_by_index() Wen Congyang
2015-07-07  8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 05/18] quorum: allow ignoring child errors Wen Congyang
2015-07-07  8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 06/18] introduce a new API to enable/disable attach device model Wen Congyang
2015-07-07  8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 07/18] introduce a new API to check if blk is attached Wen Congyang
2015-07-07  8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 08/18] block: make bdrv_put_ref_bh_schedule() as a public API Wen Congyang
2015-07-07  8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 09/18] Backup: clear all bitmap when doing block checkpoint Wen Congyang
2015-07-09  1:28   ` Dr. David Alan Gilbert
2015-07-09  1:41     ` Wen Congyang
2015-07-07  8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 10/18] allow writing to the backing file Wen Congyang
2015-07-07  8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 11/18] Allow creating backup jobs when opening BDS Wen Congyang
2015-07-07  8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 12/18] block: Allow references for backing files Wen Congyang
2015-07-07  8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 13/18] docs: block replication's description Wen Congyang
2015-07-07  8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 14/18] Add new block driver interfaces to control block replication Wen Congyang
2015-07-07  8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 15/18] skip nbd_target when starting " Wen Congyang
2015-07-07  8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 16/18] quorum: implement block driver interfaces for " Wen Congyang
2015-07-07  8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 17/18] Implement new driver " Wen Congyang
2015-07-07  8:43 ` [Qemu-devel] [PATCH COLO-BLOCK v8 18/18] Add a new API to start/stop replication, do checkpoint to all BDSes Wen Congyang
2015-07-28  4:01 ` [Qemu-devel] [PATCH COLO-BLOCK v8 00/18] Block replication for continuous checkpoints Wen Congyang

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1436258596-1253-1-git-send-email-wency@cn.fujitsu.com \
    --to=wency@cn.fujitsu.com \
    --cc=dgilbert@redhat.com \
    --cc=eddie.dong@intel.com \
    --cc=famz@redhat.com \
    --cc=kwolf@redhat.com \
    --cc=mreitz@redhat.com \
    --cc=mrhines@linux.vnet.ibm.com \
    --cc=pbonzini@redhat.com \
    --cc=qemu-block@nongnu.org \
    --cc=qemu-devel@nongnu.org \
    --cc=stefanha@redhat.com \
    --cc=yanghy@cn.fujitsu.com \
    --cc=yunhong.jiang@intel.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).