Skip to content

Latest commit

 

History

History
3923 lines (3099 loc) · 206 KB

virtuozzo_7_command_line_reference.asc

File metadata and controls

3923 lines (3099 loc) · 206 KB

Virtuozzo 7 Beta Command Line Reference

Introduction

Virtuozzo 7 is a virtualization solution that allows you to run multiple virtual machines and containers on a single physical server.

This chapter provides general information about Virtuozzo and this guide.

About Virtuozzo 7

Virtuozzo 7 is a virtualization solution that allows you to simultaneously run multiple Virtuozzo virtual machines and containers on a single physical server. With Virtuozzo, you can efficiently share your server’s hardware resources among virtual machines and containers.

Virtuozzo is installed directly on the server hardware and does not need any operating system to function. Once it is installed, Virtuozzo allows you to create virtual machines and containers and manage them using the Virtuozzo command-line interface (CLI). The command-line interface comprises a set of Virtuozzo command-line utilities that you can use to manage virtual machines and containers, both locally and remotely.

Graphically, a server with the Virtuozzo software installed can be represented as follows:

psbm55 architecture

About This Guide

This guide is a reference of Virtuozzo configuration files and command-line utilities. It familiarizes you with the way to configure Virtuozzo to meet your requirements and to perform various tasks by using the corresponding command-line utilities.

The primary audience for this guide is anyone who is looking for an explanation of a particular configuration option, needs help for a particular command, or is seeking for a command to perform a certain task.

Managing Virtuozzo 7

This chapter provides instructions on configuration files, scripts, and command-line utilities that can be used to configure the settings related to the Virtuozzo software and the hardware node.

Virtuozzo Configuration Files

The table below lists the configuration files available in Virtuozzo 7. Most files are located in the /etc directory on a hardware node. If a configuration file is stored in a place other than the hardware node, its exact location is specified.

Name Description

/etc/vz/vz.conf

Global configuration file. This file keeps system-wide settings, such as the default location of templates and global network settings.

/etc/vz/conf/<CT_name>.conf

Private configuration file of a container with the name <CT_name>. This file keeps container-specific settings: resource management parameters, the location of its private area, IP address, and so on.

/etc/vz/conf/ve-<name>.conf-sample

Sample files containing a number of default container configurations. Some pre-created samples file are shipped with Virtuozzo (e.g., basic and confixx), but you can also create your own samples to meet your demands.

/usr/libexec/libvzctl/dists/<distribution_name>.conf

Linux distribution configuration files. These files define what scripts should be run when you perform specific operations with containers (e.g., when you set a new IP address for a container). The scripts differ from Virtuozzo action scripts and depend on the Linux version a particular container is running.

/etc/vz/pfcache.conf

Configuration file used by the pfcache utility to manage memory and IOPS deduplication.

/etc/vz/oom-groups.conf

OOM killer configuration file with task badness adjustments.

/etc/vz/conf/networks_classes

Configuration file defining the network classes for traffic shaping and bandwidth management.

/etc/sysctl.conf

Kernel parameters. Virtuozzo adjusts a number of kernel sysctl parameters and modifies the default /etc/sysctl.conf file.

/etc/vztt/vztt.conf

Configuration file used by the vzpkg utility to manage OS and application EZ templates.

Global Virtuozzo Configuration File

Virtuozzo keeps its system wide configuration parameters in the /etc/vz/vz.conf configuration file. This file is in shell format. Keep in mind that Virtuozzo scripts source this file - thus, shell commands in this file will cause system to execute them under root account. Parameters in this file are presented in the form PARAMETER="value". Logically all the parameters belong to the following groups: global parameters, logging, disk quotas, template, network traffic, containers, validation and overcommitment, supplementary parameters, and name-based hosting parameters. Below is the description of all the parameters defined in this version of Virtuozzo.

Name Description Default Value

VIRTUOZZO

This can be either yes or no. Virtuozzo System V startup script checks this parameter. If set to no, then Virtuozzo modules are not loaded. You might set it to "no" if you want to perform system maintenance and do not want to bring up all containers on the server.

yes

HTTP_PROXY

Specifies either the hostname or the IP address of the HTTP proxy server. After setting this parameter and in case you use an HTTP proxy server for handling all HTTP requests, the Virtuozzo utilities communicating with the outer world through HTTP will use this server for managing all your HTTP messages.

n/a

ACTIONLOGDIR

This is the directory where prlctl keeps a log of its actions in the format suitable for Virtuozzo statistics daemon hwcoll.

/vz/actionlog

LOCKDIR

Actions on a container should be serialized, since two simultaneous operations on the same container may break its consistency. Virtuozzo keeps lock files in this directory in order to serialize access to one container.

/vz/lock

VEFSTYPE

File system to use when caching OS templates:

  • ext4,

  • simfs.

ext4

IPV6

Defines whether the IPv6 support is enabled on the hardware node.

yes

GOLDEN_IMAGE

Enables (yes) or disables (no) embedding application templates into OS EZ template cache prior to creating containers based on this cache.

yes

PFCACHE

Path to the memory and IOPS deduplication cache with common container files.

/vz/pfcache

PFCACHE_IMAGE

Path to the private area of the memory and IOPS deduplication cache.

/vz/pfcache.hdd

PFCACHE_IMAGE_SIZE

Image size (in 1KB blocks) of the memory and IOPS deduplication cache.

10485760

PFCACHE_INCLUDES

Directories for which memory and IOPS deduplication is enabled by default.

bin lib lib64 opt sbin usr

VZ_TOOLS_BCID

Enables limits for the backup, restore, and migration operations.

 

VZ_TOOLS_IOLIMIT

Sets the disk I/O limit for the backup, restore, and migration operations, in bytes per second. Not set by default.

 

Table 1. Logging parameters
Name Description Default Value

LOGGING

This parameter defines whether prlctl should log its actions.

yes

LOGFILE

File where libvzctl logs the actions of programs linked to this library.

/var/log/vzctl.log

LOG_LEVEL

Logging verbosity, from 0 to 10 (higher is more verbose).

0

Table 2. Disk quota parameters
Name Description Default Value

DISK_QUOTA

Enables or disables disk quotas for containers. If set to no then disk space accounting will be disabled.

yes

Table 3. Network traffic parameters
Name Description Default Value

TRAFFIC_SHAPING

Traffic shaping allows you to limit the bandwidth consumed by containers for outgoing traffic. If it is set to "yes", then limitations will be turned on. If you want to use this feature, TRAFFIC_ACCOUNTING should be set to yes as well.

no

BANDWIDTH

This is the list of network interfaces on which we want to shape the traffic and their speed in the form of "dev:rate". The rate is measured in Kbps. If you want to shape traffic on more than one interface, set this parameter to dev1:rate1 dev2:rate2. For example, for two 100 Mbps Ethernet cards, set it to eth0:102400 eth1:102400.

eth0:102400

TOTALRATE

This parameter sets the size of the bandwidth pool for all containers. It is the upper limit for the bandwidth available to all your containers and is specified in the form of "dev:class:rate". The rate is measured in Kbps. Containers can consume bandwidth up to this limit in addition to the limit specified by the RATE parameter. Default value corresponds to 4 Mbps limit for the Class 1 containers.

eth0:1:4096

RATE

This parameter is the default bandwidth guaranteed to a container for outgoing traffic if the container configuration file does not explicitly specify a different value. This value is in the same format as TOTALRATE and its default value is "eth0:1:8". The rate is measured in Kbps. Note that 8 Kbps, offered by the default configuration, is the guarantee and the container cannot consume less than this value and more than the sum of this value and TOTALRATE.

eth0:1:8

RATEMPU

This optional parameter (where MPU stands for "minimum packet unit") limits the packet rate by making packets smaller than MPU in size consume HTB tokens. With it, small packets can be accounted as larger ones and limited by TOTALRATE and RATE parameters. Approximately, the maximum packets per second rate can be calculated as TOTALRATE / RATEMPU.

*:1:1000

Table 4. Template parameters
Name Description Default Value

TEMPLATE

This is the directory where to find templates. It is not recommended to redefine this option since all Virtuozzo templates use the default directory.

/vz/template

Table 5. Container default parameters
Name Description Default Value

VE_ROOT

The mount point for container’s root. Must contain the literal string $VEID that will be substituted with the actual container UUID.

/vz/root/$VEID

VE_PRIVATE

The directory where all the files and directories specific to the container are stored. Must contain the literal string $VEID that will be substituted with the actual container UUID.

/vz/private/$VEID

CONFIGFILE

The default configuration file sample to be used for the container creation; it may be overridden with the --config option of the vzctl create command.

basic

DEF_OSTEMPLATE

The default OS template to be used for the container creation.

centos-7

VE_ENVIRONMENT

Additional environment variables to be passed to the container init process. Should be provided as any number of <name>=<value> pairs separated by spaces.

 

Container Configuration File

Each container has its own configuration file, which is stored in the /etc/vz/conf directory and has a name like <CT_name>.conf. This file has the same format as the global configuration file. The settings specified in this file can be subdivided into the following categories:

  • miscellaneous,

  • resource management parameters,

  • networking.

Miscellaneous Parameters

The table below list the miscellaneous parameters you can set in the configuration file of a container:

Name Description

VERSION

Specifies the Virtuozzo version the configuration file applies to. 2 relates to Virtuozzo version 4 and later.

ONBOOT

Specifies whether the container should be started automatically on system startup. Virtuozzo automatically starts all containers that have this parameter set to "yes" upon startup.

ALLOWREBOOT

Specifies whether the container may be restarted with the reboot command run from inside. If omitted or set to yes, restarting is allowed.

OSTEMPLATE

The name of the OS template that was used for creating the container. You do not have to change this parameter; prlctl will set it for you upon calling the prlctl create command (or using the defaults from the global configuration file). The . symbol before the OS template name, if specified, indicates that this is an EZ OS template.

TEMPLATES

In a configuration file of an existing container, this parameter lists application templates installed with the prlctl create or vzpkg install commands. In this case you should not modify it, because it is used by template management utilities to track installation history. This parameter is omitted if no templates have been installed to the container.

VE_ROOT

Overrides the VE_ROOT parameter from the global configuration file.

VE_PRIVATE

Overrides the VE_PRIVATE parameter from the global configuration file.

VE_ENVIRONMENT

Overrides the VE_ENVIRONMENT parameter from the global configuration file.

TECHNOLOGIES

Determines a set of technologies which should be provided by the Virtuozzo kernel for container operation. Currently, this parameter can contain the information about the following technologies:

  • The system architecture of the container (x86, x86_64, or i64).

  • Whether the container is based on the OS template supporting the Native POSIX Thread Library (NPTL). In this case, the nptl entry is specified as the value of this parameter.

  • Whether the OS EZ template the container is based on requires the sysfs filesystem support (e.g., the OS EZ template for SUSE Linux Enterprise 10).

DISABLED

If set to yes, disables the container making it impossible to start the container once it was stopped. You can start the disabled container after setting the value of this parameter to no.

DESCRIPTION

Sets the description for the container.

Note

Note: You are allowed to use only symbols in the A-z and 0-9 ranges in your descriptions.

NAME

Container name that can be used to refer to said container in commands. Names must be alphanumeric and may contain the characters \, -, _. Names with white spaces must be enclosed in quotation marks.

ORIGIN_SAMPLE

The configuration sample the container was based on when created.

CONFIG_CUSTOMIZED

Indicates whether any of the container configuration parameters have been modified as regards its original configuration sample. If this parameter is omitted, its value is considered as no.

UUID

The container unique identifier. This identifier is used by certain Virtuozzo utilities during their execution.

Resource Management Parameters

All resource management parameters can be subdivided into the CPU, disk, system, and VSwap categories for your convenience. Any parameter can be set with the prlctl set command and the corresponding option name (in the lower case, e.g., --cpuunits for CPUUNITS, etc.). See [_managing_containers] for more details. The Typical value column, if present, specifies a range of reasonable parameter values for different applications, from light to huge heavy loaded containers. If the barrier and limit fields are in use, ranges for both thresholds are given.

Table 6. CPU Parameters
Parameter Description Typical value

CPUUNITS

CPU weight. This is a positive integer number that defines how much CPU time the container can get as compared to the other virtual machines and containers running on the server. The larger the number, the more CPU time the container can receive. Possible values range from 8 to 500000. If this parameter is not set, the default value of 1000 is used.

250...1000

CPULIMIT, CPULIMIT_MHZ

CPU limit, in per cent  (CPULIMIT) or megahertz (CPULIMIT_MHZ), the container is not allowed to exceed. The parameter is not set for newly created containers; so they can consume all free CPU power of the server. When setting this parameter in per cent, keep in mind that one CPU core makes up 100%. So if the server has 4 CPU cores, the total CPU power will equal 400%.

 

CPUS

Number of CPU cores defining the CPU limit for a container. The limit is calculated by multiplying the power of one CPU core by the number of the specified CPU cores. This option also defines the number of CPUs shown to users from inside a container. This parameter is not set for newly created containers; so they can consume all free CPU power of the server.

 

CPUMASK

The CPU affinity mask defining which CPUs on the Node can be used to handle the processes running in the container. The CPU mask can be specified as both separate CPU index numbers (1,2,3) and CPU ranges (2-4,5-7).

 

NODEMASK

The NUMA node mask defining a NUMA node to bind the container to. Once you set the mask, the processes running in the container will be executed only on the CPUs that belong to the specified NUMA node.

 

Table 7. Disk Parameters
Parameter Description Typical value

DISKSPACE

Total size of disk space that can be consumed by the container, in 1 KB blocks.

204800...10485760- 204800...11534340

QUOTAUGIDLIMIT

This parameter enables (if set to a value other than 0) or disables (if set to 0) per-user and per-group quotas for further management with the standard Linux quota utility. Enabling per-user and per-group quotas for a container requires restarting the container.

0...N

IOPRIO

The container priority for disk I/O operations. The higher the priority, the more time the container has for writing to and reading from the disk. The default container priority is 4.

0-7

IOPSLIMIT

The maximum number of disk input and output operations per second a container is allowed to perform. By default, any newly created container does not have the IOPS limit set and can perform so many disk I/O operations per second as necessary.

 

IOLIMIT

The bandwidth a container is allowed to use for its disk input and output (I/O) operations. By default, the limit is set in megabytes per second. However, you can use the following suffixes to use other measurement units:

  • G - sets the limit in gigabytes per second.

  • K - sets the limit in kilobytes per second.

  • B - sets the limit in bytes per second.

In the current version of Virtuozzo, the maximum I/O bandwidth limit you can set for a container is 2 GB per second.

The default I/O bandwidth limit for all newly created containers is set to 0, which means that no limits are applied to any containers.

 

Table 8. System Parameters
Parameter Description Typical value

NUMPROC

Number of processes and threads allowed. Upon hitting this limit, container will not be able to start a new process or thread.

40...400

AVNUMPROC

Number of processes expected to run in the container on average. This is informational parameter used to ensure configuration correctness.

0...NUMPROC

VMGUARPAGES

Memory allocation guarantee, in pages. Applications are guaranteed to be able to allocate memory while the amount of memory accounted as privvmpages does not exceed the configured barrier of the vmguarpages parameter. Above the barrier, memory allocation is not guaranteed and may fail in case of overall memory shortage.

1725...107520

LOCKEDPAGES

Memory not allowed to be swapped out (locked with the mlock() system call), in pages (one page is 4 KB).

4...4096

SHMPAGES

Total size of shared memory (including IPC, shared anonymous mappings and tmpfs objects), allocated by processes of a particular container, in pages.

512...16384

PRIVVMPAGES

Size of private (or potentially private) memory, allocated by an application. Memory that is always shared among different applications is not included in this resource parameter.

3072...151200- 3450...1612800

NUMFILE

Number of files opened by all container processes.

512...8192

NUMFLOCK

Number of file locks created by all container processes.

50...200-60...220

NUMPTY

Number of pseudo-terminals. For example, the ssh session, screen, the xterm application consumes pseudo-terminal resources.

4...64

NUMSIGINFO

Number of siginfo structures (essentially this parameter limits the size of signal delivery queue).

256...512

PHYSPAGES

Total size of RAM used by processes. This parameter is used for accounting purposes only. It shows the usage of RAM by the container. For memory pages used by several different containers (mappings of shared libraries, for example), only a fraction of a page is charged to each container. The sum of the physpages for all containers corresponds to the total number of pages used in the system by all accounted users.

Not limited

NUMIPTENT

The number of IP packet filtering entries.

12...128

Table 9. VSwap Parameters
Parameter Description Typical value

PHYSPAGES

Amount of RAM that can be used by the processes of a container, in 4KB pages.

 

SWAP

Amount of swap space that can be used by the container for swapping out memory once the RAM is exceeded, in 4KB pages.

 

VM_OVERCOMMIT

Memory overcommit factor that defines the memory allocation limit for a container. The limit is calculated as (PHYSPAGES + SWAP) * factor.

Not limited

Networking Parameters

Network-related parameters allow you to set bandwidth management parameters, hostname and IP addresses that a container can use, and other parameters.

Name Description

HOSTNAME

If this parameter is specified, then prlctl will set the hostname to its value upon the next container start. This parameter can be omitted. In this case, the container administrator should configure the hostname manually.

IP_ADDRESS

This is the list of IP addresses, which can be used on container network interfaces. This list is an argument of the container start call and it is impossible to assign IP address from inside the container if the address is not on the list. Any IP address assigned from within the container will be visible only within the container.

NAMESERVER

The IP address of the DNS server the container is supposed to use. More than one server can be specified in the space-separated format.

SEARCHDOMAIN

DNS search domains for the container. More than one domain can be specified.

NETDEV

The names of physical network adapters that have been moved from the server to the given container.

NETFILTER

Indicates which iptables modules are allowed for the container. If some of the allowed modules are not loaded on the destination Hardware Node after migration or restoration from backup, they will be automatically loaded on the migrated or restored container start. The following modes are available:

  • disabled: none.

  • stateless: (default) all modules except conntrack and NAT-related.

  • stateful: all modules except NAT-related.

  • full: all modules.

NETIF

Specifies a number of parameters for the virtual network adapters existing inside the container. These parameters include:

  • ifname: the name of the veth virtual Ethernet interface inside the container.

  • mac: the MAC address assigned to the veth virtual Ethernet interface inside the container.

  • host_mac: the MAC address assigned to the veth virtual Ethernet interface on the server.

  • network: the name of the virtual network where the veth virtual network adapter is included.

  • ip: the IP address(es) assigned to the veth virtual network adapter.

RATE

If traffic shaping is turned on, then this parameter specifies bandwidth guarantee, in Kbps, for the container. The parameters should be set in the form of eth0:1:8.

RATEBOUND

If set to yes, the bandwidth guarantee is also the limit for the container, and the container cannot borrow the bandwidth from the TOTALRATE bandwidth pool.

Linux Distribution Configuration Files

Some Virtuozzo tools (e.g., prlctl) need to run special scripts inside a container to perform certain operations on it. However, carrying out one and the same operation inside containers running different Linux versions may require execution of different actions. This may be caused by the fact that different Linux distributions store files in different locations, use different commands to complete one and the same task, and so on. To distinguish between containers running different Linux versions and to determine what scripts should be executed while performing the relevant container-related operations, Virtuozzo uses special distribution configuration files located in the /usr/libexec/libvzctl/dists directory on the server.

There are a number of distribution configuration files shipped with Virtuozzo by default (centos.conf, fedora-core.conf, gentoo.conf, etc.). To view all configuration files available on your Virtuozzo, you can go to the /usr/libexec/libvzctl/dists directory and issue the ls command. The distribution configuration files will be displayed in the form of <Linux_distribution>-<version>.conf where <Linux_distribution> and <version> denote the name of the Linux distribution and its version, respectively (e.g., centos-7.conf).

Any distribution configuration file consists of a number of entries in the form of <parameter_name>=<script_name> where <parameter_name> denotes the name of the parameter defining the operation when the script in the right part of the entry is to be executed and <script_name> is the name of the script to be run on performing the operation defined by the parameter in the left part of the entry. In the current version of Virtuozzo, the following parameters are used to define what scripts should be executed for the corresponding Linux version a container is running:

  • ADD_IP: the script specified as the value of this parameter has the default name of <distribution_name>-add_ip.sh and is used to configure the network settings during the container startup and the IP address(es) assignment. The script is launched inside the container on executing the following commands:

    prlctl start <CT_name>
    prlctl set <CT_name> --ipadd <IP_address>
    prlctl set <CT_name> --ipadd <IP_address> --ipdel all
  • DEL_IP: the script specified as the value of this parameter has the default name of <distribution_name>-del_ip.sh and is used to delete an existing IP address from the container. The script is launched inside the container on executing the following commands:

    prlctl set <CT_name> --ipdel <IP_address>
    prlctl set <CT_name> --ipdel all
  • SET_HOSTNAME: the script specified as the value of this parameter has the default name of <distribution_name>-set_hostname.sh and is used to configure the hostname of the container. The script is launched inside the container on executing the following command:

    prlctl set <CT_name> --hostname <name>
  • SET_DNS: the script specified as the value of this parameter has the default name of <distribution_name>-set_dns.sh and is used to configure DNS parameters in the /etc/resolv.conf file. The script is launched inside the container on executing the following command:

    prlctl set <CT_name> --searchdomain <domain> --nameserver <IP_address>
  • SET_USERPASS: the script specified as the value of this parameter has the default name of <distribution_name>-set_userpass.sh and is used to add a new user or change the current password. The script is launched inside the container on executing the following command:

    prlctl set <CT_name> --userpasswd <user>:<passwd>
  • SET_UGID_QUOTA: the script specified as the value of this parameter has the default name of <distribution_name>-set_ugid_quota.sh and is used to set up per-user/group quota. The script is launched inside the container on executing the following command:

    prlctl set <CT_name> --quotaugidlimit <num>
  • POST_CREATE: the script specified as the value of this parameter has the default name of <distribution_name>-postcreate.sh and is used to perform certain tasks (e.g., to modify the crontab files) after the container creation. This script is launched on the server on executing the following command:

    prlctl create <CT_name>
  • POST_MIGRATE: the script specified as the value of this parameter has the default name of <distribution_name>-post_migrate.sh and is used to perform certain operations on the container where the physical server has been successfully migrated. This script is launched inside the container on executing the following command:

    vzp2v [<options>] --ctid <CT_name>

The scripts specified in distribution configuration files are located in the /usr/libexec/libvzctl/dists/scripts directory on the server and executed on performing the aforementioned operations on the containers. After an operation has been initiated, the prlctl or vzp2v utility turns to the corresponding container configuration file, looks for the value of the DISTRIBUTION variable or, if the latter is not present, of the OSTEMPLATE variable in this file, and defines on their basis what Linux version the given container is running. After that, prlctl reads the corresponding configuration file for the determined Linux version from the /usr/libexec/libvzctl/dists/ directory and executes the scripts specified in this file.

Note

Note: If no distribution is specified as the value of the DISTRIBUTION and OSTEMPLATE variables in the container configuration file or no configuration file for the given Linux version was found in the /usr/libexec/libvzctl/dists directory, the default file from this directory is used.

Memory and IOPS Deduplication Configuration File

Contained in the /etc/vz/pfcache.conf file, memory and IOPS deduplication parameters allow you to tailor cache behavior and performance to your needs.

Table 10. Parameters
Name Description Default Value

COUNT

The minimum number of file copies required for the file to become cacheable. Copies may exist in the same container or different containers.

2

MINSIZE

Minimal cacheable file size, bytes. Files smaller than this value will not be cached.

0

MAXSIZE

Maximal cacheable file size, bytes. Files larger than this value will not be cached.

2147483648

TIMEOUT

Time between caching attempts, seconds.

5

PFCACHE_IOLIMIT

Memory and IOPS deduplication cache IO bandwidth limit, bps. Unlimited by default.

 

PFCACHE_IOPSLIMIT

Memory and IOPS deduplication cache IOPS limit. Unlimited by default.

 

LOGLEVEL

Logging verbosity. Messages are logged in the system log file /var/log/messages.

1

PAGEMIN

The total number of memory pages used in containers:

  • 0 - Cache even files without memory pages.

  • 1 - Cache only files in use.

  • N - Cache only when the total number of memory pages in containers reaches N.

1

PURGEAHEAD

Extra cache space to free up in addition to the requested space. In per cent of the requested space. Used with the pfcache purge --size command.

20%

Network Classes Definition File

In Virtuozzo, both traffic accounting and bandwidth management are based on network classes. The network classes’ definition file (/etc/vz/conf/networks_classes) describes network classes that Virtuozzo recognizes. Currently, there can be up to 15 classes defined.

The lines in this file have the following format:

<class_ID> <IP_address>/<prefix_length>

where <class_ID> defines the network class identifier, <IP_address> defines the starting IP address, and <prefix_length> defines the subnet mask. In pair <IP_address> and <prefix_length> define the range of IP addresses for this class. There may be several lines for each class. Classes should be defined after Class 1 and represent exceptions from the "matching-everything" rule of Class 1. Class 0 has a special meaning and defines the IP ranges for which no accounting is done (this server container addresses).

The definition of class 1 is required; any class except class 1 can be omitted. However, it is recommended to define class 0 correctly as it will improve performance. For example:

# HW node VPS's networks
0 10.10.10.0/24
0 10.10.15.0/24
# all IP("local" traffic)
1 0.0.0.0/0
# class 2 - "foreign" traffic
#2 10.0.0.0/8
#2 11.0.0.0/8
# inside "foreign" network there
# is a hole with "local" traffic
#1 10.10.16.0/24

Kernel Parameters

There is a number of kernel limits that should be set for the Virtuozzo software to work correctly. Virtuozzo is shipped with a tuned /etc/sysctl.conf file. Understanding what parameters were changed is essential for running the required number of containers. Below is the contents of the /etc/sysctl.conf file as shipped with Virtuozzo:

# Controls IP packet forwarding
net.ipv4.ip_forward = 1
# Controls source route verification
net.ipv4.conf.default.rp_filter = 1
# Do not accept source routing
net.ipv4.conf.default.accept_source_route = 0
# Controls the System Request debugging functionality of the kernel
kernel.sysrq = 1
# Controls whether core dumps will append the PID to the core filename.
# Useful for debugging multi-threaded applications.
kernel.core_uses_pid = 1
# Controls the use of TCP syncookies
net.ipv4.tcp_syncookies = 1
# Disable netfilter on bridges.
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
net.bridge.bridge-nf-call-arptables = 0
# Controls the default maxmimum size of a mesage queue
kernel.msgmnb = 65536
# Controls the maximum size of a message, in bytes
kernel.msgmax = 65536
# Controls the maximum shared segment size, in bytes
kernel.shmmax = 68719476736
# Controls the maximum number of shared memory segments, in pages
kernel.shmall = 4294967296
net.ipv6.conf.all.proxy_ndp=1
net.ipv4.conf.default.proxy_arp = 0
net.ipv4.conf.all.rp_filter = 0
fs.super-max = 2560
fs.file-max = 262144
kernel.fairsched-nodes-max = 1538
net.ipv4.neigh.default.gc_thresh2 = 2048
net.ipv4.neigh.default.gc_thresh3 = 4096
net.ipv4.conf.default.send_redirects = 0
net.ipv4.conf.all.send_redirects = 0
net.ipv6.neigh.default.gc_thresh2 = 2048
net.ipv6.neigh.default.gc_thresh3 = 4096
net.nf_conntrack_max = 500000
fs.aio-max-nr = 1048576

Notice that some parameters of the kernel configuration depends on the maximum number of containers you plan to run. In the default configuration file, these numbers were calculated under the assumption the maximum container number is 512. If you plan to run another number of containers, it is recommended to recalculate net.ipv4.neigh.default.gc_thresh2 and net.ipv4.neigh.default.gc_thresh3 parameters as three per container plus 128…​512. Keep the second parameter twice as great as the first one.

To apply the changes issue the following command:

# sysctl -p

Besides, it makes sense to set net.ipv4.tcp_use_sg to 0, since the corresponding "Scatter/gather IO" feature is not supported by the venet device, used in Virtuozzo networking.

It is also worth mentioning that normally you should have forwarding turned on since the server forwards packets destined to or originated from containers.

Offline Management Configuration Files

The offline management configuration files located in the /etc/vzredirect.d directory define various modes of container offline management by container administrators. One configuration file describes one offline management mode. In the current Virtuozzo version, two files are accessible: vzpp.conf and vzpp-plesk.conf. The first file defines the container offline management by means of Power Panel, and the second one by means of the same Power Panel with an integrated Plesk control panel.

There are two parameters in each of the files.

Format
<parameter_name>=<parameter_value>
Table 11. Parameters
Name Description Example

PORT

This port must be entered in the address line of an Internet browser after the container IP address when managing the container by means of Power Panel or the Plesk control panel.

PORT=8443

DST_VEID

The UUID of the container where the requests coming to the specified port will be redirected.

DST_VEID=1

vztt Configuration File

This file (/etc/vztt/vztt.conf) is the configuration file used by the vzpkg utility when managing OS and application EZ templates.

Format
<parameter_name>=<parameter_value>
Table 12. Parameters
Name Description

VZTT_PROXY

The IP address or hostname of the caching proxy server to be used by the vzpkg tool for managing OS and application EZ templates.

HTTP_PROXY

The IP address or hostname of the HTPP proxy server address, if you use this server.

HTTP_PROXY_USER

The user name used by the HTTP proxy server for your authentication.

HTTP_PROXY_PASSWORD

The password of the user specified in the HTPP_PROXY_USER parameter and used for your authentication by the HTTP proxy server.

METADATA_EXPIRE

Defines the period of time, in seconds, in the course of which the downloaded software packages in the vzpkg cache are regarded as not obsolete. During this time, the vzpkg utility searches for the EZ template packages in the local cache only (without checking the remote repositories set for EZ templates). By default, this period is set to 86400 seconds (24 hours).

EXCLUDE

List of comma-separated packages that are not to be installed or updated during the vzpkg execution. The package names should correspond to the name of real packages in the repository and can contain file globs (e.g., * and ?).

pcompact.conf

The /etc/vz/pcompact.conf file is used by the pcompact utility to compact virtual disks in containers.

Format
<parameter_name>=<parameter_value>
Table 13. Parameters
Name Description

THRESHOLD=<number>

Compact the virtual disk if unused space on it exceeds THRESHOLD percent of the ploop size.

DELTA=<number>

Reduce disk space to be compacted by DELTA percent of the ploop size.

DEFRAG=<yes¦no>

Perform or skip file system defragmentation.

Virtuozzo Utilities

This section provides information on utilities that can be used to manage Virtuozzo parameters.

prlsrvctl

The prlsrvctl command-line utility is used to perform management tasks on the hardware node and Virtuozzo. The tasks include getting the Virtuozzo information, modifying its preferences, installing a license, obtaining statistics and problem reports, and some others.

Syntax
prlsrvctl [<command> [<options>]
          [-l, --login [<user>[:<passwd>]@]<server>[:<port>]]]
Table 14. Options
Name Description

<command>

The command to execute.

<options>

Command options. See individual commands for available options.

-l, --login

Connect to the remote hardware node and execute a command there. If this parameter is omitted, the command will be executed on the local server.

<user>

The name of the user used to log in to the remote server.

<passwd>

The user password. If the password is omitted, you will be prompted to enter it.

<server>:<port>

The remote server IP address or hostname and port number, If port number is omitted, the default port will be used.

Note

Note: To display help, enter prlsrvctl on the command-line without any options.

prlsrvctl backup

The command is used to back up all virtual environments on the node.

Syntax
prlsrvctl backup [-f,--full] [-i,--incremental]
		 [-s,--storage <user>[:<password>]@<server>[:<port>]]
		 [--description <desc>] [-u,--uncompressed]
Table 15. Options
Name Description

-f,--full

Creates a full backup of each virtual environment on the node. A full backup contains all the virtual environment data.

-i,--incremental

Creates an incremental backup of each virtual environment on the node. An incremental backup contains only the files that were changed since the previous full or incremental backup. This is the default backup type.

-s,--storage <user>[:<password>]
@<server>[:<port>]

The host to store backup images at.

--description <desc>

Adds a description to each virtual environment backup.

-u,--uncompressed

Does not compress backup images.

prlsrvctl info

Displays the hardware node and Virtuozzo configuration information.

Syntax
prlsrvctl info

The information returned by the info command includes the following:

  • Server ID and hostname.

  • Virtuozzo version number.

  • Default directory for storing virtual machine files.

  • Virtuozzo memory limits.

  • Virtuozzo minimum allowable security level.

  • Default directory for storing virtual machine backups.

  • Virtuozzo license information.

  • Server hardware configuration information.

  • Other miscellaneous info.

prlsrvctl net

The prlsrvctl net command is used to create and configure virtual networks.

Table 16. Subcommands
Name Description

net add

Creates a new virtual network

net set

Configures the parameters of an existing virtual network.

net del

Removes an existing virtual network.

net list

List the available virtual networks.

net add

Creates a new virtual network.

Syntax
prlsrvctl net add <vnetwork_ID> [-i, --ifname <if>] [-m, --mac <mac_address>]
                  [-t, --type <bridged|host-only>] [-d, --description <desc>]
                  [--ip <IP_address>[/<mask>]] [--dhcp-server <on|off>]
                  [--dhcp-ip <IP_address>] [--ip-scope-start <IP_address>]
                  [--ip-scope-end <IP_address>] [--ip6 <IP_address>[/<mask>_]]
                  [--dhcp6-server <on|off>] [--dhcp-ip6 <IP_address>]
                  [--ip6-scope-start <IP_address>] [--ip6-scope-end <IP_address>]
Table 17. Options
Name Description

<vnetwork_ID>

A user-defined name that will identify the new virtual network.

-i, --ifname <if>

The name of a physical network adapter on the hardware node to which this virtual network should be bound.

-m, --mac <mac_address>

The MAC address of a virtual network adapter on the hardware node to which this virtual network should be bound.

-t, --type <bridged¦host-only>

The type of the virtual network to create. Possible values are:

  • bridged. A  virtual machine and container connected to this type of virtual network appears as an independent computer on the network.

  • host_only (default). A virtual machine and container connected to this type of virtual network can access only the hardware node and the virtual machines and containers connected to the same virtual network.

-d, --description <desc>

A user-defined description of the virtual network. Descriptions with white spaces must be enclosed in quotation marks.

--ip <IP_address>[/<mask>]
--ip6 <IP_address>[/<mask>]

Set an IPv4/IPv6 address and subnet mask for the Virtuozzo virtual adapter.

--dhcp-server <on¦off>
--dhcp6-server <on¦off>

Enable or disable the Virtuozzo virtual DHCPv4/DHCPv6 server.

--dhcp-ip <IP_address>
--dhcp-ip6 <IP_address>

Set an IPv4/IPv6 address for the Virtuozzo virtual DHCPv4/DHCPv6 server.

--ip-scope-start <IP_address>
--ip-scope-end <IP_address>
--ip6-scope-start <IP_address>
--ip6-scope-end <IP_address>

Set the starting and ending IPv4/IPv6 addresses for the DHCPv4/DHCPv6 pool. The virtual machines and containers connected to the network you are creating will automatically receive their IPv4/IPv6 addresses from the respective DHCPv4/DHCPv6 pool.

net set

Configures the settings of an existing virtual network.

Syntax
prlsrvctl net set <vnetwork_ID> [-i, --ifname <if>] [-m, --mac <mac_address>]
                  [-t, --type <bridged|host-only>] [-d, --description <desc>]
                  [--ip <IP_address>[/<mask>]] [--dhcp-server <on|off>]
                  [--dhcp-ip <IP_address>] [--ip-scope-start <IP_address>]
                  [--ip-scope-end <IP_address>] [--ip6 <IP_address>[/<mask>_]]
                  [--dhcp6-server <on|off>] [--dhcp-ip6 <IP_address>]
                  [--ip6-scope-start <IP_address>] [--ip6-scope-end <IP_address>]
Table 18. Options
Name Description

<vnetwork_ID>

The name of the virtual network to modify.

-i, --ifname <if>

The name of a physical network adapter on the hardware node to which this virtual network should be bound.

-m, --mac <mac_address>

The MAC address of a virtual network adapter on the hardware node to which this virtual network should be bound.

-t, --type <bridged¦host-only>

The type of the virtual network to modify. Possible values are:

  • bridged. A  virtual machine and container connected to this type of virtual network appears as an independent computer on the network.

  • host_only (default). A virtual machine and container connected to this type of virtual network can access only the hardware node and the virtual machines and containers connected to the same virtual network.

-d, --description <desc>

A user-defined description of the virtual network. Descriptions with white spaces must be enclosed in quotation marks.

--ip <IP_address>[/<mask>]
--ip6 <IP_address>[/<mask>]

Set an IPv4/IPv6 address and subnet mask for the Virtuozzo virtual adapter.

--dhcp-server <on¦off>
--dhcp6-server <on¦off>

Enable or disable the Virtuozzo virtual DHCPv4/DHCPv6 server.

--dhcp-ip <IP_address>
--dhcp-ip6 <IP_address>

Set an IPv4/IPv6 address for the Virtuozzo virtual DHCPv4/DHCPv6 server.

--ip-scope-start <IP_address>
--ip-scope-end <IP_address>
--ip6-scope-start <IP_address>
--ip6-scope-end <IP_address>

Set the starting and ending IPv4/IPv6 addresses for the DHCPv4/DHCPv6 pool. The virtual machines and containers connected to the network you are creating will automatically receive their IPv4/IPv6 addresses from the respective DHCPv4/DHCPv6 pool.

net del

Deletes an existing virtual network.

Syntax
prlsrvctl net del <vnetwork_ID>
Table 19. Options
Name Description

<vnetwork_ID>

The name of the virtual network to delete.

net list

Lists the existing virtual networks.

Syntax
prlsrvctl net list
prlsrvctl problem-report

Generates and displays problem reports.

Syntax
prlsrvctl problem-report

The command collects technical data about Virtuozzo and the hardware node and displays the report on screen (the output can also be piped to a file). The report can then be directed to the Virtuozzo technical support team for analysis.

prlsrvctl set

Configures Virtuozzo preferences.

Syntax
prlsrvctl set [--mem-limit <auto>|<size>]
              [-s, --min-security-level <low|normal|high>]
              [-c, --cep <on|off>] [--mng-settings <allow|deny>]
              [--device <device> --assignment <host|vm>_]
              [--backup-storage [<user>[:<passwd>]@]<server>[:<port>]]
              [--backup-tmpdir <tmp_dir>] [--backup-path <path>]
              [--idle-connection-timeout <timeout>]
              [--verbose-log <on|off>] [--cluster-mode <on|off>]
              [--cpu-features-mask <{+|-}feature1,feature2=value[,...]>]
              [--vm-cpulimit-type <full|guest>]
Table 20. Options
Name Description

--mem-limit {auto¦<size>}

Sets the upper limit of the memory size that can be reserved for use by virtual machines. The following options are available:

  • auto - if this option is used, the memory size will be calculated automatically.

  • size - user-defined memory size, in megabytes.

-s, --min-security-level <low¦normal¦high>

The lowest allowable security level that can be used to connect to the hardware node. The following options are available:

  • low - plain TCP/IP (no encryption).

  • normal - most important data is sent and received using SSL over TCP/IP (user credentials during login, guest OS clipboard, etc.) Other data is sent and received using plain TCP/IP with no encryption.

  • high - all of the data is sent and received using SSL.

-c, --cep <on¦off>

Enables/disables the participation in the Customer Experience Program (CEP). The following options are available:

  • on - enables CEP.

  • off - disables CEP.

--mng-settings <allow¦deny>

Allows to grant or deny permission to new users to modify Virtuozzo preferences. By default, only administrators of the host OS can modify Virtuozzo preferences. When a new user profile is created (this happens when a user logs in to the hardware node for the first time), he/she will be granted or denied this privilege based on the default setting. This parameter allows you to set that default setting. Please note that this parameter only affects new users (the users that will be created in the future). The profiles of the existing users will not be modified.

--device <device> --assignment <host¦vm>

Allows to set the assignment mode for the specified VTd device. The following options are available:

  • host - assign the device to the hardware node.

  • vm - assign the device to virtual machines.

--backup-storage [<user>[:<passwd>]@]<server>[:<port>]

The default backup server where to store virtual machine backups.

--backup-path <path>

The name and path of the default directory on the backup server where to store virtual machine backups.

--verbose-log <on¦off>

Turns the verbose output for the command on or off.

--cluster-mode <on¦off>

Turns the cluster mode on or off.

--idle-connection-timeout <timeout>

Sets a timeout interval in seconds after which, if no data has been received from the storage server or backup client, the process of backup/restore is terminated.

--backup-tmpdir <tmp_dir>

Specifies a temporary directory where special snapshots created during virtual machine backup will be stored. This may be necessary so as not to run out of storage space on physical servers where most of the storage space is allocated to virtual machines and very little is left for the server itself.

--cpu-features-mask <{+¦-}feature1,feature2=value[,…​]>

Changes CPU features mask on the host. To mask/unmask features, use the +feature/-feature syntax respectively. Omitting the sign is equvalent to unmasking. Features that require specific value can be set using the feature=value syntax. To view a full list of host CPU features which are supported, unmaskable and already masked, run the prlsrvctl info --full command.

Note

Note: All virtual machines and containers on the host must be stopped.

--vm-cpulimit-type <full¦guest>

Specifies the type of virtual machine threads to be affected by the CPU limit:

  • full (default) - both hardware emulation and guest OS threads are limited.

  • guest - only guest OS threads are limited.

With the guest option, the guest OS is guaranteed to have all the resources implied by the VM configuration. At the same time, the VM’s hardware emulation threads spend additional resources of the host. For example, for a VM with two 2.8 GHz vCPUs, switching to guest means that VM’s guest applications will have all the resources of two 2.8 GHz vCPUs at their disposal.

Note

Notes:

  1. Some types of guest applications, like voice-over-IP software, significantly increase expenses on hardware emulation threads.

  2. After changing this parameter, restart running virtual machines for the changes to take effect.

prlsrvctl shutdown

Shuts down the Virtuozzo component responsible for managing virtual machines and containers. No operations on virtual machines and containers are possible.

Syntax
prlsrvctl shutdown [-f, --force]
Table 21. Options
Name Description

-f, --force

Specifies whether the shutdown operation should be forced. If one or more virtual machines and containers are running, clients are connected, or some tasks are currently in progress, then forcing the shutdown will stop all processes automatically and will shut down the Virtuozzo component.

prlsrvctl usb

The prlsrvctl usb command is used to permanently assign a USB device to a specific virtual machine. A permanently assigned USB device will be connected to the virtual machine automatically on server restart. This functionality works only with virtual machines (not containers).

Table 22. Subcommands
Name Description

usb list

Lists USB devices connected to the server together with the information about their virtual machine assignments for the current user.

usb set

Permanently assigns a USB device to the specified virtual machine.

usb del

Removes a previously created USB device assignment.

usb list

Lists the USB devices connected to the physical server.

Syntax
prlsrvctl usb list

Returns a list of USB devices in tabular format with the following columns:

  • Name - the USB device name.

  • ID - a string that uniquely identifies the USB devices on the physical server. The ID never changes even if the device is disconnected from the server and then reconnected again. Please note that if a device ID is listed in quotes, they are a part of the ID and must be included in other calls that use it as an input parameter.

  • VM UUID - a universally unique ID of the virtual machine to which this USB device is permanently assigned. If a USB device is not assigned to any virtual machine, this column will be empty.

usb set

Permanently assigns a USB device to the specified virtual machine. A permanently assigned USB device will be connected to the virtual machine automatically on server restart. The USB device assignment is performed for the current user only. Other users may create their own USB device assignments. This functionality works only with virtual machines (not containers).

Syntax
prlsrvctl usb set <usb\_dev\_ID> <VM_name>
Table 23. Options
Name Description

<usb_dev_ID>

The USB device ID. To obtain the list of USB devices connected to the server use the usb list command.

<VM_name>

The name of the virtual machine to which to assign the USB device.

usb del

Deletes a USB device assignment previously created with the usb set command. The USB device assignment is performed on the user level, so if you remove an assignment, it will only be removed for the current user. Other users may have their own USB devices assignments, which will not be affected.

Syntax
prlsrvctl usb del <usb_dev_ID>
Table 24. Options
Name Description

<usb_dev_ID>

The USB device ID. To see the current USB device assignments for the current user use the usb list command.

prlsrvctl user list

Displays the list of Virtuozzo users. Only those users are displayed who has created at least one virtual machine and container.

Syntax
prlsrvctl user list [-o, --output <name|mng_settings|def_vm_home>]
Table 25. Options
Name Description

-o, --output <name¦mng_settings¦def_vm_home>

Fields to include in the output. The following fields are available:

  • name - User name.

  • mng_settings - Indicates whether the user is allowed to modify Virtuozzo preferences.

  • def_vm_home - The user default virtual machine folder.

The fields must be specified in lowercase.

prlsrvctl user set

Configures the profile of the user currently logged in to the Virtuozzo server.

Syntax
prlsrvctl user set [--def-vm-home <path>]
Table 26. Options
Name Description

--def-vm-home <path>

The default virtual machine and container directory name and path.

prlsrvctl privnet

The prlsrvctl privnet command is used to manage private networks on physical servers.

Table 27. Subcommands
Name Description

add

Creates a new private network.

set

Configures the parameters of an existing private network.

del

Removes an existing private network.

list

Lists the available private networks.

add

Creates a new private network.

Syntax
prlsrvctl privnet add <private_network_ID> [-a, --ipadd <addr>[/<mask>]]
                      [--global <yes|no>]
Table 28. Options
Name Description

<private_network_ID>

The private network ID.

-a, --ipadd <addr>[/<mask>]

Add a subnet to the private network. The network can have multiple subnets.

--global <yes¦no>

Make the private network weak, allowing access to and from external networks.

set

Configures an existing private network.

Syntax
prlsrvctl privnet set <private_network_ID> [-a, --ipadd <addr>[/<mask>]]
                      [-d, --ipdel <addr>[/<mask>]] [--global <yes|no>]
Table 29. Options
Name Description

<private_network_ID>

The private network ID.

a, --ipadd <addr>[/<mask>]

Add a subnet to the private network. The network can have multiple subnets.

-d, --ipdel <addr>[/<mask>]

Delete the specified subnet from the private network.

--global <yes¦no>

Make the specified private network weak, allowing access to and from external networks.

del

Deletes a private network from the physical server.

Syntax
prlsrvctl privnet del <private_network_ID>
Table 30. Options
Name Description

<private_network_ID>

The ID of the private network to delete.

list

Lists the private networks that exist on the physical server.

Syntax
prlsrvctl privnet list

Virtuozzo Updates

Virtuozzo allows quick and easy updates with the yum utility standard for RPM-compatible Linux operating systems. For more information on yum, See Updating Virtuozzo in the Virtuozzo 7 User’s Guide and the yum manual page.

Managing containers

Virtuozzo containers can be managed using the prlctl command-line utility. The utility is installed on the hardware node during the product installation.

Matrix of Virtuozzo Command-Line Utilities

The table below contains the full list of Virtuozzo command-line utilities and command you can use for managing containers.

Table 31. General Utilities
Name Description

prlctl

Utility to control containers.

prlctl list

Utility to view a list of containers existing on the server with additional information.

Table 32. Container Migration Utilities
Name Description

prlctl clone

Command for the local cloning of containers.

Table 33. Container Backup Utilities
Name Description

prlctl backup

Command to back up individual containers.

prlctl restore

Command to restore individual containers.

Table 34. Template Management Utilities
Name Description

vzpkg

Utility to manage OS and application EZ templates either inside your containers or on the server itself.

Table 35. Supplementary Utilities
Name Description

vzps, vztop

Utilities working as the standard ps and htop utilities, with container-related functionality added.

vzpid

Utility that prints container UUID the process belongs to.

vzsplit

Utility to generate container configuration file sample, "splitting" the server into equal parts.

pfcache

Memory and IOPS deduplication management utility.

pcompact

Utility to compact containers by removing unused blocks from their virtual disks.

prlctl

prlctl is the primary tool for container management. To use it, you have to log in to the server as the root user.

Syntax
prlctl <subcommand> <CT_name>
prlctl --version
prlctl --help
Table 36. Subcommands
Name Description

create

Creates a new container.

delete

Deletes a container.

mount

Mounts the container private area and executes the container mount script.

umount

Unmounts the container private area and executes the unmount script.

start

Starts a container.

stop

Stops a container.

restart

Restarts a container.

status

Displays the container status.

set

Sets container parameters: resource control settings, hostname, IP addresses, and so on.

enter

Logs in to a container without knowing its root password.

exec

Runs arbitrary commands in a container without logging in to it.

suspend

Saves the state of a running container in a dump file.

resume

Restores a container from its dump file.

snapshot
snapshot-list
snapshot-switch
snapshot-delete

Creates and manages container snapshots.

console

Creates a command prompt channel to a container.

Table 37. Options
Name Description

--version

Displays the prlctl package version currently installed on the server.

--help

Displays the usage information about prlctl.

prlctl console

Creates a command prompt channel to a container. Allows to log in to and execute commands in running containers; provides container startup/shutdown information that may be used for troubleshooting purposes. Logging in to containers requires a virtual terminal (e.g., mingetty) to be installed in the container.

Note

Note: To exit the console, press Esc and then . (period).

Syntax
prlctl console <CT_name>
Table 38. Options
Name Description

<CT_name>

Container name.

prlctl create

This command is used to create new containers.

Syntax
prlctl create <CT_name> --vmtype ct [<options>]

With this command, you can create regular containers. A unique container name is required for this command.

Table 39. Options
Name Description

<CT_name>

An arbitrary name to assign to the new container.

--vmtype ct

Tells the prlctl create command to make a container. If the option is omitted, a virtual machine is created instead.

--ostemplate <name>

OS EZ template to use for creating the container. If omitted, this value is taken from the DEF_OSTEMPLATE parameter in the global Virtuozzo configuration file.

--config <name>

Container sample configuration file to use for creating the container. Sample configuration files are located in /etc/vz/conf and have names in the format ve-<name>.conf-sample. The sample configuration files usually have a number of resource control limits for the container and some application templates to be added to the container immediately upon its creation. If you skip this option and the default configuration file name is not specified in the global Virtuozzo configuration file, you will have to set resource control parameters for the container using the prlctl set command.

--uuid <uuid>

A custom UUID to assign to the container.

prlctl delete

Deletes a container from the server.

Syntax
prlctl delete <CT_name>
Table 40. Options
Name Description

<CT_name>

Container name.

When executed, prlctl delete physically removes all the files located in the container private area (specified as the VE_PRIVATE variable in the container configuration file) and renames the container configuration file in /etc/vz/conf from <CT_name>.conf to <CT_name>.conf.destroyed. It also renames container action scripts, if any, in a similar manner.

Note

Note: A container must be stopped before its private area can be unmounted.

prlctl exec, enter

Allow running arbitrary commands in a container.

Syntax
prlctl exec <CT_name> [--without-shell] <command>
prlctl enter <CT_name>

where <command> is a string to be executed in the container. If <command> is specified as -, then the commands for execution will be read from the standard input until the end of file or exit is encountered.

Table 41. Options
Name Description

<CT_name>

Container name.

--without-shell

Run commands directly without bash or cmd shell.

When using prlctl exec, remember that the shell parses the command-line and, if your command has shell metacharacters in it, you should escape or quote them.

The prlctl enter command is similar to prlctl exec /bin/bash. The difference between the two is that prlctl enter makes the shell interpreter believe that it is connected to a terminal. As such, you receive a shell prompt and are able to execute multiple commands as if you were logged in to the container.

prlctl mount, umount

The prlctl mount command mounts the container private area to the container root directory (/vz/root/<CT_name> on the server) without starting it. Normally, you do not have to use this command as the prlctl start command mounts the container private area automatically.

The prlctl umount command unmounts the container private area. Usually, there is no need in using this command either because prlctl stop unmounts the container private area automatically.

Syntax
prlctl mount  <CT_name>
prlctl umount <CT_name>
Table 42. Options
Name Description

<CT_name>

Container name.

prlctl move

Moves container’s private area to a new location on the same server. The container can be stopped, suspended or running.

Syntax
prlctl move <CT_name> --dst=<path>
Table 43. Options
Name Description

<CT_name>

Container name.

--dst=<path>

Path to container’s new private area.

prlctl problem-report

Generates a problem report for the specified container and either sends it to the Virtuozzo technical support team or displays it on the screen.

Syntax
prlctl problem-report <CT_name> <-d, --dump|-s, --send  [--proxy [<user> \
                      [:<passwd>]@<proxyhost>[:<port>]]] [--no-proxy]>
Table 44. Options
Name Description

<CT_name>

The name of the container for which to generate the problem report.

-d, --dump

Collect technical data about the specified container and display it on the screen. You can also pipe the output to a file and then send it to the Virtuozzo technical support team to analyze your problem.

-s, --send

Send the generated problem report to the Virtuozzo technical support team.

--proxy [<user>[:<passwd>]@ \
<proxyhost>[:<port>]]

Use the specified information to send the generated report through a proxy server, if you use one to connect to the Internet.

--no-proxy

Do not use a proxy server to send the generated report. This is the default behavior, so you can omit this parameter.

prlctl register, unregister

The register command is used to register a container with Virtuozzo.

The unregister command removes a container from the Virtuozzo registry.

Syntax
prlctl register <path> [--preserve-uuid <yes|no>]
prlctl unregister <CT_name>
Table 45. Options
Name Description

<path>

Full path to the container directory.

<CT_name>

The name of the container to remove from the Virtuozzo registry.

--preserve-uuid <yes¦no>

Specifies what to do with the container UUID (universally unique identifier). If you specify yes, the UUID is preserved. If you specify no, the UUID is regenerated.

Note

Note: By default, UUIDs are regenerated.

  • Use the register command when you have a container on the server that does not show up in the list of the containers registered with the Virtuozzo. This can be a container that was previously removed from the registry or that was copied from another location.

  • The unregister command removes a container from the Virtuozzo registry, but does not delete the container files from the server. You can re-register the container later using the register command.

prlctl reinstall

Recreates a container from scratch according to its configuration file. Copies old private area content to the /vz/root/<CT_name>/old directory.

Syntax
prlctl reinstall <CT_name> [--skipbackup] [--resetpwdb] [--scripts <script> [...]]
prlctl reinstall <CT_name> [--listscripts] [--desc]
Table 46. Options
Name Description

<CT_name>

Container name.

--resetpwdb

Removes container’s user database and creates a clean database as for any new installation.

--skipbackup

Does not save the old private area contents to the /old directory.

--scripts <script>[…​]

Specifies the scripts to be executed during reinstallation. These scripts are used to customize application templates in the new container and bring them to the same state as in the old container. By default, all available scripts are executed.

--listscripts

Lists the scripts to be executed during container reinstallation.

--desc

Displays the description of the scripts to be executed during container reinstallation. Used together with the --listscripts option.

Note

Note: Currently, the reinstall command may not be supported by the prlctl utility. Use vzctl instead.

prlctl set

This command is used for setting container parameters.

Syntax
prlctl set <CT_name> <option> <value>

where <CT_name> is container name.

The command options specified in this file can be subdivided into the following categories:

  • miscellaneous

  • networking

  • resource management

  • hard disk drive management

General Options

The table below lists the general options you can use with prlctl set.

Name Description

--onboot <yes¦no>

Set to yes to have Virtuozzo automatically start this container on next system startup.

--offline_management <yes¦no>

Enabling/disabling the direct managing of the container through a common Internet browser by means of Power Panels and the Plesk control panel (as defined by the OFFLINE_SERVICE parameter in the global or container configuration file).

--offline_service <service_name>

Defines whether the container can be managed by means of Power Panel or Plesk or both. Valid only if the OFFLINE_MANAGEMENT parameter is set to yes. The names of the available services can be taken from the file names (excluding the .conf extension) in the /etc/vzredirect.d directory on the server.

--userpasswd <user>:<password>

This setting creates a new user with the specified password in the container, or changes the password of an already existing user. This command modifies not the container configuration file, but the /etc/passwd and /etc/shadow files inside the container. In case the container root is not mounted, it is automatically mounted to apply the changes and then unmounted.

--crypted

Used with --userpasswd. Indicates that the specified password is already a hash.

--features {<name>:on¦off}

Enables/disables the support for the following functionality inside the container:

  • nfs: mounting NFS shares

  • ipip: creating IPIP tunnels

  • sit: using the Simple Internet Transition (SIT) mechanisms

  • ipgre: creating IP-GRE tunnels

  • bridge: using bridges to connect virtual Ethernet devices

  • nfsd: running an NFS-kernel-space server

--name <new_name>

Changes the container name. You can change the names of both stopped and running containers.

--description <desc>

Custom container description. Descriptions must be alphanumeric. Descriptions with white spaces must be enclosed in quotation marks.

--vnc-mode <auto¦manual¦off>

Enables or disables access to the container via the VNC protocol.

--vnc-port <port>

Sets the VNC port number for the container. Used with --vnc-mode manual.

--vnc-passwd <passwd> ¦ --vnc-nopasswd

Sets the VNC password for the container or specifies that no password is needed for VNC connections. Either of these options is mandatory for any VNC setup.

--autocompact <on¦off>

Enables or disables compaction for all disks in the container.

Note

Note: For details on how to enable or disable compaction for a specific disk in the container, see [_hard_disk_drive_management_options].

Resource Management Options

Resource management options control the amount of resources a container may consume. If the setting has bar:lim after it than this setting requires specifying both barrier and limit values separated by colons.

Name Description

--applyconfig <name>

This option lets you set the resource parameters for the container not one by one, but by reading them from the container sample configuration file. All container sample configuration files are located in the /etc/vz/conf directory and are named according to the following pattern: ve-<name>.conf-sample, so you should specify only the <name> part of the corresponding sample name after the --applyconfig option. Note that the names of sample configuration files cannot contain spaces. The --applyconfig option applies all the parameters from the specified sample file to the given container, except for the OSTEMPLATE, TEMPLATES, VE_ROOT, VE_PRIVATE, HOSTNAME, IP_ADDRESS, TEMPLATE, NETIF parameters (if they exist in the configuration sample file).

--cpuunits <units>

CPU weight. This is a positive integer number that defines how much CPU time the container can get as compared to the other virtual machines and containers running on the server. The larger the number, the more CPU time the container can receive. Possible values range from 8 to 500000. If this parameter is not set, the default value of 1000 is used.

--cpulimit {<percent>¦<megahertz>}

CPU limit, in per cent or megahertz (MHz), the container is not allowed to exceed. This parameter is not set for newly created containers; so they can consume all free CPU power of the server. By default, the limit is set in percent. To set the limit in MHz, specify m after the value. When setting this parameter in per cent, keep in mind that one CPU core makes up 100%. So if the server has 4 CPU cores, the total CPU power will equal 400%.

--cpus <num>

Number of CPU cores defining the CPU limit for a container. The limit is calculated by multiplying the power of one CPU core by the number of the specified CPU cores. This option also defines the number of CPUs shown to container users. This parameter is not set for newly created containers; so they can consume all free CPU power of the server.

--cpumask <num>

CPU affinity mask. This mask defines the CPUs on the server that can be used to handle the processes running in the container. The CPU mask can be specified as both separate CPU index numbers (1,2,3) and CPU ranges (2-4,5-7).

--nodemask {<num>¦all}

The NUMA node mask defining a NUMA node to bind the container to. Once you set the mask, the processes running in the container will be executed only on the CPUs that belong to the specified NUMA node.

--diskspace <amount>

Total disk space consumed by the container, in megabytes. You can use the following suffixes to specify measurement units:

  • G for gigabytes

  • M for megabytes

  • K for kilobytes

  • B for bytes

--quotaugidlimit {<0¦<N>}

Enables (if set to a value other than 0) or disables (if set to 0) per-user/group quotas for further management with the standard Linux quota utility. Keep in mind the following:

  • Enabling per-user and per-group quotas for a container requires restarting the container.

  • If you delete a registered user but some files with their ID continue residing inside your container, the current number of UGIDs (user and group identities) inside the container will not decrease.

  • If you copy an archive containing files with user and group IDs not registered inside your container, the number of UGIDs inside the container will increase by the number of these new IDs.

--ioprio <num>

The container priority for disk I/O operations. The allowed range of values is 0-7. The greater the priority, the more time the container has for writing to and reading from the disk. The default container priority is 4.

--iolimit <num>

The bandwidth a container is allowed to use for its disk input and output (I/O) operations. By default, the limit is set in megabytes per second. You can use the following suffixes to specify measurement units:

  • G: sets the limit in gigabytes per second

  • M: sets the limit in megabytes per second

  • K: sets the limit in kilobytes per second

  • B: sets the limit in bytes per second

In the current version of Virtuozzo, the maximum I/O bandwidth limit you can set for a container is 2 GB per second. The default I/O bandwidth limit for all newly created containers is set to 0, which means that no limits are applied to any containers.

--iopslimit <num>

The maximum number of disk input and output operations per second a container is allowed to perform. By default, any newly created container does not have the IOPS limit set and can perform so many disk I/O operations per second as necessary.

--rate <class>:_<Kbits>_

If traffic shaping is turned on, then this parameter specifies bandwidth guarantee for the container. The format is <class>_:_<Kbits>_ where <class> is the network class (group of IP addresses) and <Kbits> is the traffic bandwidth.

--ratebound <yes¦no>

If set to "yes", the bandwidth guarantee is also the limit for the container and the container cannot borrow the bandwidth from the TOTALRATE bandwidth pool.

--memsize <size>

The amount of RAM that can be used by the processes of a container, in megabytes. You can use the following suffixes to specify measurement units:

  • G for gigabytes

  • M for megabytes

  • K for kilobytes

  • B for bytes

--memguarantee <size>

Sets a percentage of container’s RAM that said container is guaranteed to have. By default, set to 0%.

--swappages <pages>

The amount of swap space that can be used by the container for swapping out memory once the RAM is exceeded, in 4KB pages. You can use the following suffixes to specify measurement units:

  • G for gigabytes

  • M for megabytes

  • K for kilobytes

  • B for bytes

--swap <size>

The amount of swap space that can be used by the container for swapping out memory once the RAM is exceeded, in bytes. You can use the following suffixes to specify measurement units:

  • G for gigabytes

  • M for megabytes

  • K for kilobytes

  • B for bytes

Network Options

Network-related options allow you to set the hostname, the domain to search when a not fully qualified domain name is used, the DNS server address and the IP addresses (both IPv4 and IPv6) that container can use, and other parameters.

Name Description

--hostname <name>

Sets the hostname to the specified name.

--ipadd <addr>

Adds an IP address to a list of IP addresses the container can use and brings up the network interface with this address inside the container. If used with the --ifname option, adds an IP address to the specified container virtual network adapter.

--ipadd <addr>/<net_mask>

Assigns the IP address and network mask to the container.

Note

Note: You can assign network masks to containers operating in the venet0 networking mode only if the USE_VENET_MASK parameter in the Virtuozzo containers configuration file is set to yes.

--ipdel {<addr>¦all}

Allows you to revoke IP address from the container. If "all" is used instead of IP address than all IP addresses will be revoked. If used with the --ifname option, deletes an IP address from the specified container virtual network adapter.

--nameserver <addr>

The DNS server IP address for the container. If used with the --ifname option, sets the DNS server for the specified container virtual network adapter.

--searchdomain <domain>

The DNS search domain for the container. More than one domain may be specified.

--netfilter <disabled¦stateless¦stateful¦full>

Indicates which iptables modules are allowed for the container. If some of the allowed modules are not loaded on the destination Hardware Node after migration or restoration from backup, they will be automatically loaded on the migrated or restored container start. The following modes are available:

  • disabled: none.

  • stateless: (default) all modules except conntrack and NAT-related.

  • stateful: all modules except NAT-related.

  • full: all modules.

--netif_add <name>[, <MAC>, <host_MAC>]

Creates a new veth virtual network adapter and assigns the name of <name> to the Ethernet interface inside the container. Along with the Ethernet interface name inside the container, you can set the following parameters when creating the veth adapter:

  • <MAC>: the MAC address to be assigned to the veth Ethernet interface inside the container.

  • <host_MAC>: the MAC address to be assigned to the veth Ethernet interface on the server.

Only the Ethernet interface name (<name>) is mandatory; all the other parameters, if not specified, are automatically generated by Virtuozzo during the veth adapter creation.

--netif_del <name>

Removes the veth virtual network adapter with the specified name from the container.

--ifname <name>

Specifies the name of the veth virtual network adapter whose settings are to be configured. This option can be used along with one of the following options: --ipadd, --ipdel, --nameserver, --gw, --network, --dhcp, --mac, --host_mac.

--mac <addr>

The MAC address to be assigned to the veth virtual Ethernet interface inside the container. Should be used along with the --ifname option.

--host_mac <addr>

The MAC address to be assigned to the veth virtual Ethernet interface on the server. Should be used along with the --ifname option.

--host_ifname <name>

The name to be assigned to the veth virtual Ethernet interface on the server. Should be used along with the --ifname option.

--network <network_ID>

Connects the veth virtual network adapter to the bridge associated with the specified network ID. Should be used along with the --ifname option. You can also use this option to disconnect the veth virtual network adapter from the bridge. To this effect, you should specify "" after the option.

--dhcp <yes¦no>

Specifies whether the virtual network adapter should obtain the IPv4 settings through a DHCP server.

--dhcp6 <yes¦no>

Specifies whether the virtual network adapter should obtain the IPv6 settings through a DHCP server.

--gw <gw>

The default gateway to be used by the container.

--gw6 <gw>

The default IPv6 gateway to be used by the container.

--apply-iponly <yes¦no>

If set to yes, the hostname, nameserver, and search domain settings from the container configuration file are ignored.

--configure <yes¦no>

If set to yes, the settings above are applied to the virtual network adapter instead of its original settings. Configuring any of the settings above automatically sets this option to yes.

Hard Disk Drive Management Options

This group of options is used to manage virtual hard disks in a container.

Syntax
prlctl set <CT_name> --device-add hdd [--image <file>] [--size <size>]
           [--mnt <path>] [--iface <ide|scsi|virtio>] [--position <pos>]
prlctl set <CT_name> --device-set hdd<N> [--image <file>] [--size +<size>]
           [--mnt <path>] [--iface <ide|scsi|virtio>] [--position <pos>]
           [--autocompact <on|off>]
prlctl set <CT_name> --backup-add <backup_ID> [--disk <disk_name>]
prlctl set <CT_name> --device-del hdd<N> [--detach-only|--destroy-image]
prlctl set <CT_name> --backup-del {<backup_ID>|all}
Table 47. Options
Name Description

<CT_name>

Container name.

--device-add hdd

Adds a virtual hard disk to the container. If no other options are specified, the command creates a new unmounted disk with the following parameters:

  • name: hdd<N> where <N> is the next available disk index.

  • size: 65536 MB

  • image location: /vz/private/<CT_UUID>/disk-<ID>.hdd.

--device-set hdd<N>

Modifies the parameters of the virtual hard disk hdd<N>.

Note

Note: For the list of disks, use the prlctl list -i command.

--image <file>

Specifies an image file that will be used to emulate the virtual disk.

  • If the specified image does not exist, it is created and used to emulate the virtual hard disk.

  • If the specified image exists, it is used to emulate the virtual hard disk.

--size <size>

Specifies the size of the virtual hard disk, in megabytes.

--mnt <path>

Specifies the mount point of the virtual hard disk inside the container. A corresponding entry is also added to container’s /etc/fstab file, so the disk is mounted automatically on container start.

--autocompact <on¦off>

Enables or disables compaction for the specified disk in the container.

Note

Note: For details on how to enable or disable compaction for all disks in the container, see [_general_options].

--backup-add <backup_ID>

Attach the backup with the identifier <backup_ID> to the virtual machine as a virtual hard disk. To obtain the backup ID, use the prlctl backup-list -f command.

--disk <disk_name>

Used with --backup-add. The name of the disk in the backup to attach. If a disk is not specified, all disks contained in the backup will be attached. To obtain the disk name, use the prlctl backup-list -f command.

--device-del hdd<N>

Deletes a virtual hard disk from the stopped container.

--detach-only

Removes the virtual disk from the container configuration but leaves its image file intact.

--destroy-image

Removes the virtual disk from the container configuration and deletes its image file.

--backup-del {<backup_ID>¦all}

Detach either the backup with the identifier <backup_ID> or detach all backups from the virtual machine.

prlctl snapshot, snapshot-list, snapshot-switch, snapshot-delete

Takes, displays, reverts to, and deletes container snapshots.

Syntax
prlctl snapshot <CT_name> [-n, --name <name>] [-d, --description <desc>]
prlctl snapshot-list <CT_name> [-t, --tree] [-i, --id <snapshot_ID>]
prlctl snapshot-switch <CT_name> -i, --id <snapshot_ID>
prlctl snapshot-delete <CT_name> -i, --id <snapshot_ID>
Table 48. Options
Name Description

<CT_name>

Container name.

-n, --name <name>

User-defined snapshot name. Names with white spaces must be enclosed in quotation marks.

-d, --description <desc>

User-defined snapshot description. Descriptions with white spaces must be enclosed in quotation marks.

-t, --tree

Displays the snapshot list as a tree. The default display format is tabular with Parent Snapshot ID and Snapshot ID as columns.

-i, --id <snapshot_ID>

  • Use with prlctl snapshot-list to specify the ID of the snapshot to use as the root. If this parameter is omitted, the entire snapshot tree will be displayed.

  • Use with prlctl snapshot-switch to specify the ID of the snapshot to revert to.

  • Use with prlctl snapshot-delete to specify the ID of the snapshot to delete.

Note

Note: If the snapshot you want to delete has children snapshots derived from it, they will not be deleted.

prlctl start, stop, restart, status

These commands start, stop, restart, and show the current state of containers, respectively.

Syntax
prlctl start <CT_name> [--wait]
prlctl stop <CT_name> [--fast]
prlctl restart <CT_name>
prlctl status <CT_name>
Table 49. Options
Name Description

<CT_name>

Container name.

The first command is used to start a container. It will set up all network interfaces inside the container, initialize the container quota, if needed, start the init process inside the container, and exit. You can also make the prlctl start command wait for all the necessary startup processes to complete and the container to boot into the default runlevel by passing the --wait option to this command.

prlctl stop shuts the container down. If the container is not down after a two-minute timeout due to an error in an application, for example, prlctl will forcibly kill all the processes inside the container. To avoid waiting for two minutes in case of a corrupted container, you may use the --fast option with this command.

When starting or stopping a container, prlctl executes a number of helper scripts located in the /vz/private/<CT_UUID>/scripts and /usr/libexec/libvzctl/scripts/ directories.

Table 50. Scripts:
Name Description

vz-create_prvt

This script is expected to create the container private area from a private area template.

vz-net_add

This script sets up the necessary routing entries for container IP addresses and adds public ARP records on all interfaces.

vz-net_del

This script deletes routing entries and ARP records for container IP addresses from all interfaces.

vz-pci_configure

This configuration script is executed after a PCI device is added to or removed from a container.

vz-setrate

This script configures the network traffic shaping for a container.

vz-start

This script is called just before a container is started and used to perform any additional setup of the container, such as network setup.

vz-stop

This script is called just after a container is shut down and can be used to perform any additional cleanup of the container, such as network cleanup.

Use action scripts vz-start/vz-stop to perform actions during container startup/shutdown. To add more functionality to other shipped scripts, create a new script and add a call to it to a shipped script. Doing so will facilitate upgrades to future versions of Virtuozzo.

The prlctl restart <CT_name> command consecutively performs the stopping and starting of the corresponding container.

The prlctl status command shows the current container state. It outputs the following information: whether the container private area exists, whether it is mounted, and whether the container is running.

prlctl suspend, resume

The prlctl suspend command is used to save the state of a running container.

Syntax
prlctl suspend <CT_name>
Table 51. Options
Name Description

<CT_name>

Container name.

During the prlctl suspend execution, the current container state is saved to a special dump file and the container itself is stopped. The created dump file is saved to the Dump file in the /vz/private/<CT_UUID>/dump directory on the server.

The prlctl resume command is used to restore the container from its dump file created with the prlctl suspend command.

Syntax
prlctl resume <CT_name>

When executed, prlctl resume searches for the Dump file in the /vz/private/<CT_UUID>/dump directory on the server and restores the container from this file.You can restore the container dump file on the Source Server, i.e. on the server where this container was running before its dumping, or transfer the dump file to another server and restore it there.

Note

Note: Before restoring a container from its dump file, make sure that the file system on the Destination Server is identical to that at the moment of the container dumping. Otherwise, the container restoration may fail.

prlctl list

Displays a list of containers on the Hardware Node. Displays information on containers on the Hardware Node.

Syntax
prlctl list --vmtype ct [-a, --all] [-o, --output <field>[,...]]
                        [-s, --sort <field>|-<field>] [-t, --template] [-j, --json]
prlctl list -i, --info --vmtype ct [<CT_name>] [-f, --full] [-t, --template]
                                   [-j, --json]
Table 52. Options
Name Description

-a, --all

List all running, stopped, suspended, and paused containers. If this and the rest of the parameters are omitted, only the running containers will be displayed.

-t, --template

List available container templates instead of actual containers.

-o, --output <field>[,…​]

Display only the specified fields. Type field names in lower case. Separate multiple fields with commas. For the list of fields, see [_prlctl_list_output_parameters].

-s, --sort {<field>¦-<field>}

Sort containers by the specified field in either ascending or descending order.

-i, --info

Display detailed information about the specified container.

-f, --full

Display detailed information about network cards in containers. Used with the --info option.

<CT_name>

Thename of the container for which to display the detailed information. If not specified, the information will be displayed for all registered containers.

-j, -json

Produce machine-readable output in the JSON format.

prlctl list Output Parameters

Listed below are the parameters that can be specified after the -o switch.

Name Output Column Description

uuid

UUID

Container UUID.

hostname

HOSTNAME

Container hostname.

name

NAME

Container name.

description

DESCRIPTION

Container description.

ostemplate

OSTEMPLATE

Specifies the name of the OS template your container is based on (e.g., centos-6-x86_64).

ip

IP_ADDR

Container IP address.

status

STATUS

Container status (e.g., running or stopped).

numproc

NPROC

The number of processes and threads allowed.

mac

MAC

Network device’s MAC address.

netif

NETIF

Network devices in the container.

iolimit

IOLIMIT

The bandwidth a container is allowed to use for its disk input and output (I/O) operation, in bytes per second.

ha_enable

HA_ENABLE

Indicates whether the container is joined to the High Availability Cluster.

ha_prio

HA_PRIO

Container priority in the High Availability Cluster (0 is the lowest). Higher-priority virtual environments are restarted first in case of failures.

Migration Utilities

This section describes the utilities you can use to move/clone containers within the same server.

prlctl clone

Creates an exact copy of the specified container.

Syntax
prlctl clone <CT_name> --name <new_name> [--template] [--dst=<path>]
Table 53. Options
Name Description

<CT_name>

Name of the container to clone.

--name <new_name>

Name to be assigned to the new container.

--template

Create a container template instead of a clone. Template cannot be started.

--dst=<path>

Full path to the directory for storing the contents of the cloned container. If this parameter is omitted, the clone is created in the default directory.

Backup and Restoration Utilities

Any container is defined by its private area, configuration files, action scripts, and quota information. Backing up these components allows you to restore all the content of a container on any Virtuozzo-based system at any time if the container gets broken.

prlctl backup, backup-list, backup-delete, restore

Creates, lists, deletes or restores container backups.

Syntax
prlctl backup <CT_name> [-f, --full] [-i, --incremental] [--description <desc>]
              [-s, --storage [<user>[:<passwd>]@]<server>[:<port>]]
              [--no-compression]
prlctl backup-list [<CT_name>] [-f, --full] [--localvms]
                   [-s, --storage [<user>[:<passwd>]@]<server>[:<port>]]
prlctl backup-delete {<CT_name> | -t, --tag <backup_ID>}
prlctl restore {<CT_name> | -t, --tag <backup_ID>} [-n, --name <new_name>]
               [--dst=<path>] [-s, --storage [<user>[:<passwd>]@]<server>[:<port>]]
Table 54. Options
Name Description

<CT_name>

Container name.

  • Use with prlctl backup to create a backup of the specified container.

  • Use with prlctl backup-list to list backups of the specified container.

  • Use with prlctl backup-delete to delete all backups of the specified container.

  • Use with prlctl restore to restore the most recent backup of the specified container.

-s, --storage [<user>[:<passwd>]@]<server>[:<port>]

Specifies a remote backup server address, port, and credentials. If this option is omitted, the backup will be saved on the default backup server that can be configured using the prlsrvctl set command.

--description <desc>

Backup description. Descriptions with white spaces must be enclosed in quotation marks.

-f, --full

  • Use with prlctl backup to create a full backup of the container. A full backup contains all container data.

  • Use with prlctl backup-list to display full backup information.

-i, --incremental

Create an incremental backup of the container. An incremental backup contains only the files changed since the previous full or incremental backup. This is the default backup type.

--localvms

List local backups only.

-t, --tag <backup_ID>

The ID of the backup to restore or delete.

-n, --name <new_name>

A new name to assign to the restored container. If this option is omitted, the container will be restored with the original name.

--dst=<path>

Restore the container to the specified directory on the server. If this option is omitted, the container will be restored to /var/parallels/<CT_name>.

--no-compression

Does not compress a backup image during its creation.

EZ Template Management Utilities

This section described the utilities you can use to manage OS and application templates.

vzpkg

The vzpkg utility is used to manage OS and application EZ templates either inside your containers or on the server itself. This tool can also be used to manage standard software packages (e.g., mysql.rpm) inside containers.

Syntax
vzpkg <command> [<options>] {<CT_name>|<object>}
vzpkg --help
Table 55. Commands
Name Description

install template

Installs OS and application EZ templates on the server.

update template

Updates OS and application EZ templates installed on the server.

remove template

Removes OS and application EZ templates from the server.

list

Outputs a list of EZ templates, OS template caches with preinstalled application templates, or software packages either on the server or inside a particular container.

info

Outputs information on any EZ templates or software packages available on the server or inside the container.

status

Outputs information on updates for the packages installed inside a container.

install

Adds application EZ templates to or to install software packages inside the container.

update

Updates application EZ templates and software packages inside the container.

remove

Removes application EZ templates or software packages from the container.

create cache

Creates a tarball (cache) for the given OS EZ template.

update cache

Updates the existing tarball (cache) for the given OS EZ template.

remove cache

Removes a tarball (cache) for the given OS EZ template.

create appcache

Creates a cache of an OS EZ template with preinstalled application templates.

update appcache

Updates or recreates a cache of an OS EZ template with preinstalled application templates.

remove appcache

Removes a cache of an OS EZ template with preinstalled application templates.

localinstall

Installs a software package inside a container from the corresponding file on the server.

localupdate

Updates the software packages installed inside your container(s) by means of the vzpkg install or vzpkg localinstall commands.

upgrade

Upgrades an OS EZ template the container is based on to a newer version.

fetch

Downloads packages included in EZ templates to the server and to store them in the vzpkg local cache.

clean

Removes all locally cached data from the template directories on the server.

update metadata

Updates the local metadata on the server.

vzpkg install template

This command is used to install an OS or application EZ template on the server from an RPM package or Virtuozzo repositories.

Syntax
vzpkg install template [<options>] <object> [...]

where <object> is a path to an RPM package or an EZ template name.

Table 56. Options
Name Description

-q, --quiet

Disables logging to the screen and to the log file.

-f, --force

Forces installation of the EZ template on the server.

Note

Note: To install multiple EZ templates, specify multiple RPM package or EZ template names separated by white spaces.

vzpkg update template

This command is used to update an OS or application EZ template on the server from an RPM package or Virtuozzo repositories.

Syntax
vzpkg update template [<options>] <object> [...]

where <object> is a path to an RPM package or an EZ template name.

Table 57. Options
Name Description

-q, --quiet

Disables logging to the screen and to the log file.

-f, --force

Forces update of the EZ template.

Note

Note: To update multiple EZ templates, specify multiple RPM package or EZ template names separated by white spaces.

vzpkg remove template

This command removes an OS or application EZ template from the server.

Syntax
vzpkg remove template [<options>] <template_name> [...]
Table 58. Options
Name Description

-F, --for-os <OS_template>

Specifies the OS EZ template to delete the application EZ template from.

-q, --quiet

Disables logging to screen and file.

-f, --force

Forces deletion of the EZ template.

When executed, the vzpkg remove template command removes the specified OS EZ template from the server. To delete an application EZ template, additionally specify the name of the OS EZ template (<OS_template>) under which this application template is to be run.

vzpkg list

The vzpkg list command is used to list

  • EZ templates installed on the server, in a container, or available in remote EZ template repositories

  • YUM software groups or individual packages installed in a container

Syntax
vzpkg list [<options>] [<OS_template>|<CT_name> [...]]

If you indicate a container name, the command will list all EZ templates applied to the specified container. If you indicate an OS EZ template, vzpkg list will display a list of application EZ templates available for this OS EZ template. Without any options, the utility lists all EZ templates installed on the server.

Table 59. Options
Name Description

-p, --package

Lists the software packages installed in the container or included in the OS EZ template.

-g, --groups

Lists the YUM software groups installed in the container or available for the OS EZ template. The -g option works only for containers running RPM-based Linux distributions.

-O, --os

Displays the OS EZ template the container is based on.

-A, --app

Displays the application EZ templates installed in the container or included in the OS EZ template.

-C, --cache

Lists the packages included in the specified EZ template or applied to the specified container from the local vzpkg cache. You can omit this parameter if the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file. Should be used along with the -p option.

-r, --remote

If the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file, you should use this option to make vzpkg list list the packages included in the specified EZ template or applied to the specified container in the remote repositories. Should be used along with the -p option.

-u, --custom-pkg

Displays a list of packages that are applied to the specified container but absent from the repository set to handle the EZ template(s) where these packages are included.

-i, --pkgid

Displays the ID assigned to the EZ template instead of its name; these IDs are unique within the given system. If the <CT_name> argument is given, the command shows the IDs of the EZ templates available inside the container. If the <OS_template> argument is given, the command displays the IDs of the OS EZ template specified and all its EZ application templates.

-S, --with-summary

In addition to listing the EZ templates available either in the container (if the <CT_name> argument is given) or installed on the server (if the <CT_name> argument is omitted), this option makes vzpkg list display the summary information on the corresponding EZ templates/packages.

-c, --cached

This option has no effect if the <CT_name> argument is given. If used for listing the EZ templates available on the server, it makes vzpkg list omit all application and OS EZ templates for which the cache has not been created (by running the vzpkg create cache command). In other words, with this option on, vzpkg list will list only the OS EZ templates ready to be used for the container creation.

appcache

Outputs a list of OS EZ template caches with preinstalled applications.

-d, --debug <num>

Sets the debugging level to one of the specified values (from 0 to 10). 10 is the highest debug level and 0 sets the debug level to its minimal value.

-q, --quiet

Disables logging to the screen and to the log file.

vzpkg info

This command displays information about EZ templates, YUM software packages, and individual software packages.

Syntax
vzpkg info [-F {<OS_template>|<CT_name>} -q|-d <app_template> [<parameters> ...]
vzpkg info -p|-g [-C|-r] [-F {<OS_template>|<CT_name>} -q|-d {<package_name>|<yum_package_group>} [<parameters> [...]]
Table 60. Options
Name Description

<CT_name>

Container name.

<OS_template>

OS EZ template.

<app_template>

Application EZ template.

<package_name>

Software package name.

<yum_package_group>

YUM software group name.

-F, --for-os {<OS_template>¦<CT_name>_}

Displays information on the application EZ template or the software package (if the -p option is specified) included in the specified OS EZ template or applied to the indicated container.

-p, --package

Displays information about the specified software package. Must be used with the -F option.

-g, --groups

Displays information about the packages included in the specified YUM software group.

-C, --cache

Displays the information on the specified package from the local vzpkg cache. You can omit this parameter if the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file.

-r, --remote

If the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file, you should use this option to make vzpkg info get the information on the specified package from the remote repositories set for handling the EZ template where this package is included.

-d, --debug <num>

Sets the debugging level to one of the specified values (from 0 to 10). 10 is the highest debug level and 0 sets the debug level to its minimal value.

-q, --quiet

Disables logging to the screen and to the log file.

While executed, vzpkg info parses the subdirectories and files located in the /vz/template/<os_name>/<os_version>/<arch>/config directory and containing the EZ template meta data. To run the command, you should specify either the OS EZ template or the container name. In either case, detailed information on the corresponding OS EZ template is displayed. You can also use the -F option to get the necessary information on any application EZ template included into the OS EZ template or applied to the container.

By default, vzpkg info displays all meta data on the EZ template/package specified. However, you can reduce the amount of the output information by using special parameters (<parameters>) listed in the table below.

Table 61. Output Parameters
Name Description

name

The name of the EZ template/package.

packages

The packages included in the EZ template. For EZ templates only.

repositories

The repository where the packages comprising the EZ template are stored. For EZ templates only.

mirrorlist

The URL to the file containing a list of repositories from where the packages comprising the EZ template are to be downloaded. For EZ templates only.

distribution

The Linux distribution on the basis the OS EZ template has been created or under which the application EZ template is to be run. For EZ templates only.

summary

Brief information on the EZ template/package.

description

Detailed information on the EZ template/package. As distinct from summary, it can contain additional data on the EZ template/package.

technologies

For EZ templates only. Displays the following information:

  • The microprocessor architecture where the EZ template is to be used (x86, x86_64);

  • Specifies whether the EZ template can be used only on the servers with the Native POSIX Thread Library (NPTL) support. In this case the nptl entry is displayed after the vzpkg info execution.

version

The version of the software package.

release

The release of the software package.

arch

The system architecture where the EZ template/package is to be used. It can be one of the following:

  • x86 if the EZ template/package is to be used on 32-bit platforms.

  • x86_64 if the EZ template is to be used on 64-bit platforms (e.g., on servers with the AMD Opteron and Intel Pentium D processors installed).

config_path

Displays the path to the EZ template configuration directory containing the template meta data where the meta data for the base OS EZ template are stored (the default directory path is  /vz/template/<OS_name>/<OS_version>/<arch>/config/os/default).

package_manager_type

For EZ templates only. The packaging system used to handle the packages included in the specified EZ template. It can be one of the following:

  • rpm for RPM-based Linux distributions (Fedora Core, Red Hat Enterprise Linux, etc.);

  • dpkg for Debian-based Linux distributions (e.g., Debian and Ubuntu).

package_manager

The package manager type for managing the packages included in the specified EZ template. It can be one of the following:

x86 Linux distributions
  • rpm49db5x86: Fedora 17

  • rpm49x86: Fedora 15 and 16

  • rpm47x86: Red Hat Enterprise Linux 6 and CentOS 6

  • rpm44x86: Red Hat Enterprise Linux 5 and CentOS 5

  • rpm43x86: Red Hat Enterprise Linux 3 and 4, CentOS 3 and 4

  • rpmzypp44x86: SUSE Linux Enterprise Server 11 with Service Pack 2

  • rpm41x86: SUSE Linux Enterprise Server 10 and SUSE Linux 10.x

  • rpm41s9x86: SUSE Linux Enterprise Server 9

  • rpmzypp49x86: openSUSE 12.1

  • dpkg: Debian and Ubuntu

x86-64 Linux distributions
  • rpm49db5x64: Fedora 17

  • rpm49x64: Fedora 15 and 16

  • rpm47x64: Red Hat Enterprise Linux 6 and CentOS 6

  • rpm44x64: Red Hat Enterprise Linux 5 and CentOS 5

  • rpm43x64: Red Hat Enterprise Linux 3 and 4, CentOS 3 and 4

  • rpmzypp44x64: SUSE Linux Enterprise Server 11 with Service Pack 2

  • rpm41x64: SUSE Linux Enterprise Server 10 and SUSE Linux 10.x

  • rpm41s9x64: SUSE Linux Enterprise Server 9

  • rpmzypp49x64: openSUSE 12.1

  • dpkgx64: Debian and Ubuntu

vzpkg status

This command is used to check the status of the packages either installed inside a container or included in an OS EZ template.

Syntax
vzpkg status [<options>] {<CT_name>|<OS_template>}
Table 62. Options
Name Description

-C, --cache

Makes the vzpkg status command look for available updates in the local vzpkg cache only. You can omit this parameter if the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file.

-r, --remote

If the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file, you should use this option to make vzpkg status look for the package updates in the remote repositories set for handling the corresponding EZ template.

-d, --debug <num>

Sets the debugging level to one of the specified values (from 0 to 10). 10 is the highest debug level and 0 sets the debug level to its minimal value.

-q, --quiet

Disables logging to the screen and to the log file.

When executed, the command performs the following operations:

  • Checks all the packages installed inside the specified container or included in the specified OS EZ template.

  • Checks the repository used to install/update packages inside the container/OS EZ template.

  • Compares the packages in the repository with those inside the container/OS EZ template.

  • Lists the found packages updates for the container/OS EZ template, if any, or informs you that the container/OS EZ template is up-to-date.

Note

Note: The vzpkg status command can be executed for running containers only.

vzpkg install

This command is used to install application EZ templates, YUM software groups, or individual software packages into containers.

Syntax
vzpkg install [<options>] <CT_name> <object> [...]

The vzpkg install command will add an <object> to the specified container. An object can be an application EZ template, a YUM software group, or a standard software package. You can specify several objects to install into the container by separating them by spaces.

When executed, vzpkg install automatically handles the interdependencies among the packages to be installed into a container and ensures that all dependencies are satisfied. If the package dependencies cannot be resolved, the installation process fails and the corresponding message is displayed.

Table 63. Options
Name Description

-p, --package

Installs a software package instead of an EZ template.

-g, --groups

Installs a YUM software group instead of an EZ template. The -g option works only for containers running RPM-based Linux distributions.

-f, --force

Forces the EZ template/package installation.

-C, --cache

Makes the vzpkg install command look for the packages included in the EZ template in the local vzpkg cache only. If there is a package not available locally, the command will fail. You can omit this parameter if the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file.

-r, --remote

If the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file, you should use this option to make vzpkg install look for the packages in the remote repositories set for handling the corresponding EZ template.

-n, --check-only

Simulates the same operations as vzpkg install completes without specifying this option (downloads the software packages to the server, handles the package interdependencies, etc.); however, the packages themselves are not installed in the specified the container.

-d, --debug <num>

Sets the debugging level to one of the specified values (from 0 to 10). 10 is the highest debug level and 0 sets the debug level to its minimal value.

-q, --quiet

Disables logging to the screen and to the log file.

By default, the specified object is treated by vzpkg install as an application EZ template. However, you can use the -p or -g option to explicitly specify the type of the object.

Note

Note: A container has to be running in order to apply an application EZ template to or install a package inside this container.

vzpkg update

The vzpkg update command is used to update the following components of a container:

  • OS EZ template

  • application EZ templates

  • YUM software groups

  • individual software packages

Syntax
vzpkg update [<options>] <CT_name> [<object> [...]]
Table 64. Options
Name Description

-C, --cache

Makes the vzpkg update command look for the package updates in the local vzpkg cache only. You can omit this parameter if the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file.

-r, --remote

If the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file, you should use this option to make vzpkg update look for the package updates in the remote repositories set for handling the corresponding EZ templates.

-p, --package

Updates the packages installed in the container by using the vzpkg install command.

-g, --groups

Updates the YUM software group in the container. The -g option works only for containers running RPM-based Linux distributions.

-f, --force

Forces the EZ template/package update procedure.

-n, --check-only

Simulates the same operations as vzpkg update completes without specifying this option (downloads the updated packages to the server, handles their interdependencies, etc.); however, the packages themselves are not updated.

-d, --debug <num>

Sets the debugging level to one of the specified values (from 0 to 10). 10 is the highest debug level and 0 sets the debug level to its minimal value.

-q, --quiet

Disables logging to the screen and to the log file.

Without any options specified, vzpkg update updates all EZ templates (including the OS EZ template) in the specified container. However, you can make the command update a particular EZ template by specifying its name as <object>. You can also use the -p or -g option to update YUM software groups or individual software packages in the container.

vzpkg remove

This command is used to remove an application EZ template, YUM software group, or a software package from a container.

Syntax
vzpkg remove [<options>] <CT_name> <object> [...]

This command will remove <object> from the container with the name <CT_name>. The <object> can be an application EZ template, a YUM software group, or a software package installed with the vzpkg install command. You may specify a number of objects for removing.

Table 65. Options
Name Description

-p, --package

Removes the specified package(s) from the container.

-g, --groups

Removes the specified YUM software group from the container. The -g option works only for containers running RPM-based Linux distributions.

-w, --with-depends

Removes also the packages having dependencies with the object specified.

-f, --force

Forces the EZ template/package deletion.

-n, --check-only

Simulates the same operations as vzpkg remove completes without specifying this option (handles interdependencies of the packages to be removed from the server, etc.); however, the packages themselves are not deleted from the specified container(s).

-d, --debug <num>

Sets the debugging level to one of the specified values (from 0 to 10). 10 is the highest debug level and 0 sets the debug level to its minimal value.

-q, --quiet

Disables logging to the screen and to the log file.

By default, the specified object is treated by vzpkg remove as an application EZ template. However, you can use the -p or -g option to explicitly specify the type of the object.

Note

Note: A container has to be running in order to remove an application EZ template/package from it.

vzpkg create cache

This command is used to create tarballs (caches) for OS EZ templates. You should execute this command before you start using a newly installed OS EZ template for creating containers.

Syntax
vzpkg create cache [<options>] [<OS_template> [...]]
Table 66. Options
Name Description

-C, --cache

Makes the vzpkg create cache command check for the packages included in the EZ OS template in the local vzpkg cache only and use them for the cache creation. You can omit this parameter if the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file. In this case vzpkg create cache will also check the local vzpkg cache only.

-r, --remote

If the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file, you should use this option to make vzpkg create cache check for the packages included in the EZ OS template in the remote repositories set for its handling.

-d, --debug <num>

Sets the debugging level to one of the specified values (from 0 to 10). 10 is the highest debug level and 0 sets the debug level to its minimal value.

-q, --quiet

Disables logging to the screen and to the log file.

-f, --force

Forces the process of the cache creation.

vzpkg create cache checks the template area on the server (by default, the /vz/template directory is used) and if it finds an OS EZ template for which no tar archive exists, it creates a gzipped tarball for the corresponding OS EZ template and places it to the /vz/template/cache directory. When a container is being created, prlctl just unpacks the tar archive.

By default, vzpkg create cache checks the tar archive existence for all OS EZ templates installed on the server and creates some, if necessary. However, you can explicitly indicate what OS EZ template should be cached by specifying its name as <OS_template>. If the cache of the OS template specified already exists on the server, the command will fail and you will be presented with the corresponding error message.

vzpkg update cache

This command is used to update tarballs (caches) of the OS EZ templates installed on the server.

Syntax
vzpkg update cache [<options>] [<OS_template> [...]]
Table 67. Options
Name Description

-C, --cache

Makes the vzpkg update cache command check for the packages updates in the local vzpkg cache only and use them for the cache creation. You can omit this parameter if the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file. In this case vzpkg update cache will also check the local vzpkg cache only.

-r, --remote

If the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file, you should use this option to make vzpkg update cache check for the packages updates in the remote repositories set for handling the given EZ OS template.

The vzpkg update cache command checks the cache directory in the template area (by default, the template area is located in the /vz/template directory on the server) and updates all existing tarballs in this directory. However, you can explicitly indicate what OS EZ template tarball is to be updated by specifying its name as <OS_template>. Upon the vzpkg update cache execution, the old tarball is renamed by receiving the -old suffix (e.g., centos-6-x86_64.tar.gz-old).

If the vzpkg update cache command does not find a tarball for one or more OS EZ templates installed on the server, it creates the corresponding tar archive(s) and puts them to the /vz/template/cache directory.

vzpkg remove cache

This command removes the cache for the OS EZ templates specified.

Syntax
vzpkg remove cache [<options>] [<OS_template> [...]]
Table 68. Options
Name Description

-d, --debug <num>

Sets the debugging level to one of the specified values (from 0 to 10). 10 is the highest debug level and 0 sets the debug level to its minimal value.

-q, --quiet

Disables logging to the screen and to the log file.

By default, vzpkg remove cache deletes all caches located in the /vz/template/cache directory on the server. However, you can explicitly indicate what OS EZ template tar archive is to be removed by specifying its name as <OS_template>.

Note

Note: The OS EZ template caches having the -old suffix are not removed from the /vz/template/cache directory. You should use the -rm command to delete these caches from the server.

vzpkg create appcache

This command combines an OS EZ template cache and one or more application EZ templates into a new OS and applications cache. If the OS EZ template cache has not been created yet, this will be done before application templates are added.

Syntax
vzpkg create appcache --config <config> [<options>]
Table 69. Options
Name Description

--config <config>

Specifies the path to the configuration file with the information on what OS and application templates to use.

--ostemplate <OS_template>

Specifies the OS EZ template to use in cache creation. This option redefines the OS EZ template specified in the configuration file.

--apptemplate <app_template>

Specifies one or more application EZ templates (comma-separated) to be added to the resulting cache.This option redefines the application EZ templates specified in the configuration file.

-d, --debug <num>

Sets the debugging level (0 to 10), 10 being the highest.

-q, --quiet

Disables logging to screen and log file.

-f, --force

Forces cache creation.

vzpkg update appcache

This command updates an existing OS EZ template cache with preinstalled application templates if the --update-cache option is provided. Otherwise, the cache is created anew.

Syntax
vzpkg update appcache --config <config> [<options>]
Table 70. Options
Name Description

--config <config>

Specifies the configuration file with the information on what OS and application templates to use.

--ostemplate <OS_template>

Specifies the OS EZ template, cache of which needs to be recreated or updated. This option redefines the OS EZ template specified in the configuration file.

--apptemplate <app_template>

Specifies all application EZ templates (comma-separated) preinstalled in the cache which needs to be updated. This option redefines the application EZ templates specified in the configuration file.

--update-cache

Instructs the command to check for updates for the existing OS and application cache. Otherwise, the cache is created anew.

-d, --debug <num>

Sets the debugging level (0 to 10), 10 being the highest.

-q, --quiet

Disables logging to screen and log file.

-f, --force

Forces cache creation.

vzpkg remove appcache

This command removes an existing OS EZ template cache with preinstalled application templates.

Syntax
vzpkg remove appcache --config <config> [<options>]
Table 71. Options
Name Description

--config <config>

Specifies the configuration file with the information on what OS and application templates to use.

--ostemplate <OS_template>

Specifies the OS EZ template, cache of which needs to be removed. This option redefines the OS EZ template specified in the configuration file.

--apptemplate <app_template>

Specifies all application EZ templates (comma-separated) preinstalled in the cache which needs to be removed. This option redefines the application EZ templates specified in the configuration file.

-d, --debug <num>

Sets the debugging level (0 to 10), 10 being the highest.

-q, --quiet

Disables logging to screen and log file.

-f, --force

Forces cache creation.

vzpkg localinstall

The vzpkg localinstall command is used to install a software package inside a container from the corresponding file on the server.

Syntax
vzpkg localinstall [<options>] <CT_name> <rpm_file_path> [...]
Table 72. Options
Name Description

-C, --cache

When handling the package interdependencies, makes the vzpkg localinstall command look for the needed packages in the local vzpkg cache only. If there is a package not available locally, the command will fail. You can omit this parameter if the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file.

-r, --remote

If the elapsed time from the last vzpkg local cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file, you should use this option to make vzpkg localinstall look for the packages in the remote repository.

-n, --check-only

Simulates the same operations as vzpkg localinstall completes without specifying this option (e.g., handles the package interdependencies); however, the package itself is not installed in the specified container.

-d, --debug <num>

Sets the debugging level to one of the specified values (from 0 to 10). 10 is the highest debug level and 0 sets the debug level to its minimal value.

-q, --quiet

Disables logging to the screen and to the log file.

When executed, the command installs the package, the full path to which is specified as <rpm_file_path>, inside the container with the name <CT_name>. You may specify multiple packages to be installed inside the container.

During its execution, vzpkg localinstall automatically handles the interdependencies among the packages to be installed inside a container and ensures that all dependencies are satisfied. If the package dependencies cannot be resolved, the installation process will fail and the corresponding message will be displayed.

vzpkg localupdate

The vzpkg localupdate command is used to update the software packages installed inside your container(s) by means of the vzpkg install or vzpkg localinstall commands.

Syntax
vzpkg localupdate [<options>] <CT_name> <rpm_file_path> [...]
Table 73. Options
Name Description

-C, --cache

When handling the package interdependencies, makes the vzpkg localupdate command look for the needed packages in the local vzpkg cache only. If there is a package not available locally, the command will fail. You can omit this parameter if the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file.

-r, --remote

If the elapsed time from the last vzpkg local cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file, you should use this option to make vzpkg localupdate look for the packages in the remote repository.

-n, --check-only

Simulates the same operations as vzpkg localupdate completes without specifying this option (e.g., handles the package interdependencies); however, the package itself is not installed in the specified container.

-d, --debug <num>

Sets the debugging level to one of the specified values (from 0 to 10). 10 is the highest debug level and 0 sets the debug level to its minimal value.

-q, --quiet

Disables logging to the screen and to the log file.

When executed, vzpkg localupdate compares the file on the server the full path to which is specified as <rpm_file_path> with the corresponding package inside the container with the name <CT_name> and updates it, if necessary. You may specify a number of packages at once to be updated inside your container.

vzpkg upgrade

The vzpkg upgrade command is used to upgrade an OS EZ template the container is based on to a newer version.

Syntax
vzpkg upgrade [<options>] <CT_name>
Table 74. Options
Name Description

-C, --cache

Makes the vzpkg upgrade command check for the packages included in the OS EZ template in the local vzpkg cache only. If any package is not available locally, the command will fail. You can omit this parameter if the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file; in this case vzpkg upgrade will also check the local vzpkg cache only.

-r, --remote

If the elapsed time from the last local vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file, you should use this option to make vzpkg upgrade check for the packages in the remote repositories set for handling the given EZ OS template.

-n, --check-only

Simulates the same operations as vzpkg upgrade completes without specifying this option (downloads the packages to the server, handles their interdependencies, etc.); however, the packages themselves inside the container are not upgraded.

-f, --force

Forces the upgrade of the OS EZ template.

-d, --debug <num>

Sets the debugging level to one of the specified values (from 0 to 10). 10 is the highest debug level and 0 sets the debug level to its minimal value.

-q, --quiet

Disables logging to the screen and to the log file.

vzpkg fetch

This command is used to download packages included in the corresponding OS EZ template or their updates from the remote repository to the vzpkg local cache on the server and to prepare them for installation.

Syntax
vzpkg fetch [<options>] <OS_template>
Table 75. Options
Name Description

-O, --os

Download packages/updates for the specified EZ OS template.

-A, --app

Download packages/updates for EZ application templates used with the EZ specified OS template.

-C, --cache

Makes the vzpkg fetch command look for the metadata in the vzpkg local cache only. You can omit this parameter if the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file.

-r, --remote

If the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file, you should use this option to make vzpkg fetch look for the OS EZ template metadata in the remote repositories set for handling the corresponding EZ template.

-f, --force

Forces the process of downloading packages and/or their updates to the server.

-d, --debug <num>

Sets the debugging level to one of the specified values (from 0 to 10). 10 is the highest debug level and 0 sets the debug level to its minimal value.

-q, --quiet

Disables logging to the screen and to the log file.

You can make vzpkg fetch run as a cron job (e.g., nightly) checking for available packages or packages updates for your EZ templates and keeping them in the local cache. Having all the necessary packages in the vzpkg local cache can greatly speed up the execution of the vzpkg install, vzpkg update, or vzpkg create cache commands since the packages are available locally and there is no need to check for them in the corresponding remote repositories.

vzpkg clean

This command is used to remove the software packages, their headers, and metadata downloaded to the server from the repository during the vzpkg execution (e.g., while caching an OS EZ template or adding an application EZ template to a container for the first time).

Syntax
vzpkg clean [<options>] [<OS_template> [...]]
Table 76. Options
Name Description

-k, --clean-packages

Removes the packages, headers, and metadata of the specified EZ OS template from the local vzpkg cache. This is also the default behavior of vzpkg clean.

-t, --clean-template

Checks the template area for the specified EZ OS template (the template area has the default path of /vz/template) and removes all packages that are currently not used by any container on the server and not included in the EZ OS template cache.

-a, --clean-all

Removes both:

  • the packages, headers, and metadata of the specified EZ OS template from the vzpkg local cache, and

  • the packages that are currently not used by any container on the server and not included in the EZ OS template cache.

-f, --force

Forces the vzpkg clean execution.

-n, --check-only

Simulates the same operations as vzpkg clean completes without specifying this option; however, the packages and headers are not removed from the server.

-d, --debug <num>

Sets the debugging level to one of the specified values (from 0 to 10). 10 is the highest debug level and 0 sets the debug level to its minimal value.

-q, --quiet

Disables logging to the screen and to the log file.

vzpkg update metadata

This command is used to update the OS EZ template local metadata on the server.

Syntax
vzpkg update metadata [<options>] [<OS_template> [...]]
Table 77. Options
Name Description

-C, --cache

Makes the vzpkg update metadata command look for available metadata updates in the local vzpkg cache only. You can omit this parameter if the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file.

-r, --remote

If the elapsed time from the last vzpkg cache update does not exceed the value of the METADATA_EXPIRE parameter specified in the /etc/vztt/vztt.conf file, you should use this option to make vzpkg update metadata look for the updated metadata in the remote repositories set for handling the corresponding OS EZ template.

-d, --debug <num>

Sets the debugging level to one of the specified values (from 0 to 10). 10 is the highest debug level and 0 sets the debug level to its minimal value.

-q, --quiet

Disables logging to the screen and to the log file.

When executed without any options, the command updates the metadata of all OS EZ templates installed on the server. If you specify one or more OS EZ templates, the command will update the metadata of the indicated OS templates only. You can run this command a cron job at regular intervals to be sure that your OS EZ templates metadata are always up-to-date.

Supplementary Tools

pcompact

Utility to compact containers by removing unused blocks from their virtual disks. By compacting virtual disks, you can increase free disk space on the physical server.

Syntax
pcompact [-v] [-n] [-s] [-t <timeout>[s|m|h]
Table 78. Options
Name Description

-v

Increase the command output verbosity. Multiple -v options can be specified to produce a more verbose output.

-n

Display the actions the command will execute but do not actually compact the disks.

-s

Stop the command execution after compacting the first virtual disk.

-t <timeout>[s¦m¦h]

Terminate the command after the specified timeout, in seconds (default), minutes or hours.

pfcache

Memory and IOPS deduplication management utility that enables/disables caching for container directories and files, verifies cache integrity, checks containers for cache errors, and purges the cache if needed.

Note

Note: The utility does not support additional disks attached to container.

Syntax
pfcache <command> {<file>|<dir> [<options>]
Table 79. Commands
Name Description

mark

Enables caching of the specified files, directories or subdirectories in containers.

unmark

Disables caching of the specified files, directories or subdirectories in containers.

purge

Frees up space in the memory and IOPS deduplication cache image.

verify

Verifies the integrity of the specified mounted memory and IOPS deduplication cache and deletes corrupted files.

check

Checks for and fixes memory and IOPS deduplication cache errors in the specified container root directory.

stat

Displays inodes summary for a running container.

dump

In addition to the summary provided by stat, shows detailed information on PFCache inodes of a running container. If no options are specified, outputs full information on checksummed peer inodes.

pfcache check

Checks for and fixes memory and IOPS deduplication cache errors in the specified container root directory.

Syntax
pfcache check <dir> [--dry-run]
Table 80. Options
Name Description

<dir>

Container root directory.

--dry-run

Report errors but do not make changes to the file system.

pfcache dump

In addition to the summary provided by stat, shows detailed information on PFCache inodes of a running container. If no options are specified, outputs full information on checksummed peer inodes.

Syntax
pfcache dump <dir> [--csummed{brvbar} -a, --all {brvbar} <csum>] [--column <col> [...]]
Table 81. Options
Name Description

<dir>

Container root directory.

--csummed

Outputs information on checksummed inodes.

-a, --all

Outputs information on all inodes.

<csum>

Outputs information on inodes with the specified checksum.

--column <col> […​]

Displays only the chosen column(s). <col> can be:

  • a - All

  • h - File handle

  • p - Page cache size, pages

  • c - Checksum

  • f - Filter state

  • s - File size, bytes

pfcache mark, unmark

Enables or disables caching of the specified files, directories or subdirectories in containers.

Syntax
pfcache mark <file>
pfcache mark <dir> [<subdir> [...]] [--recursive]
pfcache unmark <file>
pfcache unmark <dir> [<subdir> [...]] [--recursive]
Table 82. Options
Name Description

<file>

File to enable/disable caching of.

<dir>

Directory to enable/disable caching of.

<subdir>

Subdirectory to enable/disable caching of.

--recursive

Process directory’s or subdirectory’s current contents.

pfcache purge

Frees up space in the memory and IOPS deduplication cache image. If no options are specified, purges entire cache.

Syntax
pfcache purge <cache_dir> [--unused | --size <size> | --expire <date>]
Table 83. Options
Name Description

<cache_dir>

Memory and IOPS deduplication cache image location.

--unused

Remove only files unused at the moment.

--size <size>

Attempt to free size bytes in the memory and IOPS deduplication cache image.

--expire <date>

Remove files accessed before the specified date. A date can be specified in the ISO 8601 format or in the format defined in your system locale, with optional hours, minutes, and seconds. Examples:

  • 05/21/12 [09:50[:33]]

  • 2012-05-21 [09:50[:33]]

pfcache stat

Displays a summary of all files in the specified filesystem which have been accessed recently or are being accessed now.

Syntax
pfcache stat <dir>
Table 84. Options
Name Description

<dir>

Container root directory.

Table 85. Displayed Information
Name Description

csums

The number of checksummed files and their percentage in the total number of files fetched by the command.

Note

Note: Only checksummed files can be cached.

inodes

The number of files which have been accessed recently or are being accessed now.

size

The size of the files, in kilobytes.

RAM

Memory used by the files, in kilobytes.

fetched

The number of files fetched by the command.

uncached

The number of files only in container’s private area.

cached

The number of files which have copies in the PFCache area and their percentage in fetched.

pfcache verify

Verifies the integrity of the specified mounted memory and IOPS deduplication cache and deletes corrupt files.

Syntax
pfcache verify <cache_dir>
Table 86. Options
Name Description

<cache_dir>

Memory and IOPS deduplication cache image location.

prl_disk_tool

The prl_disk_tool utility is used to manage virtual hard disk drives.

prl_disk_tool compact

Removes all empty blocks from the expanding virtual disk to reduce its size on the physical hard disk. The virtual disk must be formatted to NTFS, ext2/ext3/ext4, btrfs, or xfs.

Syntax
prl_disk_tool compact --hdd <disk_path> [--force]
prl_disk_tool compact -i, --info --hdd <disk_path>
Table 87. Options
Name Description

--hdd <disk_path>

Full path to the virtual disk.

--force

Forces the compacting operation for suspended virtual disks.

-i, --info

Do not compact the virtual disk; just display the information about the size the disk  will have after compacting.

prl_disk_tool merge

Merges all snapshots of the virtual hard disk.

Syntax
prl_disk_tool merge --hdd <disk_path>
Table 88. Options
Name Description

--hdd <disk_path>

Full path to the virtual disk.

prl_disk_tool resize

Changes the capacity of the specified virtual disk. During resizing, all data present on the disk volumes are left intact. You can also resize the last partition using the --resize_partition option. The supported file systems are NTFS, ext2/ext3/ext4, btrfs, or xfs.

Syntax
prl_disk_tool resize --size <size>[K|M|G|T] [--resize_partition] --hdd <disk_path>
                     [--force]
prl_disk_tool resize -i, --info --hdd <disk_path>
Table 89. Options
Name Description

--size

New size of the virtual disk. It can be set either in kilobytes (K), megabytes (M, default), gigabytes (G), or terabytes (T).

--resize_partition

Resizes the last partition of the specified virtual disk.

Note

Note: You cannot reduce XFS filesystems (the default choice for CentOS 7 and Red Hat Enterprise Linux 7).

--hdd <disk_path>

Full path to the virtual disk.

--force

Forces the resizing operation for suspended virtual disks.

-i, --info

Do not resize the virtual disk; just show the size the disk will have after resizing.

vzpid

This utility prints the ID of the container where the process is running.

Syntax
vzpid <pid> [...]

Multiple process IDs can be specified as arguments.

vzps, vztop

These two utilities can be run on the server just as the standard Linux ps and htop utilities. For information on the ps and htop utilities, consult their man pages. The vzps and vztop utilities provide certain additional functionality related to monitoring separate containers running on the server.

The vzps utility has the following functionality added: the -E <CT_name> command-line switch can be used to show only the processes running inside the container with the specified ID.

The vztop utility has the CTID column added to display the container UUID where a particular process is running  (0 stands for the server itself).

vzsplit

This utility is used to generate a sample container configuration file with a set of system resource control parameters.

Syntax
vzsplit [-n <num>] [-f <sample_name>] [-s <swap_size>]

This utility is used for dividing the server into equal parts. It generates a full set of containers system resource control parameters based on the total physical memory of the server it runs on and the number of containers the server shall be able to run even if the given number of containers consume all allowed resources.

Without any option the utility prompts for the desired number of containers and outputs the resulting resource control parameters to the screen.

Table 90. Options
Name Description

-n <num>

Desired number of containers to be simultaneously run on the server.

-f <sample_name>

Name of the sample configuration to create.

-s <swap_size>

Size of the swap file on the server. It is recommended to specify the swap size to be taken into account when the utility generates sample configurations.

The resulting sample configuration will be created in the /etc/vz/conf directory. The file name will be ve-<sample_name>.conf-sample. Now you can pass <sample_name> as an argument to the --config option of the prlctl create command. If a sample with this name already exists, the utility will output an error message and will not overwrite the existing configuration.

Managing Virtual Machines

prlctl

Virtuozzo virtual machines can be managed using the prlctl command-line utility. The utility is installed on the hardware node during the product installation.

General Syntax

The prlctl utility is used to perform administration tasks on virtual machines. The utility supports a full range of tasks from creating and administering virtual machines to getting statistics and generating problem reports.

Syntax
prlctl <command> <VM_name> [<options>] [-v, --verbose <number>] [--timeout <sec>]
       [-l, --login [<user>[:_<passwd>_]@]<server>] [-p, --read-passwd <file>]]
Table 91. Options
Name Description

<command>

The name of the command to execute.

<VM_name>

The name of the virtual machine to perform the operation on. To obtain the list of the available virtual machines, use the prlctl list command.

<options>

Command options. See individual commands for available options.

-v, --verbose <number>

Enables verbose output. The greater the <number>, the higher the verbosity.

-l, --login [<user>[:<passwd>]@]<server>

Connect to a remote <server> with the specified credentials. If this flag is omitted, the prlctl command is assumed to be run locally.

-p, --read-passwd <file>

Use the password from the file <file> to log in to a remote hardware node, other credentials being specified with the --login option. The --read-passwd option can be specified multiple times in order to form a password stack for operations requiring multiple passwords. Each password must be supplied in a separate file.

To display help, enter prlctl without any options.

prlctl clone

Creates an exact copy of the specified virtual machine.

Syntax
prlctl clone <VM_name> --name <new_name> [--template] [--dst=<path>] [--changesid]
             [--detach-external-hdd <yes|no>]
Table 92. Options
Name Description

<VM_name>

Name of the virtual machine to clone.

--name <new_name>

Name to be assigned to the new virtual machine.

--template

Create a virtual machine template instead of a real virtual machine. Templates are used as a basis for creating new virtual machines.

--dst=<path>

Full path to the directory where the new virtual machine will be stored. If this option is omitted, the new virtual machine will be created in the default directory.

--changesid

Generate a new Windows security identifier (SID) for a Windows-based virtual machine. For this parameter to work, Virtuozzo tools must be installed in the virtual machine.

--detach-external-hdd <yes¦no>

If set to no, hard disks located outside the source virtual machine are not removed from the configuration of the resulting clone. Setting the parameter to yes removes external hard disks from the configuration.

Note

Note: External hard disks are not copied to the cloned virtual machine.

prlctl create

Creates a new virtual machine. A virtual machine can be created from scratch or from a virtual machine template. When created from scratch, the target operating system type or version must be specified. To create a virtual machine from a template, the template name must be passed to the command.

Syntax
prlctl create <VM_name> [<options>]
Table 93. Options
Name Description

<VM_name>

User-defined new virtual machine name. If the name consists of two or more words separated by spaces, it must be enclosed in quotes.

-d, --distribution {<name>¦list}

The operating system distribution the virtual machine will be optimized for. For the full list of supported distributions, refer to the prlctl man pages.

--ostemplate <template_name>

The name of the virtual machine template from which to create the new virtual machine. Use the prlctl list --template command to obtain the list of the available templates.

--dst <vm_path>

User-defined new VM home path. If this parameter is omitted, the VM will be placed in the default virtual machine directory.

--uuid <uuid>

A custom UUID to assign to the virtual machine.

Note

Note: You can use either --distribution or --ostemplate, not both options at once.

When creating a virtual machine from scratch, you may specify the operating system family or version. If an operating system version is specified using the --distribution parameter, the virtual machine will be configured for that operating system. If an operating system family is specified using the --ostype parameter, the virtual machine will be configured for the default version of this OS family. The default versions are determined internally by Virtuozzo. The best way to find out the default versions used in your Virtuozzo installation is by creating a sample virtual machine.

prlctl delete

Deletes a virtual machine from the hardware node. The command removes a virtual machine from the Virtuozzo registry and permanently deletes all its files from the server. Once completed, this operation cannot be reversed.

Syntax
prlctl delete <VM_name>
Table 94. Options
Name Description

<VM_name>

The name of the virtual machine to delete.

prlctl enter

Creates a command prompt channel to a virtual machine. By using this command, you can create a command prompt channel and execute commands in a virtual machine. Virtuozzo tools must be installed in a virtual machine to use this utility.

Syntax
prlctl enter <VM_name>
Table 95. Options
Name Description

<VM_name>

The name of the virtual machine.

prlctl exec

Executes a command inside a virtual machine. Virtuozzo tools must be installed in a virtual machine to use this utility. By default, running prlctl exec <command> is equivalent to executing bash -c <command> in a Linux VM or cmd /c <command> in a Windows VM.

Syntax
prlctl exec <VM_name> [--without-shell] <command>
Table 96. Options
Name Description

<VM_name>

The name of the virtual machine.

<command>

A command to execute.

--without-shell

Run commands directly without bash or cmd shell.

prlctl list

Displays a list of virtual machines on the Hardware Node. Displays information on virtual machines on the Hardware Node.

Syntax
prlctl list --vmtype vm [-a, --all] [-o, --output <field>[,...]]
            [-s, --sort {<field>|-<field>}] [-t, --template] [-j, --json]
prlctl list -i, --info --vmtype vm [<VM_name>] [-f, --full] [-t, --template]
                                   [-j, --json]
Table 97. Options
Name Description

-a, --all

List all running, stopped, suspended, and paused virtual machines. If this and the rest of the parameters are omitted, only the running virtual machines will be displayed.

-t, --template

List available virtual machine templates instead of actual virtual machines.

-o, --output <field>[,…​]

Display only the specified fields. Type field names in lower case. Separate multiple fields with commas. For the list of fields, see [_prlctl_list_output_parameters].

-s, --sort {<field>¦-<field>}

Sort virtual machines by the specified field in either ascending or descending order.

-i, --info

Display detailed information about the specified virtual machine.

-f, --full

Display detailed information about network cards in virtual machines. Used with the --info option.

<VM_name>

The name of the virtual machine for which to display the detailed information. If not specified, the information will be displayed for all registered virtual machines.

-j, -json

Produce machine-readable output in the JSON format.

prlctl list Output Parameters

Listed below are the parameters that can be specified after the -o switch.

Name Output Column Description

uuid

UUID

Virtual machine UUID.

hostname

HOSTNAME

Virtual machine hostname.

name

NAME

Virtual machine name.

description

DESCRIPTION

Virtual machine description.

ostemplate

OSTEMPLATE

Specifies the name of the OS template the virtual machine is based on (e.g., centos-6-x86_64).

ip

IP_ADDR

Virtual machine IP address.

status

STATUS

Virtual machine status (e.g., running or stopped).

numproc

NPROC

The number of processes and threads allowed.

mac

MAC

Network device’s MAC address.

netif

NETIF

Network devices in the virtual machine .

iolimit

IOLIMIT

The bandwidth the virtual machine is allowed to use for its disk input and output (I/O) operations, in bytes per second.

ha_enable

HA_ENABLE

Indicates whether the virtual machine is joined to the High Availability Cluster.

ha_prio

HA_PRIO

Virtual machine priority in the High Availability Cluster (0 is the lowest). Higher-priority virtual environments are restarted first in case of failures.

prlctl migrate

Migrates a virtual machine from one host to another.

Syntax
prlctl migrate <VM_name> <destination_server>[/<VM_name>]
               [--dst=<path>] [--keep-src] [--switch-template] [--changesid]
               [--ssh <options>]
Table 98. Options
Name Description

<VM_name>

The source virtual machine name.

<source_server>

The source server information. Use the following format to specify this info: [<user>[:<password>]@]<server_IP_address_or_hostname>[:<port>].

<destination_server>

The destination server information. If omitted, the migration will be performed locally. Use the following format to specify this info: [<user>[:<password>]@]<server_IP_address_or_hostname>[:<port>].

--dst=<path>

Name and path of the directory on the destination server where the virtual machine files should be stored.

--keep-src

If this option is included, the original virtual machine will be left intact on the source server. If this option is omitted, the original virtual machine will be removed from the source server.

--switch-template

Converts the virtual machine to a template and a template to a virtual machine. For example, if the source virtual machine was a template, it becomes a full featured virtual machine after the migration, and vice versa.

--changesid

Changes the resulting virtual machine SID.

--ssh

Additional options to pass to ssh to connect to the destination server. All standard ssh options are supported.

Note

Note: Do not specify the destination server hostname or IP address as an ssh option.

prlctl mount, umount

Mounts or unmounts the hard disks of a virtual machine to the /vz/root/<UUID> directory on the hardware node.

Syntax
prlctl mount <VM_name> [-o <ro|rw> | --info]
prlctl umount <VM_name>
Table 99. Options
Name Description

<VM_name>

Virtual machine name.

-o <ro¦rw>

Sets access rights:

  • ro - read-only,

  • rw - read-write.

--info

Show information about the mounted virtual disks.

prlctl move

Moves the files of a virtual machine to a new location on the same server. The virtual machine must be stopped or suspended.

Syntax
prlctl move <VM_name> --dst=<path>
Table 100. Options
Name Description

<VM_name>

Virtual machine name.

--dst=<path>

Path to the new virtual machine files location.

prlctl pause, suspend, resume

Pause, suspend, and resume a virtual machine.

Syntax
prlctl pause <VM_name>
prlctl suspend <VM_name>
prlctl resume <VM_name>
Table 101. Options
Name Description

<VM_name>

The name of the virtual machine to pause, suspend, or resume.

The pause command pauses a virtual machine. To continue the virtual machine operation, use the prlctl start command.

The suspend command suspends the virtual machine operation. When a running virtual machine is suspended, the state of the virtual machine processes is saved to a file on the host. After that, the machine is stopped. To resume the machine, use the resume command.

prlctl problem-report

Obtains a problem report for the specified virtual machine and either sends it to the Virtuozzo technical support team or displays it on the screen.

Syntax
prlctl problem-report <VM_name> <-d, --dump|-s, --send  [--proxy [<user> \
                      [:<passwd>]@<proxyhost>[:<port>]]] [--no-proxy]>
Table 102. Options
Name Description

<VM_name>

The name of the virtual machine for which to obtain the problem report. If the name consists of separate words, it must be enclosed in quotes.

-d, --dump

Collect technical data about a virtual machine and display it on the screen. You can also pipe the output to a file and then send it to the Virtuozzo technical support team to analyze your problem.

-s, --send

Send the generated problem report to the Virtuozzo technical support team.

--proxy [<user>[:<passwd>]@ \
<proxyhost>[:<port>]]

Use the specified information to send the generated report through a proxy server, if you use one to connect to the Internet.

--no-proxy

Do not use a proxy server to send the generated report. This is the default behavior, so you can omit this parameter.

prlctl register, unregister

The register command is used to register a virtual machine with Virtuozzo.

The unregister command removes a virtual machine from the Virtuozzo registry.

Syntax
prlctl register <path> --preserve-uuid <yes|no>
prlctl unregister <VM_name>
Table 103. Options
Name Description

<path>

An absolute path to the virtual machine directory.

<VM_name>

The name of the virtual machine to remove from the Virtuozzo registry.

--preserve-uuid <yes¦no>

Specifies what to do with the UUID (universally unique identifier). If you specify yes, the UUID is preserved. If you specify no, the UUID is regenerated (default behavior).

Use the register command when you have a virtual machine on the server that does not show up in the list of the virtual machines registered with the Virtuozzo. This can be a machine that was previously removed from the registry or a machine that was copied from another location.

The unregister command removes a virtual machine from the Virtuozzo registry, but does not delete the virtual machine files from the server. You can re-register such a machine with Virtuozzo later using the register command.

prlctl reset-uptime

Resets a virtual machine uptime counter as well as count start date and time.

Syntax
prlctl reset-uptime <VM_name>
Table 104. Options
Name Description

<VM_name>

Virtual machine name. Names consisting of multiple words must be enclosed in quotes.

prlctl set

The prlctl set command is used to modify the configuration of a virtual machine and manage virtual machine devices. The following subsections provide technical information on how to use the command to perform these tasks.

Modifying Virtual Machine Configuration

The prlctl set command is used to modify the virtual machine configuration parameters.

Syntax
prlctl set <VM_name> [--cpus <number>] [--memsize <number>]
           [--videosize <number>] [--memguarantee <percentage>]
           [--mem-hotplug <on|off>] [--distribution _<name>] [--description <desc>]
           [--autostart <on|off|auto>] [--autostart-delay <number>]
           [--autostop <stop|suspend>] [--applyconfig <conf>] [--name <new_name>]
           [--start-as-user <administrator|owner|<user>:_<passwd>_]
           [--vnc-mode <auto|manual|off> {--vnc-passwd <passwd> | --vnc-nopasswd}]
           [--vnc-port <port>] [--vnc-address <address>] [--cpu-hotplug <on|off>]
           [--cpuunits <units>] [--cpulimit {<percent>|<megahertz>}]
           [--ioprio <priority>] [--iolimit <limit>] [--iopslimit <limit>]
           [--cpumask {<N>[,N,N1-N2] | all}] [--offline-management <on|off>]
           [--offline-service <service_name>] [--userpasswd <user>:<passwd>
           [--crypted]] [--rate <rate>] [--ratebound <on|off>_]
           [--apply-iponly <yes|no>] [--efi-boot <on|off>]
           [--tools-autoupdate <on|off>]
Table 105. Options
Name Description

<VM_name>

Target virtual machine name.

--cpus <number>

Number of virtual CPUs in the virtual machine. If the server has several CPU cores, this option also defines the number of CPUs shown to users from inside a virtual machine.

--memsize <number>

The amount of memory (RAM) available to the virtual machine, in megabytes. You can use the following suffixes to specify measurement units:

  • G for gigabytes

  • M for megabytes

  • K for kilobytes

  • B for bytes

--videosize <number>

The amount of video memory available to the virtual machine graphics card. You can use the following suffixes to specify measurement units:

  • G for gigabytes

  • M for megabytes

  • K for kilobytes

  • B for bytes

--memguarantee <size>

Sets a percentage of virtual machine’s RAM that said VM is guaranteed to have. By default, set to 40%.

--mem-hotplug <on¦off>

Enables or disables memory (RAM) hotplug support in the virtual machine. This feature is disabled in the virtual machine by default. The guest operating system must support memory hotplug for this functionality to work.

--distribution <name>

Optimize the virtual machine for use with  the  operating  system <name>. You can get the list of available distributions using the prlctl set <VM_name> -d list command.

--description <desc>

Sets virtual machine description. Descriptions with white spaces must be enclosed in quotation marks.

--autostart <on¦off¦auto>

Defines the virtual machine start-up options:

  • on - the virtual machine is started automatically wen the hardware node starts or the Virtuozzo component responsible for managing virtual machines is disabled.

  • off - the autostart is off. This is the default virtual machine start-up mode.

  • auto - resume the virtual machine state prior to shutting down the hardware node or disabling the Virtuozzo component responsible for managing virtual machines.

If you set this option to on or auto, you must additionally specify the --start-as-user option.

--autostart-delay <number>

Sets the time delay used during the virtual machine automatic startup.

--autostop <¦suspend>

Sets the automatic shutdown mode for the specified virtual machine:

  • stop - the virtual machine is stopped when you shut down the hardware node or disable the Virtuozzo component responsible for managing virtual machines.

  • suspend - the virtual machine is suspended when the hardware node is shut down or the Virtuozzo component responsible for managing virtual machines is disabled.

--applyconfig <conf>

Applies the resource parameter values from the specified VM sample file in /etc/parallels/samples to the virtual machine. The following parameters are applied:

  • all memory-related parameters (both RAM and video)

  • all CPU-related parameters

  • IO and IOPS limits

  • disk size

--name <new_name>

Changes the virtual machine name. You can only change the names of stopped virtual machines.

--start-as-user <administrator¦owner¦<user>:<passwd>

Specifies the account to use to autostart the virtual machine:

  • administrator - start the virtual machine as the administrator of the host operating system.

  • owner - start the virtual machine as the virtual machine owner.

  • <user>:<passwd> - start the virtual machine as the specified user.

--vnc-mode <auto¦manual¦off>

Enables or disables access to the virtual machine via the VNC protocol.

--vnc-port <port>

Sets the VNC port number.

--vnc-passwd <passwd> ¦ --vnc-nopasswd

Sets the VNC password or specifies that no password is needed for VNC connections. Either of these options is mandatory for any VNC connection.

--vnc-address <address>

Sets the IP address to use for logging in to the virtual machine via VNC. It must be one of the IP addresses assigned to the hardware node. By default, you can use any of the IP addresses of the hardware node to log in to the virtual machine.

--cpu-hotplug <on¦off>

Enables or disables CPU hotplug support in the virtual machine. This feature is disabled by default. The guest operating system must support CPU hotplug for this functionality to work.

--cpuunits <units>

Sets the CPU weight for the virtual machine. This is a positive integer number that defines how much CPU time the virtual machine can get as compared to the other virtual machines and containers running on the server. The larger the number, the more CPU time the virtual machine can receive. Possible values range from 8 to 500000. If this parameter is not set, the default value of 1000 is used.

--cpulimit {<percent>¦<megahertz>}

CPU limit, in percent or megahertz (MHz) the virtual machine is not allowed to exceed.  By default, the limit is set in percent. To set the limit in MHz, specify "m" after the value.

Note

Note: If the server has 2 processors, the total CPU time equals 200%.

--ioprio <priority>

Disk I/O priority level from 0 to 7. The default is 4.

--iolimit <limit>

Disk I/O bandwidth limit. The default is 0 (no limit). By default the limit is set in megabytes per second. You can use the following letters following the number to specify units of measure:

  • G - gigabytes per second (e.g., 1G).

  • K - kilobytes per second (e.g., 10K).

  • B - bytes per second (e.g., 100B).

The default I/O bandwidth limit for all newly created virtual machines is set to 0, which means that no limits are applied to them.

--iopslimit <limit>

Maximum number of disk input and output operations per second a virtual machine is allowed to perform. By default, any newly created container does not have the IOPS limit set and can perform so many disk I/O operations per second as necessary.

--cpumask {<N>[,N,N1-N2] ¦ all}

An affinity mask indicating what CPU(s) the virtual machine processes should be run on. You can specify a list of CPUs identified by their index numbers separated by commas (0, 1, 2, 3, etc.) or a range (4-6). To make all CPUs available for the virtual machine processes specify --cpumask all.

--offline-management <on¦off>

Turns the offline management on or off.

--offline-service <service_name>

The name of the service to use for offline management.

--userpasswd <user>:<passwd>

Sets the password for the specified user in the virtual machine. If the user account does not exist, it will be created. Virtuozzo tools must be installed in the virtual machine for the command to work.

--crypted

Used with --userpasswd. Indicates that the specified password is already a hash.

--rate <rate>

Sets the guaranteed outgoing traffic rate in Kbps for the virtual machine.

--ratebound <on¦off>

Turns the network traffic rate limitation set by the --rate parameter (above) on or off. The default value is off.

--apply-iponly <yes¦no>

If set to yes, the hostname, nameserver, and search domain settings from the virtual machine configuration file are ignored.

--efi-boot <on¦off>

If set to on, the virtual machine will boot using the EFI firmware. If set to off (default), the virtual machine will boot using the BIOS firmware.

--tools-autoupdate <on¦off>

Enables or disables automatic update of Virtuozzo tools inside Windows virtual machines. If set to on, Virtuozzo tools are updated automatically on user log in. A reboot is required to complete the update. If set to off, Virtuozzo tools are not updated automatically, so that you can do it manually at a convenient time.

Managing Virtual Devices

The prlctl set command allows to add, modify, and delete virtual devices of virtual machines.

Syntax
prlctl set <VM_name> --device-add <dev_type> <options>
prlctl set <VM_name> --device-set <dev_name> <options>
prlctl set <VM_name>  --device-del <dev_name> <options> --destroy-image-force
prlctl set <VM_name>  --device-connect <dev_name>
prlctl set <VM_name>  --device-disconnect <dev_name>
prlctl set <VM_name>  --device-bootorder "dev_name1 dev_name2 [...]"
Table 106. Options
Name Description

<VM_name>

Virtual machine name.

--device-add <dev_type> <options>

Adds a virtual device of the type <dev_type> to a virtual machine. The <dev_type> parameter can be: hdd, cdrom, net, fdd, serial, usb, pci. Except for SCSI and VirtIO hard disks, devices can only be added to stopped virtual machines.

--device-set <dev_name> <options>

Modifies the configuration of the virtual device <dev_name> in a stopped virtual machine.

--device-del <dev_name> <options>

Deletes the virtual device <dev_name> from a stopped virtual machine.

--destroy-image-force

Used with the --device-del option. Deletes a virtual machine HDD even if it is used in that virtual machine’s snapshots.

--device-connect <dev_name>

Connects the virtual device <dev_name> to a running virtual machine.

--device-disconnect +<dev_name>

Disconnects the virtual device <dev_name> from a running virtual machine.

--device-bootorder "dev_name1 dev_name2 [...]"

Specifies the boot order for a virtual machine.

Note

Note: Device names can be obtained with the prlctl list -i command.

The device-related <options> can be subdivided into the following categories:

  • hard disk drives

  • optical disk drives

  • network cards

  • floppy disk drives

  • serial ports

  • USB devices

Each group of options is explained in the following subsections in detail.

Hard Disk Drive Management Options

This group of options is used to add and configure virtual hard disks in a virtual machine. The first syntax uses a file to emulate a hard disk drive. The second syntax connects a physical hard disk on the host server to the virtual machine.

Syntax
prlctl set +<VM_name> {--device-add hdd | --device-set hdd<N>}
           [--image <file>] [--type <expanded|plain>] [--size <size>] [--split]
           [--iface <ide|scsi|virtio>] [--position <pos>] [--enable|--disable]
prlctl set <VM_name> --device-add hdd --device <dev_name> [--position <pos>]
           [--iface <ide|scsi|virtio>]
prlctl set <VM_name> --backup-add <backup_ID> [--disk <disk_name>]
           [--iface <ide|scsi|virtio>] [--position <pos>]
prlctl set <VM_name> --backup-del {<backup_ID>|all}
Table 107. Options
Name Description

<VM_name>

Virtual machine name.

--device-add hdd

Adds a virtual hard disk to the VM. New hard disks are created in the virtual machine directory and are automatically named harddisk<N>.hdd, where <N> is the next available disk index. SCSI and VirtIO hard disks can be added to both running and stopped VMs, IDE disks can only be added to stopped VMs.

--device-set hdd<N>

Modifies the parameters of an existing virtual hard disk. Virtual hard disks are named using the hdd<N> format where <N> is the drive index number starting from 0 (e.g., hdd0, hdd1). To obtain the list of disk names, use the prlctl list command with the --info option.

--image <file>

Specifies an image file that will be used to emulate the virtual disk.

  • If the specified image does not exist, it is created and used to emulate the virtual hard disk.

  • If the specified image exists, it is used to emulate the virtual hard disk.

--device <dev_name>

This option is used to connect a physical hard disk on the hardware node to the virtual machine. You can obtain the names of the existing hard disks on the server using the prlsrvctl info command.

--size <size>

The size of the virtual hard disk, in megabytes. The default size is 65536 MB.

--split

Splits the hard disk image file into 2 GB pieces. You should split a virtual disk if it is stored on a file system that cannot support files larger than 2 GB (e.g., FAT16).

--enable

Enables the specified virtual disk drive. All newly added disk drives are enabled by default (provided the --disable option is omitted).

--disable

Disables the specified virtual disk drive. The disk drive itself is not removed from the virtual machine configuration.

--backup-add <backup_ID>

Attach the backup with the identifier <backup_ID> to the virtual machine as a virtual hard disk. To obtain the backup ID, use the prlctl backup-list -f command.

--disk <disk_name>

Used with --backup-add. The name of the disk in the backup to attach. If a disk is not specified, all disks contained in the backup will be attached. To obtain the disk name(s), use the prlctl backup-list -f command.

+--backup-del {<backup_ID>¦all}

Detach either the backup with the identifier <backup_ID> or detach all backups from the virtual machine.

--iface <ide¦scsi¦virtio>

The disk drive Interface type. If omitted, the SCSI interface will be used.

--position <pos>

The SCSI or IDE device identifier to be used for the virtual disk.

Optical Disk Drive Management Options

This group of options is used to add and configure virtual optical disk drives, such as DVD or CD drives.

Syntax
prlctl set <VM_name> {--device-add cdrom | --device-set cdrom<N>}
           {--device <dev_name> | --image <file>} [--iface <ide|scsi>]
           [--position <pos>] [--enable|--disable] [--connect|--disconnect]
Table 108. Options
Name Description

<VM_name>

Virtual machine name.

--device-add cdrom

Adds a DVD/CD drive to the virtual machine.

--device-set cdrom<N>

Modifies the parameters of an existing virtual optical disk. The <N> postfix indicates the drive index number. To obtain the list of the available drives, use the prlctl list command with the --info option.

--device <dev_name>

The name of the physical optical disk to connect to the virtual machine.

--image <file>

The name of an existing disk image file to mount in the virtual machine. Currently, the following image file formats are supported: .iso, .cue, .ccd, and .dmg. The image must not be compressed and/or encrypted.

--iface <ide¦scsi>

Interface type:

  • ide - IDE disk.

  • scsi - SCSI disk (default).

--position <pos>

The SCSI or IDE device identifier to be used for the DVD/CD drive. You can use one of the following formats for specifying IDs: <ID>:_<bus>_, <ID>-<bus>, <ID>. For example, if you specify 3:0 (or 3-0 or 3) as <number> for a SCSI drive, the guest OS will see the drive as having ID 3 on SCSI bus 0.

--enable

Enables the specified DVD/CD drive. All newly added drives are enabled by default (provided the --disable option is omitted).

--disable

Disables the specified optical disk drive. The disk drive itself is not removed from the virtual machine configuration.

--connect

Automatically connect the specified optical disk drive during the virtual machine startup process.

--disconnect

Do not automatically connect the specified optical disk drive during the virtual machine startup process.

Network Adapter Management Options

This group of options is used to manage virtual network adapters in a virtual machine.

Syntax
prlctl set <VM_name> {--device-add net | --device-set net<N>}
           {--type routed | --network <network_ID>} [--mac {<addr>|auto}]
           [{--ipadd <addr>[/<mask>] | --ipdel <addr>[/<mask>] | --dhcp <yes|no> |
           --dhcp6 <yes|no>}] [--gw <gw>] [--gw6 <gw>]
           [--nameserver <addr>] [--searchdomain <addr>]
           [--configure <yes|no>] [--ipfilter <yes|no>] [--macfilter <yes|no>]
           [--preventpromisc <yes|no>] [--enable|--disable]
           [--connect|--disconnect] [--adapter-type <e1000|rtl|virtio>]
Table 109. Options
Name Description

<VM_name>

Virtual machine name.

--device-add net

Adds a new virtual network adapter to the virtual machine.

--device-set net<N>

Modifies an existing virtual network adapter. To obtain the list of the available adapters, use the prlctl list command with the --info option.

--type routed

Sets the networking mode for the virtual network adapter to "routed". In this mode, the network adapter is communicating with the outside world through an internal virtual network adapter.

--network <network_ID>

Sets the networking mode for the virtual network adapter to "virtual_network". In this mode the adapter is connected to a virtual network specified by <network_ID>.

--mac {<addr>¦auto}

Specifies the MAC address to assign to an existing network adapter. Specify a desired MAC address using the addr parameter value or use the auto option to generate the existing address automatically.

--ipadd <addr>[/<mask>]

Adds an IP address and a mask (optional) to the network adapter.

--ipdel <addr>[/<mask>]

Deletes an IP address from the network adapter.

--dhcp <yes¦no>

Specifies whether the virtual network adapter should obtain the IPv4 settings through a DHCP server.

--dhcp6 <yes¦no>

Specifies whether the virtual network adapter should obtain the IPv6 settings through a DHCP server .

--gw <gw>

The default gateway to be used by the virtual machine.

--gw6 <gw>

The default IPv6 gateway to be used by the virtual machine.

--nameserver <addr>

The default DNS server address to be used by the virtual machine.

--searchdomain <addr>

The default search domain to be used by the virtual machine.

--configure <yes¦no>

If set to yes, the settings above are applied to the virtual network adapter instead of its original settings. Configuring any of the settings above automatically sets this option to yes.

--ipfilter <yes¦no>

Determines if the specified network adapter is configured to filter network packages by IP address. If set  to yes, the adapter is allowed to send packages only from IPs in the network adapter IP addresses list.

--macfilter <yes¦no>

Determines if the specified network adapter is configured to filter network packages by MAC  address.  If set to yes, the adapter is allowed to send packages only from its own MAC address.

--preventpromisc <yes¦no>

Determines if  the  specified  network adapter should reject packages not addressed to its virtual machine. If set to yes, the adapter will drop such packages.

--enable¦--disable

Enables or disable the network adapter. If omitted during the adapter creation, the adapter will be enabled.

--connect¦--disconnect

Connects or disconnects the network adapter. When disconnected, the adapter is not removed from the virtual machine.

--adapter-type <e1000¦rtl¦virtio>

Emulated network adapter:

  • e1000 - Intel 82545EM,

  • rtl - Realtek RTL8029,

  • virtio - VirtIO.

    Note

    Note: The adapter requires no additional configuration on supported Linux and FreeBSD guest operating systems. However, additional drivers need to be installed on Windows Server 2012 R2 guest OSes. For the drivers, visit https://alt.fedoraproject.org/pub/alt/virtio-win/latest/. The VirtIO adapter is not supported on the Windows Server 2008 guest operating systems.

Floppy Disk Drive Management Options

This group of options is used to add a floppy disk drive to a virtual machine and to modify the existing virtual floppy disk drive.

Syntax
prlctl set <VM_name> {--device-add fdd | --device-set fdd0}
           {--device <dev_name> | --image <file>}
           [--enable|--disable] [--connect|--disconnect]
Table 110. Options
Name Description

<VM_name>

Virtual machine name.

--device-add fdd

Adds a new floppy disk drive to the virtual machine.

--device-set fdd0

Modifies the parameters of the existing virtual floppy disk drive.

--device <dev_name>

The name of the physical floppy disk drive to connect to the virtual machine. If this parameter is omitted, a floppy drive image emulating the floppy disk drive will be created.

--image <file>

The name and path of an existing floppy disk image file (usually floppy.fdd) to mount in the virtual machine.

--enable

Enables the specified floppy disk drive. All newly added floppy drives are enabled by default (provided the --disable option was omitted during the drive creation).

--disable

Disables the specified floppy disk drive. The drive itself is not removed from the virtual machine configuration.

--connect

Connect the specified floppy disk drive automatically during the virtual machine  startup process.

--disconnect

Use this option if you don’t want the specified floppy disk drive automatically connected to the virtual machine on its start.

Serial Port Management Options

This group of options is used to manage serial ports in a virtual machine.

Syntax
prlctl set <VM_name> {--device-add serial | --device-add serial<N>}
           {--device <dev_name> | --output <file> | --socket <name>}
           [--enable|--disable] [--connect|--disconnect]
Table 111. Options
Name Description

<VM_name>

Virtual machine name.

--device-add serial

Adds a new serial port to the virtual machine.

--device-set serial<N>

Modifies the parameters of an existing serial port.

--device <dev_name>

The name of the physical serial port to which to connect the virtual machine.

--output <file>

The name and path of the output file to which to connect the virtual serial port.

--socket <name>

The name of the physical socket to which to connect the virtual serial port.

--enable¦--disable

Enables or disables the virtual serial port. All newly added serial ports are enabled by default (provided the --disable option is omitted).

--connect

Automatically connect the virtual serial port during the virtual machine startup process.

--disconnect

Do not automatically connect the virtual serial port during the virtual machine startup process.

USB Controller Management Options

This group of options is used to manage the USB controller in a virtual machine.

Syntax
prlctl set <VM_name> --device-add usb [--enable|--disable]
Table 112. Options
Name Description

<VM_name>

Virtual machine name.

--device-add usb

The type of the virtual device to add to the virtual machine (in this instance, a USB device).

--enable¦--disable

Enables or disables the USB controller. The controller is enabled by default (provided the --disable option is omitted).

Removing Devices from Virtual Machines

The --device-del option is used to remove virtual devices from a virtual machine.

Syntax
prlctl set <VM_name> --device-del <dev_name> [--detach-only|--destroy-image]
Table 113. Options
Name Description

<dev_name>

The name of the virtual device to delete from the virtual machine. To obtain the list of virtual devices, use the prlctl list -i command.

--detach-only

Deletes the information about the specified device from the virtual machine configuration.

--destroy-image

Deletes the information about the specified device from the virtual machine configuration and removes the device from the server.

prlctl snapshot, snapshot-list, snapshot-switch, snapshot-delete

Takes, displays, reverts to, and deletes snapshots of a running virtual machine.

Syntax
prlctl snapshot <VM_name> [-n, --name <name>] [-d, --description <desc>]
prlctl snapshot-list <VM_name> [-t, --tree] [-i, --id <snapshot_ID>]
prlctl snapshot-switch <VM_name> -i, --id <snapshot_ID>
prlctl snapshot-delete <VM_name> -i, --id <snapshot_ID>
Table 114. Options
Name Description

<VM_name>

Virtual machine name.

-n, --name <name>

User-defined snapshot name. Names with white spaces must be enclosed in quotation marks.

-d, --description <desc>

User-defined snapshot description. Descriptions with white spaces must be enclosed in quotation marks.

-t, --tree

Displays the snapshot list as a tree. The default display format is tabular with Parent Snapshot ID and Snapshot ID as columns.

-i, --id <snapshot_ID>

  • Use with prlctl snapshot-list to specify the ID of the snapshot to use as the root. If this parameter is omitted, the entire snapshot tree will be displayed.

  • Use with prlctl snapshot-switch to specify the ID of the snapshot to revert to.

  • Use with prlctl snapshot-delete to specify the ID of the snapshot to delete.

Note

Note: If the snapshot you want to delete has child snapshots derived from it, they will not be deleted.

prlctl start, stop, restart, reset, status

Start, stop, reset, and check the status of a virtual machine.

Syntax
prlctl start <VM_name>
prlctl stop <VM_name> [--kill]
prlctl restart <VM_name>
prlctl reset <VM_name>
prlctl status <VM_name>
Table 115. Options
Name Description

<VM_name>

The name of the virtual machine to start, stop, restart, reset, or check the status of.

--kill

Perform a hard virtual machine shutdown. If this option is omitted, an attempt to perform a graceful shutdown will be made.

The stop command can perform a hard or a graceful virtual machine shutdown. If the --kill parameter is included, the hard shutdown will be performed. If the parameter is omitted, the outcome of the graceful shutdown attempt will depend on the following:

  • If Virtuozzo tools are installed in a virtual machine, the graceful shutdown will be performed using its facilities.

  • If Virtuozzo tools are not installed, the command will try to perform a graceful shutdown using ACPI. Depending on the ACPI support availability in the guest operating system, this may work or not.

The restart command first gracefully shuts down a virtual machine and then starts it again.

The reset command resets a virtual machine without shutting it down.

Note

Note: Resetting a VM may result in loss of unsaved data stored in that VM.

The start command can be used to start a stopped virtual machine or to resume a paused virtual machine).

Managing Virtual Machine Backups

This section describes the utilities you can use for creating and managing virtual machine backups.

prlctl backup, backup-list, backup-delete, restore

Creates, lists, deletes or restores virtual machine backups.

Syntax
prlctl backup <VM_name> [-f, --full] [-i, --incremental] [--description <desc>]
              [-s, --storage [<user>[:<passwd>]@]<server>[:<port>]]
              [--no-compression]
prlctl backup-list [<VM_name>] [-f, --full] [--localvms]
                   [-s, --storage [<user>[:<passwd>]@]<server>[:<port>]]
prlctl backup-delete {<VM_name> | -t, --tag <backup_ID>}
prlctl restore {<VM_name> | -t, --tag <backup_ID>} [-n, --name <new_name>]
               [--dst=<path>] [-s, --storage [<user>[:<passwd>]@]<server>[:<port>]]
Table 116. Options
Name Description

<VM_name>

Virtual machine name.

  • Use with prlctl backup to create a backup of the specified virtual machine.

  • Use with prlctl backup-list to list backups of the specified virtual machine.

  • Use with prlctl backup-delete to delete all backups of the specified virtual machine.

  • Use with prlctl restore to restore the most recent backup of the specified virtual machine.

-s, --storage [<user>[:<passwd>]@]<server>[:<port>]

Specifies a remote backup server address, port, and credentials. If this option is omitted, the backup will be saved on the default backup server that can be configured using the prlsrvctl set command.

--description <desc>

Backup description. Descriptions with white spaces must be enclosed in quotation marks.

-f, --full

  • Use with prlctl backup to create a full backup of the virtual machine. A full backup contains all virtual machine data.

  • Use with prlctl backup-list to display full backup information.

-i, --incremental

Create an incremental backup of the virtual machine. An incremental backup contains only the files changed since the previous full or incremental backup. This is the default backup type.

--localvms

List local backups only.

-t, --tag <backup_ID>

The ID of the backup to restore or delete.

-n, --name <new_name>

A new name to assign to the restored virtual machine. If omitted, the virtual machine will be restored with the original name.

--dst=<path>

Restore the virtual machine to the specified directory on the hardware node. If this option is omitted, the virtual machine will be restored to /var/parallels/<VM_name>.

--no-compression

Does not compress a backup image during its creation.

prl_disk_tool

The prl_disk_tool utility is used to manage virtual hard disk drives.

Syntax
prl_disk_tool <command> [<options>] --hdd <disk_path> [<options>]
prl_disk_tool --help

prl_disk_tool compact

Removes all empty blocks from the expanding virtual disk to reduce its size on the physical hard disk. The virtual disk must be formatted to NTFS, ext2/ext3/ext4, btrfs, or xfs.

Syntax
prl_disk_tool compact --hdd <disk_path> [--force]
prl_disk_tool compact -i, --info --hdd <disk_path>
Table 117. Options
Name Description

--hdd <disk_path>

Full path to the virtual disk.

--force

Forces the compacting operation for suspended virtual disks.

-i, --info

Do not compact the virtual disk; just display the information about the size the disk  will have after compacting.

prl_disk_tool merge

Merges all snapshots of the virtual hard disk.

Syntax
prl_disk_tool merge --hdd <disk_path>
Table 118. Options
Name Description

--hdd <disk_path>

Full path to the virtual disk.

prl_disk_tool resize

Changes the capacity of the specified virtual disk. During resizing, all data present on the disk volumes are left intact. You can also resize the last partition using the --resize_partition option. The supported file systems are NTFS, ext2/ext3/ext4, btrfs, or xfs.

Syntax
prl_disk_tool resize --size <size>[K|M|G|T] [--resize_partition] --hdd <disk_path>
                     [--force]
prl_disk_tool resize -i, --info [--units <K|M|G|T>] --hdd <disk_path>
Table 119. Options
Name Description

--size

New size of the virtual disk. It can be set in kilobytes (specify K after the value), megabytes (M), gigabytes (G), or terabytes (T). By default, the size is set in megabytes.

--resize_partition

Resizes the last partition of the specified virtual disk.

Note

Note: You cannot reduce XFS filesystems (the default choice for CentOS 7 and Red Hat Enterprise Linux 7).

--hdd <disk_path>

Full path to the virtual disk.

--force

Forces the resizing operation for suspended virtual disks.

-i, --info

Do not resize the virtual disk; just show the size the disk will have after resizing.

--units

Displays the disk size in kilobytes (K), megabytes (M, default), gigabytes (G), or terabyles (T).