Skip to content

Latest commit

 

History

History
218 lines (133 loc) · 11.9 KB

mac-vagrant.md

File metadata and controls

218 lines (133 loc) · 11.9 KB

Vagrant Web Development Setup for Apple Macintosh Computers

In this step, we will install, configure and test your vagrant web development environment. At the end of this process, you will see a web application that is running from within this environment active inside your web browser.

Note: Make sure to close any other virtualization environments you have running. If you happen to be running Parallels, VirtualBox or VMWare for other reasons, you will need to close them.

Follow the following steps to install and use your vagrant environment.

Step 1: Get the files

Your vagrant virtual machine will need a variety of files to set this up.

Note: This folder will become the folder where your web development environment and source code will be used.

Step 2: Install three programs

There are three programs you will need to install to setup your environment: Sublime text, VirtualBox and vagrant.

Program 1 — Sublime Text Editor

You may have already installed this program, but if you haven't follow these steps.

First, visit the Sublime Text Editor Website and click "Download for Mac".

Second, open the file and drag the Sublime Text program into the Applications folder, then launch the program by going into your Launch Pad and finding "Sublime Text".

Note: When you follow this step, you may be presented with an error because this program wasn't installed from the App Store. The error may look like this.

If this happens do the following:

  • open Launch Pad
  • navigate to System Preferences > Security & Privacy
  • Click the Open Anyway option.

If you see an error that "Sublime Text" is an application downloaded from the internet. Are you sure you want to open it? (screenshot), press the Open button.

This will launch the Sublime Text editor, and you'll be good.

If you need more help check out this Sublime Text install video that shows how to do this.

Program 2 — VirtualBox

First, visit the VirtualBox Website, click the link to Download "OS X hosts".

Second, Open the dmg file that downloads, then double click on VirtualBox.pkg that pops up and follow the instructions (you're clicking continue most of the time). Once you go through that step close out the "VirtualBox" window.

Note: if you see an error message that indicates that you are not allowed to install programs from unidentified developers you will need to adjust your privacy settings to allow this.

Open the Launchpad and open the Systems Preferences. When this launched open the Security and Privacy pane.

From there, scroll down and find the section that says: System software from developer "Oracle America, Inc." was blocked from loading. and click the Allow button to the right of this to finish the installation process of VirtualBox.

Allow blocked

Program 3 — Vagrant

First, visit the Vagrant Download Page, click Find the Mac OS X section and click "Universal (32 and 64-bit)". Run the file you downloaded and follow the instructions (you're clicking next most of the time)

Finally, restart your computer if you're prompted to.

Step 3: Starting Your Virtual Machine

The previous steps installed all the programs that were needed to use a vagrant virtual machine. The next step will run through the steps of turning the environment on for the first time.

Turning on your virtual environment will take a bit longer than usual on the first time.

Open the terminal on your computer. To do this, hold the Command+Spacebar keys to open the spotlight. Then type Terminal and press the enter key. This will open a terminal window.

You will need to run two commands in your terminal windows.

First, run the following command to change your working directory, to make it so you're working with the web development environment you downloaded earlier.

cd ~/Desktop/coding-environment

Second, you will need to run the command to turn on your virtual computer environment.

Note: this command will require you to download a file that is hundreds of megabytes long. Make sure you are on a strong Internet connection before you run this command.

Run the following command — and after the command completes, read the next section before you run another command.

vagrant up

IMPORTANT: Read this before running any additional commands.

The previous command may complete with a variety of messages. It also may instruct you to run commands that will cause problems in your environment: so make sure to read this section before doing anything.

[SUCCESS] — Everything is successful.

If everything is successful you will see output that looks like the following.

Screenshot

If you see this, continue to Step 4: vagrant has been installed and started as expected. If this isn't what your screen looks like, continue below and find the message that matches the output you're seeing.

[ERROR] — Vagrant environment or target machine error message shown.

The error message will look like this:

Screenshot

The command may come back with an error message suggesting that you run the vagrant init command. Do not run this command.

If you see this error, click here to understand and fix the problem so the vagrant up command works.

[ERROR] — vagrant up timeouts.

Error messages indicating that:

Timed out while waiting for the machine to boot. This means Vagrant was unable to communicate with the guest machine within th e configured ("config.vm.boot_timeout" value) time period.

This error message indicates that your computer was unable to connect to the vagrant environment. This can happen if your computer is incompatible with vagrant.

When this error message happens it's often best to try to run the command an additional time to see if the command executes successfully the next time.

Typically, we suggest switching to use a Cloud IDE if this problem persists. Click here to use a CloudIDE to use your coding environment.

[SOMETHING ELSE] — the output produces something else and does not indicate that everything worked as expected.

If you encountered an output that is different than the above actions your environment is in a state that is slightly different than these instructions expect. Because of this, you should ask for help for a TA.

To get the best answer, use the following template to ask for help.

Hello. I'm setting up my web development environment using vagrant and when running the vagrant up command I encountered an unusual problem. Attached is a screenshot of the error.

Then take a screenshot of the full output of the command you just ran in the terminal window and include it in your request for help. We will get back to you about it, soon!

Step 4: Log into your dev environment

The previous steps installed, configured and turned on a virtual computer that you can use for web development. The next steps will log you into your environment, so you can begin using it.

After vagrant up finishes, enter the following command in the terminal window.

vagrant ssh

This command will change your regular terminal window into a terminal window that you can use to run commands inside the virtual computer that was setup.

When you are logged into your virtual computer and it is ready for you to run commands inside this virtual machine your terminal will look like this.

Vagrant SSH output

This brings you into your web dev environment ready to run commands. This terminal window with the green [ENV] text is a terminal window that is running inside your vagrant virtual computer. We will refer to as your coding environment from now on.

Step 5: Connecting your environment with your accounts

In the previous steps you setup accounts on GitHub.com and heroku.com. For these accounts to work correctly, you will need to connect your coding environment with these accounts.

Follow the steps in the account setup guide to hook up your environment to these accounts.

Step 6: Test

Now that your environment is properly installed, setup and configured you will now be able to test that the environment is able to run a ruby on rails project.

First, within your coding environment change your directory to the folder where the Ruby on Rails test application's source code is.

cd /vagrant/src/rails-test-app

Second, run the following command to start a Ruby on Rails server. This command will start running and prevent you from running additional commands, but will allow you to interact with your application within a web browser.

rails s -b 0.0.0.0 -p 3000

Important: When the server finishes starting up, it may appear that it is hanging. The result will look like this:

server

After your server finishes spinning up and the text that says User Ctrl-C to stop appears it means your server is running.

Third, open a web browser on your computer and go to: http://127.0.0.1:3030. You will be able to preview the application in your web browser and it will look like this.

preview

If you see this, it means you've finished setting up your application and can preview an application that is running.

Step 7: Stop your rails server

The command you ran above started running a server that can be previewed in a web browser. Before we finish, we should close the program we just opened.

Find your web development terminal where you ran the rails server (rails s) command and hold CTRL+C.

After you press hold CTRL+C on your keyboard, your terminal will give you a message that indicates your server has closed and return the prompt so new commands can be entered.

^C- Gracefully stopping, waiting for requests to finish === puma shutdown: 2018-10-31 23:35:32 +0000 ===

  • Goodbye! Exiting

This will prevent the webpage from loading in the future, but will allow you to enter new commands.

Step 8: Learn about your vagrant coding environment

By following these instructions in this guide you've setup a virtual machine with vagrant on your computer. This will be your coding environment that you will be able to use for the remainder of the course.

Since you will be using this coding environment extensively in the future, understanding it will be important.

Visit the the Introduction to Vagrant to learn more about how to use this development environment that you just setup.