Per a poder llançar maquines virtuals a l'OpenNebula amb docker-machine i després crear i instanciar-hi contenidors necessitem tenir instal·lat al nostre ordinador el següent programari:
- Docker Machine: Ens permet crear i gestionar les maquines virtuals
- Driver Docker Machine Opennebula: Ens permet utilitzar el docker-machine al cloud de l'OpenNebula
- Docker Engine: Ens permet crear els contenidors, gestionar-los i instanciar-los
Instal·lar docker-machine
Des de l'usuari root per descargar-nos el binari executem:
Code Block |
---|
curl -L https://github.com/docker/machine/releases/download/v0.6.0/docker-machine-`uname -s`-`uname -m` > /usr/local/bin/docker-machine && \
chmod +x /usr/local/bin/docker-machine |
Un cop instal·lat, per comprovar que podeu executar docker-machine, executeu des del vostre usuari:
Code Block |
---|
docker-machine version |
Si us digués que no troba el binari, executeu:
Code Block |
---|
export PATH=$PATH:/usr/local/bin |
Més info a: https://docs.docker.com/machine/install-machine/
Instal·lar el driver per a OpenNebula de docker-machine
Abans d'instal·lar el driver, hem de preparar l'equip per a l'instal·lació.
Preparació Sistema
Paquet GO
Code Block |
---|
wget https://storage.googleapis.com/golang/go1.6.linux-amd64.tar.gz |
Code Block |
---|
tar -C /usr/local -xvzf go1.6.linux-amd64.tar.gz |
Code Block |
---|
export GOROOT=/usr/local/go |
Code Block |
---|
export PATH=$PATH:$GOROOT/bin |
En creem el directori work en el nostre espai de treball, per exemple al $HOME:
Code Block |
---|
mkdir $HOME/work |
Indiquem les variables d'entorn necessàries:
Code Block |
---|
export GOPATH=$HOME/work |
Code Block |
---|
export PATH=$PATH:$GOPATH/bin |
Paquet GIT
Code Block |
---|
sudo apt-get install git |
Paquet GODEP
Code Block |
---|
go get github.com/tools/godep |
Paquet BZR
Code Block |
---|
sudo apt-get install bzr |
Instal·lació del driver
Code Block |
---|
go get github.com/OpenNebula/docker-machine-opennebula |
Code Block |
---|
cd $GOPATH/src/github.com/OpenNebula/docker-machine-opennebula |
Code Block |
---|
make build |
Copiem el binari:
Code Block |
---|
make install |
ONE_AUTH i ONE_XMLRPC
Ens creem un fitxer on indicarem el nostre usuari i password de l'OpenNebula
Code Block |
---|
usuari:password |
Creem les variables d'entorn necessàries:
Code Block |
---|
export ONE_AUTH=path_al_fixer_one_auth |
Code Block |
---|
export ONE_XMLRPC=https://iaas.csuc.cat:2633/RPC2 |
Més info a: https://github.com/OpenNebula/docker-machine-opennebula
Instal·lar docker-engine
https://docs.docker.com/engine/installation/linux/
Com utilitzar docker-machine
Crear la màquina virtual
Existeix una imatge a l'OpenNebula d'un sistema operatiu on ja està instal·lat el docker i on podem llançar contenidors, es diu boot2docker. També existeix una versió d'Ubuntu.
Si no està disponible, des del Marketplace de l'OpenNebula en la descarreguem.
Un cop tenim descarregada la imatge, creem la màquina virtual:
Code Block |
---|
docker-machine create --driver opennebula --opennebula-image-id [num_imatge_boot2docker] --opennebula-network-id [num_xarxa] --opennebula-b2d-size [mida_en_MB] [nom_màquina_virtual] |
Més opcions:
--opennebula-cpu
: CPU value for the VM--opennebula-vcpu
: VCPUs for the VM--opennebula-memory
: Size of memory for VM in MB--opennebula-template-id
: Template ID to use--opennebula-template-name
: Template to use--opennebula-network-id
: Network ID to connect the machine to--opennebula-network-name
: Network to connect the machine to--opennebula-network-owner
: User ID of the Network to connect the machine to--opennebula-image-id
: Image ID to use as the OS--opennebula-image-name
: Image to use as the OS--opennebula-image-owner
: Owner of the image to use as the OS--opennebula-dev-prefix
: Dev prefix to use for the images: 'vd', 'sd', 'hd', etc...--opennebula-disk-resize
: Size of disk for VM in MB--opennebula-b2d-size
: Size of the Volatile disk in MB (only for b2d)--opennebula-ssh-user
: Set the name of the SSH user--opennebula-disable-vnc
: VNC is enabled by default. Disable it with this flag
Enllaçar la shell local amb la de la maquina virtual
Ara el que farem serà connectar la nostra shell local a la de la màquina virtual perquè cada cop que executem docker, aquest dongui ordres al docker instal·lat a la màquina virtual.
Obtenim les variables d'entorn de la maquina virtual.
Code Block |
---|
docker-machine env [nom_màquina_virtual] |
Linkem la shell.
Code Block |
---|
eval "$(docker-machine env [nom_màquina_virtual])" |
Ara ja podem utilitzar docker normalment.
Info | ||
---|---|---|
| ||
Per mantenir les noves variables d'entorn de manera persistent, afegiu-les al vostre .profile ($HOME/.profile) |