Réseau virtuel Comme il a été brièvement indiqué au , VirtualBox fournit huit cartes Ethernet PCI virtuelles pour chaque machine virtuelle. Pour chacune de ces cartes, vous pouvez sélectionner individuellement 1. le matériel qui sera virtualisé ou 2. le mode de virtualisation avec lequel la carte virtuelle agira par rapport à votre matériel réseau physique sur l'hôte. Quatre des cartes réseau peuvent être configurées dans la section « Réseau » des paramètres de la boîte de dialogue dans l'interface graphique de VirtualBox. Vous pouvez configurer les huit cartes réseau en ligne de commande avec VBoxManage modifyvm ; voir . Ce chapitre explique les divers paramètres réseau avec plus détails. Matériel de réseau virtuel Pour chaque carte, vous pouvez sélectionner individuellement le type de matériel qui sera présenté à la machine virtuelle. VirtualBox peut virtualiser les six types de matériels de carte suivants : AMD PCNet PCI II (Am79C970A); AMD PCNet FAST III (Am79C973, celle par défaut) ; Intel PRO/1000 MT Desktop (82540EM); Intel PRO/1000 T Server (82543GC); Intel PRO/1000 MT Server (82545EM); Paravirtualized network adapter (virtio-net). La PCNet FAST III est celle par défaut parce qu'elle est supportée par presque tous les systèmes d'exploitation d'ordinateur et le gestionnaire de démarrage GNU GRUB. Sauf que les adaptateurs de la famille Intel PRO/1000 sont choisis pour certains types de système d'exploitation invités qui n'incluent plus les pilotes de la carte PCNet, tels que Windows Vista. Celle de type Intel PRO/1000 MT Desktop fonctionne avec Windows Vista et les versions supérieures. La variante Server T de la carte Intel PRO/1000 est reconnue par les invités Windows XP sans l'installation de pilotes supplémentaires. La variante Server T facilite les importations OVF à partir d'autres plateformes. L'« adaptateur réseau para-virtualisé (virtio-net » est spécial. Si vous le sélectionnez, VirtualBox ne virtualise pas du matériel réseau classique (qui est supporté par les systèmes d'exploitation habituels hors du PC). VirtualBox s'attend par contre à ce qu'une interface logicielle spéciale pour les environnements virtualisés soient fournies par l'invité, évitant ainsi la complexité d'émuler du matériel réseau et améliorant la performance réseau. À partir de la version 3.1, VirtualBox fournit le support des pilotes de réseau « virtio » industriels, qui font partie du projet libre KVM. Les pilotes de réseau « virtio » sont disponibles pour les systèmes d'exploitation invités suivants : Les noyaux Linux version 2.6.25 ou supérieur peuvent être configurés pour fournir le support de virtio ; certaines distributions ont aussi porté virtio dans des noyaux plus anciens. Pour Windows 2000, XP et Vista, les pilotes virtio peuvent être téléchargés et installés à partir de la page Internet du projet KVM. http://www.linux-kvm.org/page/WindowsGuestDrivers. VirtualBox a aussi un support pour les cadres appelés jumbo, par exemple les paquets réseaux avec plus de 1500 bytes de données fournies pour que vous utilisiez la virtualisation de la carte réseau Intel et le réseau bridgé. En d'autres termes, les cadres jumbo ne sont pas supportés avec les périphériques réseau AMD ; dans ces cas les paquets jumbo seront refusés sans message à la fois dans la direction de la transmission et de la réception. Les systèmes d'exploitation invités qui essaient d'utiliser cette fonctionnalité verront cela comme une perte de paquets, ce qui peut provoquer un comportement inattendu de certaines applications dans l'invité. Cela n'entraîne pas de problèmes avec des systèmes d'exploitation invités dans leur configuration par défaut, vu que les cadres jumbo doivent être explicitement activés. Introduction aux modes réseaux Chacun des huit adaptateurs réseau peut être configuré séparément pour agir dans l'un des cinq modes suivants : Non attaché Dans ce mode, VirtualBox indique à l'invité qu'une carte réseau est présente mais qu'il n'y a pas de connexion -- comme si aucun câble Ethernet n'était branché sur la carte. - De cette façon, il est possible de « débrancher » le câble Ethernet virtuel et de couper la connexion, ce qui peut être utile pour informer un système d'exploitation invité qu'aucune connexion réseau n'est disponible et l'obliger à une reconfiguration. Network Address Translation (NAT) (traduction d'adresse réseau) Si tout ce que vous voulez faire est de naviguer sur Internet, télécharger des fichiers et lire les messages à l'intérieur de l'invité, ce mode par défaut devrait vous suffire et vous pouvez sauter en toute sécurité le reste de cette section. Merci de remarquer qu'il y a certaines limitations quand on utilise le partage de fichiers Windows (voir le pour des détails). Réseau bridgé C'est pour des besoins réseau plus avancés tels que des simulations de réseau et le fonctionnement de serveurs dans un invité. Lorsqu'il est activé, VirtualBox se connecte à une de vos cartes réseaux installées et échange directement des paquets réseaux, contournant la pile réseau de votre système d'exploitation hôte. Réseau interne Ceci peut être utilisé pour créer un genre différent de réseau de type logiciel, visible par les machines virtuelles sélectionnées mais pas pour les applications en fonction sur l'hôte ou dans le monde extérieur. Réseau privé-hôte Ceci peut être utilisé pour créer un réseau contenant l'hôte et un ensemble de machines virtuelles, sans qu'il y ait besoin de l'interface physique de l'hôte. À la place, une interface réseau virtuelle (comme une interface loopback) est créée sur l'hôte, fournissant la connectivité parmi les machines virtuelles et l'hôte. Réseau générique Les modes rarement utilisés partagent la même interface réseau générique mais ils permettent à l'utilisateur de sélectionner un pilote qui peut être inclu dans VirtualBox ou distribué dans un pack d'extension. Pour l'heure, il y a deux sous-modes disponibles : Tunnel UDP On peut l'utiliser pour connecter directement des machines virtuelles en fonction sur des hôtes différents, facilement et de manière transparente, via une infrastructure réseau existante. Réseau VDE (Virtual Distributed Ethernet) Cette option peut être utilisée pour se connecter à un switch Virtual Distributed Ethernet (Ethernet distribué virtuel) d'un hôte Linux ou FreeBSD. Pour l'instant, il implique de compiler VirtualBox à partir des sources, car les paquets d'Oracle ne l'incluent pas. Les sections suivantes décrivent les modes de réseau disponibles avec plus de détails. Network Address Translation (NAT) La traduction d'adresses réseaux (NAT) est la façon la plus simple d'accéder à un réseau externe depuis une machine virtuelle. Habituellement, cela ne demande aucune configuration sur le réseau hôte et le système invité. Pour cette raison, c'est le mode réseau par défaut de VirtualBox. Une machine virtuelle où le NAT est activé agit comme un vrai ordinateur qui se connecte à Internet à travers un routeur. Le « routeur », dans ce cas, est le moteur réseau de VirtualBox qui dresse le plan du trafic venant et à destination de la machine virtuelle de façon intégréte. L'inconvénient du mode NAT est que, tout comme se comporte un réseau privé derrière un routeur, la machine virtuelle est invisible et injoignable à partir et à l'extérieur sur Internet ; vous ne pouvez pas lancer de serveur de cette façon sauf si vous réglez le forwarding (routage) de ports (décrit ci-dessous). Les trames réseau envoyés par le système d'exploitation invité sont reçus par le moteur NAT de VirtualBox, qui extrait les données TCP/IP et les réexpédie en utilisant le système d'exploitation de l'hôte. Sur une application de l'hôte ou sur un autre ordinateur du même réseau que l'hôte, on a l'impression que les données ont été envoyées par l'application VirtualBox sur l'hôte, en utilisant une adresse IP appartenant à l'hôte. VirtualBox écoute les réponses aux paquets envoyés, puis les réemballe et les renvoie sur la machine invitée sur son réseau privé. La machine virtuelle reçoit son adresse réseau et sa configuration sur le réseau privé à partir d'un serveur DHCP intégré dans VirtualBox. L'adresse IP ainsi assignée à la machine virtuelle est en général sur un réseau complètement différent de l'hôte. Comme plus d'une carte d'une machine virtuelle peut être paramétrée pour utiliser NAT, la première carte est connectée au réseau privé 10.0.2.0, la deuxième au réseau 10.0.3.0 et ainsi de suite. Si vous devez modifier la plage d'IP assignées à l'hôte pour une raison quelconque, merci de vous reporter au . Configurer la redirection de ports avec NAT Comme la machine virtuelle est connectée à un réseau privé interne à VirtualBox et qu'il est invisible pour l'hôte, les services réseau de l'invité ne sont pas accessibles pour la machine hôte ou pour d'autres ordinateurs du même réseau. Néanmoins, comme un routeur physique, VirtualBox peut effectuer un transfert de ports sélectionné. Cela signifie que VirtualBox écoute certains ports sur l'hôte et renvoie tous les paquets qui y arrivent vers l'invité, sur un port identique ou différent. Pour une application de l'hôte ou d'autres machines physiques (ou virtuelles) du réseau, c'est comme si le service derrière le proxy fonctionnait finalement sur l'hôte. Cela signifie aussi que vous ne pouvez pas exécuter le même service sur les mêmes ports que sur l'hôte. Néanmoins, vous en tirez les avantages de l'exécution d'un service dans une machine virtuelle : par exemple les services de la machine hôte ou d'autres machines virtuelles ne peuvent pas être compromis ou plantés par une vulnérabilité ou un bogue du service, et le service peut s'exécuter sur un système d'exploitation différent du système hôte. Vous pouvez paramétrer un service invité que vous souhaitez mettre derrière un proxy en utilisant l'outil en ligne de commande VBoxManage ; pour des détails, merci de vous référer au . Vous devrez savoir quels ports sur l'invité le service utilise et décider quels ports utiliser sur l'hôte (vous voudrez souvent, mais pas toujours, utiliser les mêmes ports sur l'invité et sur l'hôte). Vous pouvez utiliser n'importe quel port de l'hôte qui n'est pas déjà utilisé par un service. Par exemple, pour paramétrer des connexions entrantes NAT vers un serveur ssh de l'invité, utilisez la commande suivante : VBoxManage modifyvm "nom VM" --natpf1 "guestssh,tcp,,2222,,22"Avec l'exemple ci-dessus, tout le trafic tcp arrivant sur le port 2222 sur n'importe quelle interface de l'hôte sera transféré sur le port 22 dans l'invité. Le nom du protocole tcp est un attribut obligatoire définissant quel protocole devrait être utilisé pour la redirection (on pourrait aussi utiliser (udp). Le nom guestssh est purement descriptif et sera généré automatiquement si vous n'en spécifiez pas. Le numéro après --natpf nomme la carte réseau, comme dans d'autres paramétrages de VboxManage. Pour supprimer à nouveau cette règle de redirection, utilisez la commande suivante : VBoxManage modifyvm "nom VM" --natpf1 delete "guestssh" Si pour une raison quelconque l'invité utilise une adresse IP statique non attribuée par le serveur DHCP intégré, il faut spécifier l'IP de l'invité lors de l'enregistrement de la règle de redirection : VBoxManage modifyvm "nom VM" --natpf1 "guestssh,tcp,,2222,10.0.2.19,22"Cet exemple est identique au précédent, sauf qu'on dira au moteur NAT qu'on peut trouver l'invité sur l'adresse 10.0.2.19. Pour rediriger tout le trafic entrant d'une interface spécifique de l'hôte vers l'invité, spécifiez l'IP de cette interface hôte comme ceci :VBoxManage modifyvm "nom VM" --natpf1 "guestssh,tcp,127.0.0.1,2222,,22"Ceci redirige tout le trafic TCP arrivant sur l'interface localhost (127.0.0.1) via le port 2222 vers le port 22 de l'invité. Il n'est pas possible de configurer des connexions NAT entrantes pendant que la VM est en fonction. Néanmoins, vous pouvez modifier les paramètres d'une VM actuellement sauvegardée (ou éteinte) dans un instantané. Amorçage PXE avec NAT L'amorçage PXE est à présent supporté par le mode NAT. Le serveur DHCP NAT fournit un fichier d'amorçage nommé sous la forme nomvm.pxe si le répertoire TFTP existe dans le répertoire où est conservé le fichier VirtualBox.xml de l'utilisateur. C'est à l'utilisateur de fournir nomvm.pxe. Limites du NAT Il existe quatre limites du mode NAT dont l'utilisateur devrait être conscient : Limite du protocole ICMP : Certains outils de débogage réseau fréquemment utilisés (tels que ping ou tracerouting) utilisent le protocole ICMP pour envoyer/recevoir des messages. Si le support d'ICMP a été amélioré avec VirtualBox 2.1 (ping devrait maintenant fonctionner), il se peut que d'autres outils ne fonctionnent pas de façon fiable. La réception de broadcasts (diffusion de messages) UDP n'est pas fiable : L'invité ne reçoit pas de façon fiable les broadcasts puisque, pour économiser des ressources, il n'écoute qu'un certain temps après que l'invité ait envoyé des données UDP sur un port particulier. Par conséquent, la résolution de nom NetBios basée sur les broadcasts ne fonctionne pas toujours (mais WINS fonctionne toujours). Vous pouvez utiliser, en contournement, l'IP numérique du serveur désiré noté \\server\share. Les protocoles tels que GRE ne sont pas supportés : Les protocoles autres que TCP et UDP ne sont pas supportés. Cela signifie que certains produits VPN (par exemple PPTP de Microsoft) ne peuvent pas être utilisés. Il y a d'autres produits VPN qui utilisent simplement TCP ou UDP. Redirection des ports de l'hôte < 1024 impossible : Sur les hôtes basés sur Unix (comme Linux, Solaris, Mac OS X) il n'est pas possible de solliciter des ports inférieurs à 1024 depuis des applications non lancées par root. Il en résulte que si vous essayez de configurer une telle redirection de ports, la VM refusera de démarrer. Ces limitations ne devraient normalement pas perturber l'utilisation standard du réseau. Mais la présence du NAT a aussi des effets subtils qui peuvent interagir avec des protocoles qui, normalement, fonctionnent. NFS est un exemple où le serveur est souvent configuré pour refuser les connexions provenant de ports non privilégiés (c'est-à-dire des ports non inférieurs à 1024). Réseau bridgé Avec le réseau bridgé, VirtualBox utilise un pilote de périphérique de votre système hôte qui filtre les données depuis l'adaptateur de votre réseau physique. Ce pilote est donc appelé un pilote « net filter » (filtre de réseau). Ceci permet à VirtualBox d'intercepter des données du réseau physique et d'injecter des données dedans, créant de fait une nouvelle interface réseau logicielle. Quand un invité utilise une telle nouvelle interface logicielle, le système hôte voit l'invité comme si il était physiquement connectés à l'interface par un câble réseau : l'hôte peut envoyer des données à l'invité par cette interface et reçoit des données à partir d'elle. Cela signifie que vous pouvez régler un routage ou un pont entre l'invité et le reste de votre réseau. Pour que cela fonctionne, VirtualBox a besoin d'un pilote de périphérique sur votre système hôte. La façon dont fonctionne le réseau bridgé a été entièrement réécrite avec VirtualBox 2.0 et 2.1, selon le système d'exploitation hôte. Pour les hôtes Mac OS X et Solaris, les pilotes net filter étaient déjà ajoutés à VirtualBox 2.0 (en tant que support dès le départ pour Host Interface Networking (réseau par interface hôte) sur ces plateformes). Avec VirtualBox 2.1, les pilotes net filter ont également été ajoutés pour les hôtes Windows et Linux, en remplaçant les mécanismes présents auparavant dans VirtualBox pour ces plateformes ; surtout sur Linux, la méthode plus récente sous Linux exigeait de créer des interfaces et des ponts (bridge) TAP, ce qui était complexe et ce qui changeait d'une distribution à l'autre. Rien de tout cela n'est nécessaire aujourd'hui. Le réseau bridgé s'appelait avant « Host Interface Networking » (réseau avec interface de l'hôte), et il a été renommé dans la version 2.2 sans modification de son fonctionnement. Même si TAP n'est plus nécessaire sur Linux avec le réseau bridgé, vous pouvez toujours utiliser des interfaces TAP pour certains réglages avancés, puisque vous pouvez connecter une VM à n'importe quelle interface hôte -- ce qui pourrait aussi être une interface TAP. Pour activer le réseau bridgé, tout ce que vous avez besoin de faire est d'ouvrir la boîte de dialogue Paramètres de la fenêtre d'une machine virtuelle, aller sur la page « Réseau » et sélectionner « Réseau bridgé » dans la liste déroulante du champ « Attaché à ». Enfin, sélectionnez l'interface hôte désirée depuis la liste au bas de la page, qui contient les interfaces réseau physiques de vos systèmes. Sur un MacBook typique, par exemple, cela vous permettra de choisir entre « en1: AirPort » (qui est l'interface tans fil) et « en0: Ethernet », qui représente l'interface avec un câble réseau. En fonction de votre système d'exploitation hôte, vous devriez garder à l'esprit les limites suivantes : Sur des hôtes Macintosh, la fonctionnalité est limitée quand on utilise AirPort (le réseau sans fil de Mac) pour le réseau bridgé. Actuellement, VirtualBox ne supporte que l'IPv4 via AirPort. Pour d'autres protocoles tels qu'IPv6 et IPX, vous devez choisir une interface filaire. Sur les hôtes Linux, la fonctionnalité est limitée lors de l'utilisation d'interfaces sans fil pour le réseau bridgé. VirtualBox ne supporte actuellement que l'IPv4 via le sans fil. Pour les autres protocoles tels que IPv6 et IPX, vous devez choisir une interface filaire. En outre, régler le MTU à moins de 1500 bytes sur les interfaces filaires fournies par le pilote sky2 sur la Marvell Yukon II EC Ultra Ethernet NIC est connu pour entraîner des pertes de paquets dans certaines conditions. Sur les hôtes Solaris, il n'y a pas de support pour utiliser les interfaces sans fil. Le filtrage du trafic invité en utilisant IPFilter n'est pas non plus totalement supporté du fait de restrictions techniques du sous-système de réseau de Solaris 11. Avec VirtualBox 2.0.4 et supérieur, il est possible d'utiliser des interfaces réseaux virtuelles Crossbow (Crossbow Virtual Network Interfaces, VNICs) avec le réseau bridgé, mais avec les précautions suivantes : Vous ne pouvez pas partager un VNIC entre plusieurs interfaces réseau virtuelles, ainsi chaque interface réseau invité doit avoir son propre VNIC. La VNIC et l'interface réseau de l'invité qui utilise le VNIC doivent se voir assigner des adresses MAC. Lors de l'utilisation des interfaces VLAN avec VirtualBox, elles doivent être nommées selon le schéma de nommage du hack PPA (comme "e1000g513001"), car sinon, il se peut que l'invité reçoive des paquets sous un format inattendu. Réseau interne Le réseau interne est similaire au réseau bridgé dans le sens où la VM peut communiquer directement avec le monde extérieur. Cependant le « monde extérieur » est limité aux autres VMs qui se connectent au même réseau interne. Même si techniquement, tout ce que vous pouvez faire en utilisant le réseau interne est aussi faisable en utilisant le réseau bridgé, il y a des avantages en matière de sécurité à utiliser le réseau interne. En mode réseau bridgé, tout le trafic passe par une interface physique du système hôte. Il est donc possible d'attacher un détecteur de paquets (tel que Wireshark) à l'interface hôte et d'enregistrer tout le trafic qui passe par lui. Si, pour une raison quelconque, vous préférez que deux ou davantage de VMs de la même machine communiquent de façon privée, tout en cachant leurs données à la fois au système hôte et à et à l'utilisateur, le réseau bridgé n'est donc pas une option. Les réseaux internes sont créés automatiquement selon les besoins, ainsi il n'y a pas de configuration centrale. Chaque réseau interne est simplement identifié par son nom. Une fois qu'il y a plus d'une carte réseau virtuelle active avec le même ID de réseau interne, le pilote de support de VirtualBox va automatiquement « brancher » les cartes et agir comme un switch réseau. Le pilote du support de VirtualBox implémente une switch Ethernet complet et supporte à la fois les trames broadcast/multicast et le mode promiscuité. Afin d'attacher la carte réseau d'une machine virtuelle à un réseau interne, réglez son mode réseau sur « réseau interne ». Il y a deux façons d'accomplir cela : Vous pouvez utiliser la boîte de dialogue « Paramètres » de la VM dans l'interface graphique. Dans la catégorie « Réseau » de la boîte de dialogue des paramètres, sélectionnez « Réseau interne » dans la liste déroulante des modes réseau. Maintenant, sélectionnez le nom d'un réseau interne existant depuis le menu déroulant en-dessous ou entrez un nouveau nom dans le champ d'édition. Vous pouvez utiliser VBoxManage modifyvm "nom VM" --nic<x> intnet Vous pouvez éventuellement spécifier un nom de réseau avec la commande VBoxManage modifyvm "nom VM" --intnet<x> "network name" Si vous ne spécifiez pas de nom de réseau, la carte réseau sera attachée au réseau intnet par défaut. Sauf si vous configurez les cartes réseau (virtuelles) des systèmes d'exploitation invités qui participent au réseau interne pour utiliser des adresses IP statiques, il se peut que vous vouliez utiliser le serveur DHCP construit dans VirtualBox pour gérer les adresses IP pour le réseau interne. Merci de voir le pour des détails. Par mesure de sécurité, l'implémentation Linux du réseau interne n'autorise que les VMs en fonction sous le même ID utilisateur à établir un réseau interne. Réseau privé avec l'hôte (Host-only) Le réseau privé avec l'hôte est un autre mode réseau qui a été ajouté avec la version 2.2 de VirtualBox. On peut le concevoir comme un hybride entre les modes réseau bridgé et interne : comme avec le réseau bridgé, les machines virtuelles peuvent se parler entre elles et avec l'hôte comme si elles étaient connectées sur un switch ethernet physique. De la même façon, comme avec le réseau interne cependant, il n'est pas besoin qu'une interface réseau physique soit présente et les machines virtuelles ne peuvent pas parler au monde extérieur à l'hôte puisqu'elles ne sont pas connectées à une interface réseau physique. Quand on utilise le réseau privé avec l'hôte, VirtualBox crée à la place une nouvelle interface logicielle sur l'hôte qui apparaît ensuite à côté de vos interfaces réseau existantes. En d'autres termes, alors qu'avec un réseau bridgé, on utilise une interface réseau existante pour y attacher les machines virtuelles, avec le mode hôte privé on crée une nouvelle interface « loopback » sur l'hôte. Et alors qu'avec le réseau interne, on ne peut pas voir le trafic entre les machines virtuelles, on peut intercepter le trafic sur l'interface « loopback » de l'hôte. Le réseau avec hôte privé est particulièrement utile pour les applications virtuelles pré-configurées, où plusieurs machines virtuelles sont emballées ensembles et destinées à coopérer. Par exemple, il se peut qu'une machine virtuelle contienne un serveur Web et la seconde une base de données, et puisqu'elles sont prévues pour se parler, l'application peut demander à VirtualBox de régler un réseau avec hôte privé pour les deux. Un second réseau (bridgé) connecterait alors le serveur Web au monde extérieur pour donner accès aux données, mais le monde extérieur ne peut pas se connecter à la base de données. Pour passer l'interface réseau de la machine virtuelle en mode « avec hôte privé » : soit allez sur la page « réseau » dans les paramètres de la machine virtuelle dans l'interface graphique et sélectionnez « Hôte privé » ou en ligne de commande, tapez VBoxManage modifyvm "nom VM" --nic<x> hostonly ; voir le pour les détails. Pour le réseau privé avec hôte, comme avec le réseau interne, il se peut que vous trouviez le serveur DHCP construit dans VirtualBox utile. On peut l'activer puis gérer les adresses IP dynamiques dans le réseau avec hôte privé puisque sinon vous devriez configurer toutes les adresses IP de manière statique. Dans l'interface graphique de VirtualBox, vous pouvez configurer toutes ces options dans les paramètres globaux avec « Fichier » -> « Paramètres » -> « Réseau », qui liste tous les réseaux avec hôte privé présentement utilisés. Cliquez sur un nom de réseau puis sur le bouton « Éditer » à droite et vous pouvez modifier les paramètres de l'adaptateur et du DHCP. Alternativement, vous pouvez utiliser VBoxManage dhcpserver en ligne de commande ; voir le pour des détails. Réseau par tunnel UDP Ce mode réseau permet de connecter entre elles des machines virtuelles en fonction sur plusieurs hôtes. Techniquement, cela se fait en encapsulant des cadres (frames) Ethernet envoyés ou reçus par la carte réseau invitée dans un chiffreur de données (data datagrams) UDP/IP, et en les envoyant à l'hôte à travers un réseau disponible. Le mode Tunnel UDP prend trois paramètres : port UDP source Le port sur lequel écoute l'hôte. Les déchiffreurs de données arrivant sur ce port issus de n'importe quelle adresse source seront redirigés vers la partie réceptrice d'une carte réseau invitée. adresse de destination L'adresse IP de l'hôte cible des données transmises. Port UDP de destination Numéro de port vers lequel sont envoyées les données transmises. Lorsqu'on connecte deux machines virtuelles sur deux hôtes différents, leurs adresses IP doivent être échangées. Sur un hôte unique, les ports sources et de destination doivent être échangés. Dans l'exemple suivant, l'hôte 1 utilise l'adresse IP 10.0.0.1 et l'hôte 2 utilise l'adresse IP 10.0.0.2. Configuration en ligne de commande : VBoxManage modifyvm "VM 01 on host 1" --nic<x> generic VBoxManage modifyvm "VM 01 on host 1" --nicgenericdrv<x> UDPTunnel VBoxManage modifyvm "VM 01 on host 1" --nicproperty<x> dest=10.0.0.2 VBoxManage modifyvm "VM 01 on host 1" --nicproperty<x> sport=10001 VBoxManage modifyvm "VM 01 on host 1" --nicproperty<x> dport=10002 et VBoxManage modifyvm "VM 02 on host 2" --nic<y> generic VBoxManage modifyvm "VM 02 on host 2" --nicgenericdrv<y> UDPTunnel VBoxManage modifyvm "VM 02 on host 2" --nicproperty<y> dest=10.0.0.1 VBoxManage modifyvm "VM 02 on host 2" --nicproperty<y> sport=10002 VBoxManage modifyvm "VM 02 on host 2" --nicproperty<y> dport=10001 Bien entendu, vous pouvez connecter deux machines virtuelles sur le même hôte en réglant le paramètre d'adresse de destination sur 127.0.0.1 sur les deux. Dans ce cas, il agira comme le « Réseau interne », mais l'hôte peut voir le trafic réseau, ce qu'il ne pourrait pas faire en réseau interne normal. Sur les hôtes basés sur Unix (comme Linux, Solaris, Mac OS X), il n'est pas possible de diriger (bind) sur des ports inférieurs à 1024, à partir d'applications qui ne sont pas exécutées par root. Il s'en suit que si vous essayez de configurer un tel port source UDP, la VM refusera de démarrer. Réseau VDE Virtual Distributed Ethernet (Ethernet virtuel distribué, VDEVDE est un projet développé par Renzo Davoli, professeur associé à l'Université de Bologna en Italie.) est une infrastructure réseau virtuelle flexible, reliant plusieurs hôtes de manière sécurisée. Elle permet de basculer entre L2/L3, y compris avec un protocole d'arborescence de passerelles, entre VLANs et l'émulation WAN. C'est une partie facultative de VirtualBox qui n'est incluse que dans code source. Les blocs de construction de base de l'infrastructure sont des switches VDE, des plugs (prises) VDE et des fils VDE, qui connectent les switches entre eux. Le pilote VDE de VirtualBox prend un paramètre : Réseau VDE Le nom du socket du switch du réseau VDE vers lequel se connectera la VM. L'exemple de base suivant montre comment connecter une machine virtuelle à un switch VDE : Créez un switch VDE : vde_switch -s /tmp/switch1 Configuration en ligne de commande : VBoxManage modifyvm "nom VM" --nic<x> generic VBoxManage modifyvm "nom VM" --nicgenericdrv<x> VDE Pour se connecter au port du switch automatiquement affecté, utilisez : VBoxManage modifyvm "nom VM" --nicproperty<x> network=/tmp/switch1 Pour se connecter à un port spécifique du switch <n>, utilisez : VBoxManage modifyvm "nom VM" --nicproperty<x> network=/tmp/switch1[<n>] La dernière option peut être utile pour des VLANs. Plan facultatif entre un port de switch VDE et un VLAN : (du switch en console) vde$ vlan/create <VLAN> vde$ port/setvlan <port> <VLAN> VDE n'est disponible que sur des hôtes Linux et FreeBSD. Il n'est disponible que si le logiciel VDE et la bibliothèque du plugin VDE du projet VirtualSquare sont installés sur le système hôte. Pour plus d'informations sur le paramétrage des réseaux VDE, merci de voir la documentation qui accompagne le logiciel. http://wiki.virtualsquare.org/wiki/index.php/VDE_Basic_Networking. Limiting bandwidth for network I/O Starting with version 4.2, VirtualBox allows for limiting the maximum bandwidth used for network transmission. Several network adapters of one VM may share limits through bandwidth groups. It is possible to have more than one such limit. Limits are configured through VBoxManage. The example below creates a bandwidth group named "Limit", sets the limit to 20 Mbit/s and assigns the group to the first and second adapters of the VM:VBoxManage bandwidthctl "VM name" add Limit --type network --limit 20m VBoxManage modifyvm "VM name" --nicbandwidthgroup1 Limit VBoxManage modifyvm "VM name" --nicbandwidthgroup2 Limit All adapters in a group share the bandwidth limit, meaning that in the example above the bandwidth of both adapters combined can never exceed 20 Mbit/s. However, if one adapter doesn't require bandwidth the other can use the remaining bandwidth of its group. The limits for each group can be changed while the VM is running, with changes being picked up immediately. The example below changes the limit for the group created in the example above to 100 Kbit/s:VBoxManage bandwidthctl "VM name" set Limit --limit 100k