Open main menu

OpenVZ Virtuozzo Containers Wiki β

Changes

Virtual network device

2,139 bytes added, 16:59, 10 February 2013
Adding IP address to a container
Vitual Virtual network device (<code>venet</code>) is the default network device for a [[VEcontainer]]. This Due to [[w:Network_Layer|Layer 3]] employed by OpenVZ's venet, this network device looks like a peerpoint-to-peer point connection between [[VEcontainer]] and the [[VE0CT0|host system]]. It does packet switching based on IP header. This is a default network device for VE container (an alternative is [[veth]] device).
Venet drop ip-packets '''from''' the container with a source address, and '''in''' the container with the destination address, which is not corresponding to an ip-address of the container. Venet device is created automatically on [[VEcontainer]] start. Vzctl scripts set up an appropriate IP address and other settings on venet inside a VEcontainer.
== Usage ==
== Kernel module ==
First of all, check that <code>venetdevvznetdev</code> module is loaded:
<pre>
# lsmod | grep vznetdev
You might want to check /etc/init.d/vz script to make sure the module gets loaded during startup.
=== Adding IP address to a VE container ===
<pre>
vzctl set <VEIDCTID> --ipadd <IP1>[,<IP2>,...] [--save]
</pre>
 
Address can optionally have a netmask specified in the CIDR notation (e.g. 10.1.2.3/25).
{{Note|This option is incremental, so IP addresses are added to already existing ones.}}
==== Example ====
<pre>
vzctl set 101 --ipadd 10.0.0.1 --savevzctl set 101 --ipadd fd00::101 --save
</pre>
After executing this command IP address 10.0.0.1 will be added to VE container 101 and IP configuration will be saved to a VE container configuration file.
=== Removing IP address from a VE container ===
<pre>
vzctl set <VEIDCTID> --ipdel <IP1>[,<IP2>,...] [--save]vzctl set <VEIDCTID> --ipdel all [--save]
</pre>
<pre>
vzctl set 101 --ipdel 10.0.0.1
vzctl set 101 --ipdel fd00::101
</pre>
After executing this command IP address 10.0.0.1 will be removed from VE container 101, but IP configuration will not be changed in VE container config file. And after VE container reboot IP address 10.0.0.1 will be assigned to this container again. == Specific aspects of venet network device == {{Note|If you require a feature which venet is lacking (from the list below), please consider using [[veth]] device (which have [[w:Data_Link_Layer|layer 2]] support.)}} === No [[w:Address_Resolution_Protocol|ARP]] protocol support ===Venet network device is explicitly NOARP, so there is no MAC address.Consequently, it's not possible to make broadcasts inside a [[container]], so software like Samba server or DHCP server will not function (under a container with a venet network device). === No [[w:Network_bridge|bridge]] support ===Venet network device cannot be bridged together and/or with other devices. === No possiblity to assign an IP from the CT ===With venet device, only OpenVZ [[hardware node]] administrator can assign an IP address to a [[container]]. === Limited packet sniffing support ===Some applications using libpcap and similar packages will report an error. === No full support of IPv6 stack ===venet devices are not fully IPv6 compliant. They do not properly support MAC addresses and consequently link local addresses and can not play nice with neighbor discovery or router advertisements, router discovery, or auto-conf. They also require additional modifications to the layer 3 forwarding behaviour of the host via sysctl, to get your venet devices working.Please have a look at the [[Quick installation#sysctl]] section. veth devices do require iptables and ip6tables exceptions on the host for each VE againaddress.  You'll need to use the veth bridging device if you want full IPv6 compliance. See the [[VEs and HNs in same subnets]] article for an example.
== See also ==
* [[Virtual ethernet deviceVeth]]
* [[Differences between venet and veth]]
[[Category: Networking]]
[[Category: HOWTO]]
Anonymous user