Skip to content
This repository has been archived by the owner on Jul 25, 2024. It is now read-only.

Latest commit

 

History

History
102 lines (82 loc) · 4.43 KB

02-vagrant.md

File metadata and controls

102 lines (82 loc) · 4.43 KB

Vagrant

Vagrant is a great tool designed for developers to create disposable machines with a quick turn around. In our case we want to install the binary NOT the gem, so go here to download (or use your native package manager).

After you installed it, go ahead and spin up [Terminal|iTerm2|xterm|cmd] and type vagrant. You should see something like the following:

[~] % vagrant
Usage: vagrant [-v] [-h] command [<args>]

    -v, --version                    Print the version and exit.
    -h, --help                       Print this help.

Available subcommands:
     box
     destroy
     halt
     help
     init
     package
     plugin
     provision
     reload
     resume
     ssh
     ssh-config
     status
     suspend
     up

For help on any individual command run `vagrant COMMAND -h`

If you see this, you are ready for the next step.

I personally like creating a vagrant/ directory, and place a directory inside each of them for different VMs. The first test to make sure you have everything working is this.

[~] % cd ~
[~] % mkdir vagrant
[~] % mkdir vagrant/lucid32
[~] % cd vagrant/lucid32
[~/vagrant/lucid32] % vagrant box add base http://files.vagrantup.com/lucid32.box
[~/vagrant/lucid32] % vagrant init
[~/vagrant/lucid32] % vagrant up

Then you should see something that resembles this:

Bringing machine 'default' up with 'virtualbox' provider...
[default] Importing base box 'base'...
[default] Matching MAC address for NAT networking...
[default] Setting the name of the VM...
[default] Clearing any previously set forwarded ports...
[default] Creating shared folders metadata...
[default] Clearing any previously set network interfaces...
[default] Preparing network interfaces based on configuration...
[default] Forwarding ports...
[default] -- 22 => 2222 (adapter 1)
[default] Booting VM...
[default] Waiting for machine to boot. This may take a few minutes...
[default] Machine booted and ready!
[default] The guest additions on this VM do not match the installed version of
VirtualBox! In most cases this is fine, but in rare cases it can
cause things such as shared folders to not work properly. If you see
shared folder errors, please update the guest additions within the
virtual machine and reload your VM.

Guest Additions Version: 4.2.0
VirtualBox Version: 4.3
[default] Mounting shared folders...
[default] -- /vagrant

Go ahead and vagrant ssh into the box and you'll see that you have a complete box that can run Linux commands, basically anything. Type something like sudo apt-get update && sudo apt-get install vim -y. You'll see vim being installed. Start it up with vim test-file and write some things in there. wq out of it. Go ahead and logout of the machine. You should see your original command prompt from your host machine now. Type vagrant ssh and you should see the file that you wrote out, cat test-file.

As you can see you have been able to create a base box, ssh into it, change it around, and log out then log back in without losing any of your data. The next step is to destroy it and start over, so in the place you did your vagrant up, type vagrant destroy -f. This is a "Do not pass Go" type of destroy, so be careful, you have been warned. When you run vagrant destroy -f, you'll see output like:

[~/vagrant/lucid32] % vagrant destroy -f
[default] Forcing shutdown of VM...
[default] Destroying VM and associated drives...
[~/vagrant/lucid32] %

It shuts down the machine, and blows it up. If you attempt to vagrant ssh it'll say:

[~/vagrant/lucid32] % vagrant ssh
VM must be created before running this command. Run `vagrant up` first.
[~/vagrant/lucid32] %

Because the machine is gone. You can simply run vagrant up to re-create it. You'll notice that neither the test-file nor vim is there anymore, and that's expected, you blew it up didn't you? I strongly suggest playing around with vagrant. The docs for version 2 are extremely straight forward, and you should spend the time to get comfortable with it. It'll make your chef experience so much better.

Bonus round: Try to set up an Apache server/nginx server and use port forwarding with Vagrant so you can hit http://localhost:8080 in your browser and see the default page being served by the VM.

Move on to The beginning of your playground