VAGRANT
related
help
- vagrant_hosts →
sync_hosts: https://www.rubydoc.info/gems/vagrant-hosts/2.6.2
config files
- provision docker : https://www.vagrantup.com/docs/provisioning/docker.html
resumen comandos
imágenes (box)
vagrant box add <imagen>: descargar- alternativamente, descarga manual:
wget https://app.vagrantup.com/<USER>/boxes/<BOX>/versions/<VERSION>/providers/<PROVEEDOR>.box
vagrant box list: listar imagenes disponiblesvagrant box repackage <imagen> <proveedor> <version>: generar fichero .box a partir de imagen descargadavagrant box remove <imagen>: eliminar imagenvagrant box add <fichero.box> –name debian/jessie64: añadir imagen desde fichero local (nombre ejemplo)vagrant box outdated: mirar estado de versión de las imágenes descargadas–globalsobre todas las imágenes
vagrant box prune: eliminar versiones de imágenes viejas (cuando se actualiza no se elimina la versión anterior)vagrant box update: actualizar imágenes- crear una imagen desde una VM de virtualbox:
VBoxManage list vms: obtener listado de MVsvagrant package –base “Nombre de la MV” –output maquina.box
máquinas virtuales
vagrant init <imagen>: montar un escenario (en su directorio)- -m crea el
Vagrantfilesin comentarios
vagrant up: arrancar la máquinavagrant reload: aplica cambios en el Vagrantfile sin que impliquen la destrucción de la máquina.vagrant halt: parar la máquinavagrant status: estado de la máquinavagrant global-status: estado y situación de todas las máquinasvagrant ssh: conexión a la máquinavagrant destroy: destruir máquina
red
vagrant port: muestra los puertos redireccionados de la MV
snapshots
vagrant snapshot save <nombre_snapshot>: crea un snapshotvagrant snapshot restore <snapshot>: restaura un snapshotvagrant snapshot push↔vagrant snapshot pop: crea una «pila» de snapshots
Vagrantfile
vagrant validate: comprueba que el fichero Vagrantfile sea correcto
otros
vagrant rsync: sincroniza los directorios «compartidos» entre el host y la VMvagrant rsync-auto: demonio que se encarga de mantener los directorios «compartidos» en syncro contínua
plugins
vagrant-hosts
vagrant plugin install vagrant-hosts→ https://www.rubydoc.info/gems/vagrant-hosts/2.6.2Vagrant.configure('2') do |config| config.vm.box = "puppetlabs/ubuntu-14.04-64-nocm" config.vm.provision :hosts do |provisioner| # Add a single hostname provisioner.add_host '10.0.2.2', ['myhost.vagrantup.internal'] # Or a fqdn and a short hostname provisioner.add_host '10.0.2.3', ['myotherhost.vagrantup.internal', 'myotherhost'] # Or as many aliases as you like! provisioner.add_host '10.0.2.5', [ 'mypuppetmaster.vagrantup.internal', 'puppet.vagrantup.internal', 'mypuppetmaster', 'puppet' ] end end
disk-size
vagrant plugin install vagrant-disksize: ayuda a crear discos «a medida»Vagrant.configure("2") do |config| config.vm.box = "debian/stretch64" config.disksize.size = "20GB" end
uso en vim
" Teach vim to syntax highlight Vagrantfile as ruby " " Install: $HOME/.vim/plugin/vagrant.vim " Author: Brandon Philips <brandon@ifup.org> augroup vagrant au! au BufRead,BufNewFile Vagrantfile set filetype=ruby augroup END
vagrant + virtualbox
como enlazar una máquina Vagrant con su correspondiente máquina en el proveedor (suponiendo que sea virtualbox)
vagrant global-status: relación de máquinas y su path originalVBoxManage list vmw: ralación de máquinas virtuales y su ID.vagrant/machines/default/virtualbox/action_provision: contiene el ID de la máquina virtualbox asociada
solo hay que localizar esos ficheros, extraer el campo del ID y cotejarlo con la información de VBoxManage:
find /home/mate/Vagrant -name action_provision
for var in $(find ~/Vagrant -name action_provision); do echo "${var}"; cat $var | cut -d ":" -f 2 | sort -n; done
VBoxManage list vms | sed 's/[{}"]//g' | awk '{print $2 " " $1}'
- No funciona correctamente
LISTA=`vagrant global-status | awk '/^[a-f0-9]{1,7}\s+/ {print $5}'` for variable in $LISTA; do cat ${variable}/.vagrant/machines/default/virtualbox/action_provision; done