Basic Vagrant commands

vagrant init [name [url]]

Initializes the Vagrant environment and creates the Vagrantfile.

$ vagrant init centos/7

Output

A `Vagrantfile` has been placed in this directory. You are now
ready to `vagrant up` your first virtual environment! Please read
the comments in the Vagrantfile as well as documentation on
`vagrantup.com` for more information on using Vagrant.

vagrant up [name|id]

Creates and configures the Virtual Machine from the Vagrantfile.

$ vagrant up 

Output

==> default: Configuring and enabling network interfaces...
    default: SSH address: 192.168.121.24:22
    default: SSH username: vagrant
    default: SSH auth method: private key
==> default: Rsyncing folder: /home/naavi/Vagrant/my-vagrant/ => /vagrant

vagrant status [name|id]

Displays running or stopped VMs.

$ vagrant status 

Output

Current machine states:

default                   running (virtualbox)

The VM is running. To stop this VM, you can run `vagrant halt` to
shut it down forcefully, or you can run `vagrant suspend` to simply
suspend the virtual machine. In either case, to restart it again,
simply run `vagrant up`.

vagrant halt [name|id]

Attempts a graceful shutdown.

$ vagrant halt 

Output

==> default: Attempting graceful shutdown of VM...

vagrant destroy [name|id]

Removes the guest machine.

$ vagrant destroy

Output

default: Are you sure you want to destroy the 'default' VM? [y/N] y
==> default: Forcing shutdown of VM...
==> default: Destroying VM and associated drives...

vagrant ssh [name|id]

SSH into the guest machine or logs into the guest machine.

$ vagrant ssh 

Output

Welcome to Ubuntu 16.04.7 LTS (GNU/Linux 4.4.0-187-generic x86_64)

 * Documentation:  https://help.ubuntu.com
 * Management:     https://landscape.canonical.com
 * Support:        https://ubuntu.com/advantage

 * Kubernetes 1.19 is out! Get it in one command with:

     sudo snap install microk8s --channel=1.19 --classic

   https://microk8s.io/ has docs and details.

8 packages can be updated.
0 updates are security updates.

New release '18.04.5 LTS' available.
Run 'do-release-upgrade' to upgrade to it.


Last login: Tue Sep  1 05:42:38 2020 from 10.0.2.2
vagrant@vagrantbox1:~$

vagrant suspend [name|id]

Suspends the machine in its current state and does not shutdown.

$ vagrant suspend

Output

==> default: Saving VM state and suspending execution...

vagrant resume [name|id]

Starts the guest machine from suspended or halt.

$ vagrant resume

Output

==> default: Resuming suspended VM...
==> default: Booting VM...
==> default: Waiting for machine to boot. This may take a few minutes...
    default: SSH address: 127.0.0.1:2222
    default: SSH username: vagrant
    default: SSH auth method: private key
==> default: Machine booted and ready!
==> default: Machine already provisioned. Run `vagrant provision` or use the `--provision`
==> default: flag to force provisioning. Provisioners marked to run always will still run.

vagrant box add ADDRESS

The vagrant box add ADDRESS command downloads the box from the cloud repository and stores it in your local environment. It does not initialize the Vagrantfile.

$ vagrant box add centos/7 

vagrant global-status

This command will show the current state of the Vagrant VM in your system, regardless of the directory.

$ vagrant global-status

Output

id       name    provider   state    directory                           
-------------------------------------------------------------------------
5c7d007  default virtualbox poweroff /home/naavi/Downloads/vag           
14d0e56  default virtualbox poweroff /home/naavi/Downloads/vag2          
 
The above shows information about all known Vagrant environments
on this machine. This data is cached and may not be completely
up-to-date (use "vagrant global-status --prune" to prune invalid
entries). To interact with any of the machines, you can go to that
directory and run Vagrant, or you can use the ID directly with
Vagrant commands from any directory. For example:
"vagrant destroy 1a2b3c4d"

Get hands-on with 1300+ tech skills courses.