ctys-cloneVM

February, 2011



.

NAME

ctys-cloneVM - Copy and configure VMs


SYNTAX


ctys-cloneVM


   [-d <debug-level>]
   --directory=<directory>
   [--defaults-file=<file-name>]
   [-f]
   [-h]
   [-H <help-options>]
   [--ip=<IP-address>]
   --label=<the-target-vm-label>
   --label-old=<the-source-vm-label>
   [--mac=<MAC-address>]
   [--no-create-image]
   [--no-save-para-kernel]
   -t <session-type>
   [--tcp=<TCP-DNS-name>]
   [-V]
   [--vm-state=<VSTAT>]
   [--uuid=<UUID>]
   [-X]






DESCRIPTION

ctys-cloneVM provides the automated duplication of present virtual machines. Therefore first the VM is copied to a defined target and second the configuration parameters are altered to new values. The duplicated new VM is executable without any further required modification. The conversion between different hypevisors - a.k.a. session types - is provided by the tool ctys-convertVM(1).

The current version of ctys-cloneVM could be applied by batch processing mode to offline-VMs, where basic values could be consistently altered for the new VM. Local targets are supported only, thus a remote VM target requires the remote copy by OS means.

Additional fine grained configuration parameters could be set by ctys-createConfVM(1). The target VM could be stored locally or to a remote location by secure connections via 'scp' from the OpenSSH package. The full scope of authorisation for remote connections by OpenSSH could be applied, this comprises particularly SSH-Keys and Kerberos.

The current version provides the following features:

The following table shows a sumup of available features for the current version. The sessiontypes requirering specific tools for their repositories has to be executed on a platform with installed tools and probably with running and enabled hypervisor including helper processes. In cases with specific storage addressing the appropriate mapping functions are required.

Hypervisor/Emulator VM-Copy VM-Config VM-Registration GuestOS-Config
QEMU/KVM x x ctys ffs. 3.)
VBOX x x ctys + OEM 1.) ffs. 3.)
VMW x x ctys + OEM 2.) ffs. 3.)
VMWE - VMware ESX(TM) ffs. ffs. ffs. ffs. 3.)
VMWEi - VMware ESXi(TM) ffs. ffs. ffs. ffs. 3.)
XEN x x ctys ffs. 3.)
XENS - XenServer(TM) ffs. ffs. ffs. ffs. 3.)

Clone Automation

ctys Ctys database by ctys-vdbgen and ctys-vhosts.
OEM Registration within the native inventory of the OEM.
   
1.) Requires additional registration in runtime database by VirtualBox-Gui.
2.) Requires for some versions additional registration in runtime database
by VMware-Gui. Registration for VMware-Server-2.x could be performed
implicitly when providing User and non-crypted Password at the commandline,
which should be avoided.
3.) Requires the native configuration, which depends on the OS. E.g. a
MS-Widows(TM) workstation may require the reconfiguration of system parameters
for networking and in addition the new reqistration in it's ADS domain.


The available call options are partly set by the commandline options, but could the majority of the values are used by pre-assigned environment variables. This is similar to the call of ctys-createConfVM(1), the variables are the same. The modification of the configuratrion parameters is accomplished by ctys-createConfVM. Therefore the values are just passed through to ctys-createConfVM.

.

OPTIONS

-d <debug-level>

Same as ctys.

--directory=<directory>

Parent directory for storage of cloned VM. The actually created directory path is '<directory>/<label>'. The value of '<directory>' is required to be absolute.

--defaults-file=<file-name>

Filename of pre-stored default values for copied VM, the creation could be performed by usage of ctys-createConfVM.

-f

Force the processing when the target directory is present.

-h|--help|-help*

Print help, refer to "-H" for additional information.

-H <help-option>

The extended help option is based on system interfaces for display of manpages, PDF and HTML documents. This comprises the man pages and installed manuals.

For additional help refer to the documents or type ctys -H help.

--label=<label-for-target-vm>

The label - the name - for the target VM to be created.

--label-old=<label-for-source-vm>

The label - the name - for the source VM to be cloned.

--list-env-var-options

List of current options to be set by environment variables. For additional information refer to ctys-createConfVM(1).

--no-create-image

Suppresses the copy of the virtual file image.

--vm-state=<VSTAT>

The state to be set for the target machine. For additional information on values refer to ctys-states(1).

--no-save-para-kernel

Suppresses the copy of the external runtime kernels. External runtime kernels are frequently requiered for paraviretualized DomU of Xen and in some cases of QEMU.

-t <session-type>

The session type the VM has to be created for. Currently QEMU (for QEMU and KVM on x86), VMW , VBOX , and XEN are supported. Each defines a common set of parameters with additional specific variations.

-V

Version.

-X

Terse.


.

ARGUMENTS

None.


.

EXAMPLES

Create a Test-VM
The following call creates a dummy VM with a small dummy-image.
  
  MAC=00:11:22:33:44:55 \
  IP=12.12.12.12 \
  TCP=gecko \
  HDDBOOTIMAGE_INST_SIZE=128M \
  HDDBOOTIMAGE_INST_BLOCKSIZE=32M \
  HDDBOOTIMAGE_INST_BLOCKCOUNT=4 \
  ctys-createConfVM \
    -t XEN \
    --label=tst02 \
    --auto-all \
    --create-image
  
Create defaults file from the Source-VM
The following call of ctys-createConfVM(1) creates the defaults file, which is used for pre-assignment of values from the source machine for the cloned machine. Some basic machine related IDs are required to be altered by command line assignment.
  
  MAC=00:11:22:33:44:55 \
  ctys-createConfVM \
    -t XEN \
    --label=tst02 \
    --defaults-file-create \
    --auto-all \
    --no-create-image \
    --no-save-para-kernel
  
Clone the Source-VM
The follwing call actually cloned the source VM.
  
  ctys-cloneVM \
    -t xen \
    --label=tst02clone \
    --label-old=tst02 \
    --directory=/mntn/vmpool/vmpool05/xen/test/tst-ctys-call \
    --ip=14.14.14.14 \
    --mac=44:44:44:44:44:44 \
    --tcp=abc \
    --uuid=123412341234 \
    --vm-state=DISABLED \
    -f
  

Display and modify some attributes on the Cloned-VM
  1. List XEN configuration file:
      ctys-attribute --list tst02clone.conf
    

  2. List CTYS configuration file:
      ctys-attribute --list tst02clone.ctys
    

  3. Replace all values of an attribute in XEN configuration file:
      ctys-attribute \
        --attribute-name='kernelbase' \
        --attribute-replace=ALL  \
        --attribute-value-new="'/nboot1'"  \
        tst02clone.conf
    

  4. Replace string in all values of an attribute in XEN configuration file:
      ctys-attribute \
        --attribute-name='kernelbase' \
        --attribute-replace=ALL \
        --attribute-value-new="'/nboot1'" \
        --attribute-value-old="'/boot'" \
        tst02clone.conf
    

  5. Replace string in FIRST value of an attribute in XEN configuration file:
      ctys-attribute \
        --attribute-name='kernelbase' \
        --attribute-replace=FIRST \
        --attribute-value-new="'/nboot1'" \
        --attribute-value-old="'/boot'" \
        tst02clone.conf
    

  6. Replace string in LAST value of an attribute in XEN configuration file:
      ctys-attribute \
        --attribute-name='kernelbase' \
        --attribute-replace=FIRST \
        --attribute-value-new="'/nboot1'" \
        --attribute-value-old="'/boot'" \
        tst02clone.conf
    

  7. Replace string in 2. value of an attribute in CTYS configuration file:
      ctys-attribute \
        --attribute-name='kernelbase' \
        --attribute-replace=FIRST \
        --attribute-value-new="'/nboot1'" \
        --attribute-value-old="'/boot'" \
        tst02clone.conf
    

  8. Replace all values of an attribute in CTYS configuration file:
      ctys-attribute \
        --attribute-name='WRAPPERCALL' \
        --attribute-replace=ALL  \
        --attribute-value-new="'123'"  \
        tst02clone.ctys
    

  9. Create new attribute value assignment in CTYS configuration file:
      ctys-attribute \
        --attribute-create=TOP \
        --attribute-name='NEWATTR' \
        --attribute-value-new="'123'"  \
        tst02clone.ctys
    

  10. Create new attribute value assignment in CTYS configuration file:
      ctys-attribute \
        --attribute-create=BOTTOM \
        --attribute-name='NEWATTR' \
        --attribute-value-new="'123'"  \
        tst02clone.ctys
    

  11. Create new attribute value assignment in CTYS configuration file:
      ctys-attribute \
        --attribute-create=15 \
        --attribute-name='NEWATTR' \
        --attribute-value-new="'123'"  \
        tst02clone.ctys
    

  12. Delete first occurance of an attribute in CTYS configuration file:
      ctys-attribute \
        --attribute-delete \
        --attribute-name='NEWATTR' \
        tst02clone.ctys
    
    or
      ctys-attribute \
        --attribute-delete=1 \
        --attribute-name='NEWATTR' \
        tst02clone.ctys
    

  13. Delete ALL occurances of an attribute in CTYS configuration file:
      ctys-attribute \
        --attribute-delete=ALL \
        --attribute-name='NEWATTR' \
        tst02clone.ctys
    



.

EXIT-VALUES

0: OK:
Result is valid.

1: NOK:
Erroneous parameters.

2: NOK:
Missing an environment element like files or databases.


SEE ALSO

ctys executables
ctys-attribute(1) , ctys-createConfVM(1) , ctys-convertVM(1)

ctys plugins
PMs
ctys-PM(1)

VMs
KVM(1) , ctys-QEMU(1) , ctys-VBOX(1) , ctys-VMW(1) , ctys-XEN(1)

HOSTS
ctys-CLI(1) , ctys-RDP(1) , ctys-VNC(1) , ctys-X11(1)




AUTHOR

Written and maintained by Arno-Can Uestuensoez:

Maintenance: <<acue_sf1 (a) sourceforge net>>
Homepage: <https://arnocan.wordpress.com>
Sourceforge.net: <http://sourceforge.net/projects/ctys>
Project moved from Berlios.de to OSDN.net: <https://osdn.net/projects/ctys>
Commercial: <https://arnocan.wordpress.com>




COPYRIGHT

Copyright (C) 2008, 2009, 2010, 2011 Ingenieurbuero Arno-Can Uestuensoez

For BASE package following licenses apply,

This document is part of the DOC package,

For additional information refer to enclosed Releasenotes and License files.