[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH RFC V2 0/7] COLO-Proxy: Make Xen COLO use userspace colo-proxy
Because of some reason, We no longer support COLO kernel proxy. So we send this patch set to make Xen use userspace colo-proxy in qemu. Below is a COLO userspace proxy ascii figure: Primary qemu Secondary qemu +--------------------------------------------------------------+ +----------------------------------------------------------------+ | +----------------------------------------------------------+ | | +-----------------------------------------------------------+ | | | | | | | | | | | guest | | | | guest | | | | | | | | | | | +-------^--------------------------+-----------------------+ | | +---------------------+--------+----------------------------+ | | | | | | ^ | | | | | | | | | | | | +------------------------------------------------------+ | | | | |netfilter| | | | | | netfilter | | | | +----------+ +----------------------------+ | | | +-----------------------------------------------------------+ | | | | | | | out | | | | | | filter excute order | | | | | | +-----------------------------+ | | | | | | +-------------------> | | | | | | | | | | | | | | | | TCP | | | | +-----+--+-+ +-----v----+ +-----v----+ |pri +----+----+sec| | | | +------------+ +---+----+---v+rewriter++ +------------+ | | | | | | | | | | |in | |in | | | | | | | | | | | | | | | | filter | | filter | | filter +------> colo <------+ +--------> filter +--> adjust | adjust +--> filter | | | | | | mirror | |redirector| |redirector| | | compare | | | | | | redirector | | ack | seq | | redirector | | | | | | | | | | | | | | | | | | | | | | | | | | | | | +----^-----+ +----+-----+ +----------+ | +---------+ | | | | +------------+ +--------+--------------+ +---+--------+ | | | | | tx | rx rx | | | | | tx all | rx | | | | | | | | | | +-----------------------------------------------------------+ | | | | +--------------+ | | | | | | | | | filter excute order | | | | | | | | | | +----------------> | | | +--------------------------------------------------------+ | | +-----------------------------------------+ | | | | | | | | | +--------------------------------------------------------------+ +----------------------------------------------------------------+ |guest receive | guest send | | +--------+----------------------------v------------------------+ | | NOTE: filter direction is rx/tx/all | tap | rx:receive packets sent to the netdev | | tx:receive packets sent by the netdev +--------------------------------------------------------------+ You can know the detail from here: http://wiki.qemu.org/Features/COLO https://github.com/qemu/qemu/blob/master/docs/colo-proxy.txt V2: - Address wei's comments, use macro to reuse codes. - Do some work on the last patch. - Fix some typo. - Add LIBXL_HAVE_COLO_USERSPACE_PROXY macro in libxl.h. - Some bug fix. V1: - Initial patch Zhang Chen (7): COLO-Proxy: Add remus command to open userspace proxy COLO-Proxy: Setup userspace colo-proxy on primary side tools/libxl: refactor do_domain_create() COLO-Proxy: Setup userspace colo-proxy on secondary side COLO-Proxy: Add primary userspace colo proxy start args COLO-Proxy: Add secondary userspace colo-proxy start args COLO-Proxy: Use socket to get checkpoint event. docs/man/xl.pod.1.in | 5 ++ tools/libxl/libxl.h | 6 ++ tools/libxl/libxl_colo.h | 7 +++ tools/libxl/libxl_colo_proxy.c | 99 +++++++++++++++++++++++++++++ tools/libxl/libxl_colo_restore.c | 19 ++++-- tools/libxl/libxl_colo_save.c | 19 +++++- tools/libxl/libxl_create.c | 21 ++++--- tools/libxl/libxl_dm.c | 132 +++++++++++++++++++++++++++++++++++++++ tools/libxl/libxl_nic.c | 109 ++++++++++++++++++++++++++++++++ tools/libxl/libxl_types.idl | 64 ++++++++++++++++--- tools/libxl/xl_cmdimpl.c | 120 +++++++++++++++++++++++++++++++++-- tools/libxl/xl_cmdtable.c | 3 +- 12 files changed, 575 insertions(+), 29 deletions(-) -- 2.7.4 _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx https://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |