Skip to content
This repository has been archived by the owner on Oct 26, 2023. It is now read-only.
/ zenias Public archive

Vagrant box development for FCC students who are learning Python, Ruby, PHP, Clojure, Jave, Node etc.

License

Notifications You must be signed in to change notification settings

DevBlend/zenias

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

FreeCodeCamp - Zeus

Join the chat at https://gitter.im/FreeCodeCamp/vagrant

Table of Contents

What is Zeus

Zeus is a CLI tool that creates a platform-independent Vagrant development environment.

Presently, we support creating Ubuntu 14.04 LTS environment with these stacks:

  • Clojure-Compojure-Leiningan
  • Node-Express
  • Java 1.8-Tomcat-Maven-Gradle
  • PHP-CakePHP
  • Python-Django
  • Ruby-Rails-Sinatra

In all of the above, PostgreSQL 9.3 is present and configured for use as Database, except for the Node and Express stack; where MongoDB has been provided.

Current Version

Present version of this project stands at 1.0.0. We use Semvar based versioning.

How to Use

Basic Requirement

You need to install latest (version 5.0.20) Virtualbox, its compatible Virtualbox Extension pack for USB 2.0 support; and latest (1.8.1) Vagrant itself.

If you are on Windows, you need Git Bash. On other platforms, like Linux or MacOSX; you would require having git installed in your machine. On Windows, you might need to restart your machine after Vagrant installation.

Once you have installed these, you can choose to boot up one of the following environments. In future, we plan on installing the basic requirements as part of zeus as well.

Clojure

Java

In the Java box we have provided the following packages :

  • Java 8 - v1.8
  • Maven 3
  • Gradle 2
  • Tomcat 8

Additionally, Postgres database has been setup.

Tomcat server is set to auto-start on port 8080. Now in this box, the port 8080 is mapped with Host, i.e your machine's port 9100. Thus, run anything on the tomcat server and it would be accessible on your machine in the address http://localhost:9100

Node

In the Node box we have provided the following packages :

In our vagrant configuration, the port 3000 is mapped with guest port 9200. Thus, if you start an express app on port 3000, you can access it via the address http://localhost:9200

We have also included a sample Todo app with Socket Stream, built by the awesome guys at TodoMVC. To run it, do the following :

cd /vagrant # navigate to shared vagrant folder
cd socketstream
npm install
bower install
npm start

Now open http://localhost:9200 in your browser and voila! The todo app is working!

PHP

The PHP box comes with the following packages:

  • Apache 2.4 webserver
  • PHP 5.5 with these extensions:
    • php5-intl
      • php5-pgsql
    • php5-mcrypt
    • php5-sqlite
    • php5-apcu
    • php5-cli
    • php5-gd
  • PostgreSQL server 9.3 (MySQL or MariaDB support may come later)
  • PostgreSQL client 9.3
  • phpunit 3.7

Typical workflow for using this PHP box:

  1. Launch the virtual machine
  2. Work on the host with your favorite tools (Apache documentRoot is <zeus>/php/www on the host, /vagrant/www on the guest)
  3. Test
  4. Push your commits on github and/or heroku: - From the host, with your usual tools (I use SmartGit to manage my git repos, and the Heroku toolbelt) - From the guest : you will have to configure your git repository, but the Heroku toolbelt is installed.
  5. Repeat from 2
  6. Celebrate.

Defaults

  • The default IP adress of the guest is http://192.168.56.101.
  • You can access the PostgreSQL server with user vagrant, password vagrant. An empty database named my_app has already been created.

For more information. refer to the PHP readme.

Python

Ruby

In the Ruby box we have provided the following packages :

It installs the following gems:

Start rails servers with rails s -b 0.0.0.0 to make the server available at http://localhost:3000

Motivation

Zeus is made for students of FreeCodeCamp, who are starting their journey in learning back-end development.

The motivation for this Open Source project is to let users focus more on coding web apps, and less on configuration and set-up.

We expect our vagrant environments running smoothly on most platforms; including Windows, Mac, and Linux. We also aim to reduce the size of the box as much as possible.

Features and Packages

There are three levels that zeus will change: your local machine, Vagrant VM, and virtualenv within the Vagrant VM. Various features are installed on different levels.

Individual Boxes

  • Each individual box has its own shell-based provisioner. For instance, java provisioner is zeus/java/provision.sh.
  • Each box has a DB, a web framework, a package manager and some nifty tools like curl, git, dos2unix etc.

Common Features

  • All boxes come with pre-installed heroku toolbelt and heroku CLI for easy deployment of apps on heroku.
  • All boxes have port forwarding. So, you don't need to know the IP address of a vagrant box - you can simply access the running app inside vagrant via http://localhost:<port_number> in your browser.
  • All boxes share a workspace with host machine. It allows an end-user to work on their own local IDE.

Contributing Guidelines

  • Do talk to us before you raise a pull request.
  • If you are looking for something to work on, please check our issues.
  • Vagrant testing takes time, and we intend to support major platforms. If you raise a PR, it might take a day or two for us to test on most platforms. So have patience.
  • You can contribute by adding documentation on FreecodeaCamp Wiki about this project.
  • You can contribute by testing various boxes on new platforms, or existing PRs on common platforms.

Frequently Asked Questions

Why Not Docker?

Docker is not natively supported on Windows and Mac. While on Linux, it makes sense to use Docker, on Windows and Mac; one needs lot of extra packages to make Docker work.

Docker is in no way superior to Vagrant if we are targeting development environment for end user, on their personal laptop or family desktop. We chose to start with Vagrant and the project grew from there. If we get a compelling reason to move to Docker, we would.

Why are c9 or Nitrous not used?

Cloud 9 and Nitrous are great services, for coding in-browser. They give you a full-fledged terminal with superuser access, among other things. But we are trying to help people get jobs by building a solid back-end or full-stack profile.

A user needs to be comfortable working on their own machine, outside a browser. A vagrant environment is a great place to start. Once we have a user comfortably working using a vagrant, we can take them through the journey of taking apart their environments, and setting up their own environment.

We plan on creating some detailed tutorials on these, and an environment in a local machine is a step towards that.

In a lot of countries, getting good reliable internet is an issue. Power cuts are rampant. If you are from one of those places, you are probably more comfortable working on your local environment offline.

We acknowledge the benefits of cloud-hosted, browser-interfaced envs like c9 or nitrous. And our tool is complementary to these. In the end, it's the end-user who gets to decide which one they want to use.

Why shell-script provisioning?

State-of-the-art provisioners like Chef, Puppet, Ansible, and Salt are there. They work amazingly well, with 100% reliability; and most big and small companies use them internally in their DevOps.

But, while they are great for provisioning 16 GB CentOS workstations in a team, part of a large MNC, your local Windows 10 with 4 GB RAM would most likely not be able to handle them. You machine would slow down, or would need to download hundreds of files along with the huge plugins. In some cases, even more things to download.

We started with shell-script as it is lightweight, and it just works. Our setup is not that complex. In our usecase, where we are provisioning personal machines, we found shell script to provision envs the fastest. We have not yet had a reason to move to any of these provisioners; however, if such a need were to arise, we won't think twice before moving to these!

Shell script can be odd and esoteric at times, but we have figured out solutions to most of the common problems over the course of this project.

As for reliability, we have test suites, to be executed after a box has been provisioned.

Why all the >/dev/null style output suppressing? Are you hiding something?

The only thing we are hiding from end-users, is misleading red-text information. We have noticed that, during provisioning, shell script provisioning prints a lot of stuff in red-text, indicating error.

Those could be something as harmless as download progress, or gpg key fetching, or even building database of man pages. In cases like those, we don't want the output and we pipe them to /dev/null. However, we do need to know if something went wrong - so we also do 2>&1, to indicate STDERR outputs in STDOUT.

And as mentioned earlier, we have test cases to inspect if the provisioning went fine.

Why no Continuous Integration, like Travis?

To be frank, setting up CI is not so straightforward with this. Our requirement is this: A contributor changes some file(s) and submits a PR. The CI service should pull in the changes and run vagrant provisioning. After the boxes have been provisioned, the test suites are invoked from inside the provisioned from within the boxes to ensure everything is fine.

As you can see, it requires that a virtual environment be set up inside the environment that CI service is providing you. However, most CI services use some form of virtualization themselves. Like the Docker images Travis use, uses OpenVZ containers.

Virtual systems within an already-virtual system is kind of tricky, and in most cases not allowed. We did some research, and we are yet to find a solution. However, if you have a workaround, do get in touch with us!

Why build your own vagrant box project, when there are plenty such boxes on GitHub and Atlas?

In simple words, to have control over what we distribute. One of the focus of our project is to give the bare minimum necessity, because we have planned some tutorials on top of our vagrant boxes in the future. In those, the end user would install and configure some stuff on their own. We want to leave those opportunities - not distribute everything that we can!

Also, most such projects are built to complement an existing project of the authors who created the project. They most likely won't work on your personal Windows 7 laptop. They are not usually active, and defintely not meant for mass consumption.

We encountered an interesting bug when we were following a popular repo's vagrant provisioning - it has issues on some Windows machine. Upon further inspection, we found that there was a step to copy ~/.bashrc from the cloned repo into the vagrant box. Guess what, if the cloning git client is not set up to handle line terminators properly, the vagrant box would only see Windows style line terminators and the whole ~/.bashrc sourcing would fail with lot of error texts.

We wanted to get rid of all these, so decided to have our own boxes. But the good practices of all these repositories, still live on. We incorporate them whenever possible, with proper credit to original author.

Why PostgreSQL, and no MySQL?

Because our campers prefer Heroku for deployment. Heroku is simpler than AWS or gcloud or Google App Engine. And by default, PostgreSQL is supported on Heroku.

Since 2012, when Oracle acquired MySQL, there have been a steady move to PostgreSQL or MariaDB even within the big companies. PostgreSQL is a great DB with popularity and good community support.

But if you still wish to use MySQL, you can install it! In fact, please talk to us so that we can let the user choose during provisioning whether to have a box with MySQL or PostgreSQL.

License

Continue to our license.

Features

asciinema Tutorial

or

Video Tutorial by John Wu

1. User's Local Machine Level

Files

  • .gitignore, Vagrantfile, provisioning.sh, README.md, Procfile, requirements.txt, runtime.txt

Programmes

[WIP] for the release of Version 0.2.0 (in June) and not within Version 0.1.0:

  • Vagrant, Git, VirtualBox, VirtualBox Extension Pack

2. Vagrant VM Level

These are system-wide installations within the Vagrant VM:

Programmes

  • python2.7, python3.4, python-dev, python3-dev, libpq-dev, pip, build-essential, dos2unix, python-pip, man, Git, Heroku toolbelt, Heroku CLI, ruby, virtualenvwrapper, postgresql, Postgresql-contrib
  • Custom commands in the command line via zeus. Refer to section "How to Use Zeus" to know what commands are available.

Configurations

  • Initiate a local git repository inside the synced folder /vagrant.
  • Initiate a virtualenv every time you perform vagrant ssh.
  • Create Postgres database and its user.
  • Store user configurations and credentials for git, Github, and Heroku.

3. Virtualenv Level

Programmes

  • dj-database-url==0.4.1, Django==1.9.6, django-rest==3.3.3, django-widget-tweaks==1.4.1, gunicorn==19.5.0, psycopg2==2.6.1, whitenoise==3.0

Vagrant Base-box

Ubuntu 14.04 LTS based box minimal/trusty64, hosted at https://atlas.hashicorp.com/minimal/boxes/trusty64

How to Use Zeus

System Requirements

You need to have the following programmes installed on your local machine before you start to use this tool.

If you are on Windows, restart your local machine after the installation of these programmes.

Standard Usage

  1. git clone --recursive https://github.com/alayek/zeus.git
  2. Navigate to the directory of this cloned repo. cd your/path/to/zeus/ruby
  3. vagrant up in your bash-compliant terminal (Git Bash on Windows, regular terminal on Linux or Mac).
  4. Inside the directory your/path/to/zeus/ruby run vagrant ssh to start the session inside the development VM.
  5. Complete Github and git config setup. You only need to login to Github once during your first push and never again. You don't need to authenticate yourself when you perform git commit.
  6. Start coding.

Note that you end up inside the Vagrant VM after these four steps. The VM is isolated from your local machine. Your current working directory has the absolute path of /vagrant, which is termed the "synced directory". It is in real-time sync with the your/path/to/fcc-python-vagrant local git repo. That is how your local machine communicates with the Vagrant VM.

If you run into trouble, hit zeus help inside the Vagrant ssh session.

Zeus CLI

Run these commands within your Vagrant ssh session.

  • zeus gitconfig Create or overwrite existing git configuration for the user in terms of username and email address. Git push is set to simple as this is best practice.
  • zeus gitcreate private or zeus gitcreate public Create a private or public repository on Github via the GitHub API. You need to first have setup your git configurations with zeus gitconfig to use this properly. You only need to specify the name you wish to give to the remote repository.

Nota Bene:

is the directory you with to create in side which you are going to code your web apps. This is your synced folder in the Vagrant ssh session. All your coding should happen here. If you exit the Vagrant ssh session, you might end up in a different directory. Please navigate to wherever is located and start your VM session again with vagrant ssh

Test Your Setup

Optionally, you might wish to test the development environment setup by following these steps:

  • Test manually by checking whether all the features we promised are installed inside your Vagrant VM.
  • Use date && vagrant up > logfile.log && date instead of just vagrant up to log all printouts of vagrant up into the logfile.log with start time and end time of the execution. (The terminal will print nothing during the entire setup, please don't panic, everything is written into the logfile.log). Finally, inspect logfile.log to ensure no installation error occurred.
  • Run vagrant halt and restart with vagrant up and vagrant ssh. Ensure the state of the VM is the same as before, run another test if necessary.
  • Automated testing:

It is assumed that these tests would be run inside the standard virtualenv of the vagrant ssh session.

It would require the py.test module to run it, which can be installed as:

$ pip install pytest

Then navigate to the top-level directory of the Vagrant synced folder:

$ cd /vagrant

Invoke the automated tests:

$ py.test -v

You should see all tests PASSED and no errors printed.

Security

The Vagrant VM initiated by zeus stores your GitHub credentials on file. Please do not package this VM and share it. Attempts are made in the future to use HashiCorp Vault to store safely your credentials while not compromising on convenience.

About

Vagrant box development for FCC students who are learning Python, Ruby, PHP, Clojure, Jave, Node etc.

Resources

License

Stars

Watchers

Forks

Packages

No packages published