- What is Zenias
- Current Version
- How to Use
- Motivation
- Features and Packages
- Contributing Guidelines
- Frequently Asked Questions
- License
Zenias 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.
Present version of this project stands at 1.0.0. We use Semvar based versioning.
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 zenias
as well.
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
In the Node box we have provided the following packages :
- MongoDB 3.0 server and client
- NVM or Node Version Manager
- Node version 4.4.3 (Can be easily updated via
nvm install
) - Bower
- Gulp
- Yeoman CLI
- Express
- Essential Nodeschool Workshopper modules
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!
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
- php5-intl
- 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:
- Launch the virtual machine
- Work on the host with your favourite tools (Apache documentRoot is
<zenias>/php/www
on the host,/vagrant/www
on the guest) - Test
- 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.
- Repeat from 2
- Celebrate.
- The default IP address of the guest is
http://192.168.56.101
. - You can access the PostgreSQL server with user
vagrant
, passwordvagrant
. An empty database namedmy_app
has already been created.
For more information. refer to the PHP readme.
In the Ruby box we have provided the following packages :
- ruby 3.2.1 precompiled by Travis CI
- chruby
- ruby-install
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
Zenias 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.
There are three levels that Zenias will change: your local machine, Vagrant VM, and virtualenv within the Vagrant VM. Various features are installed on different levels.
- Each individual box has its own shell-based provisioner. For instance,
java
provisioner iszenias/java/provision.sh
. - Each box has a DB, a web framework, a package manager and some nifty tools like
curl
,git
,dos2unix
etc.
- 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.
- 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 FreecodeCamp Wiki about this project.
- You can contribute by testing various boxes on new platforms, or existing PRs on common platforms.
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.
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
env
s 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.
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
env
s 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.
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 do2>&1
, to indicateSTDERR
outputs inSTDOUT
.
And as mentioned earlier, we have test cases to inspect if the provisioning went fine.
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!
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 definitely 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.
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.
Continue to our license.
or
- .gitignore, Vagrantfile, provisioning.sh, README.md, Procfile, requirements.txt, runtime.txt
[WIP] for the release of Version 0.2.0 (in June) and not within Version 0.1.0:
- Vagrant, Git, VirtualBox, VirtualBox Extension Pack
These are system-wide installations within the Vagrant VM:
- 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 Zenias. Refer to section "How to Use Zenias" to know what commands are available.
- 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.
- 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
Ubuntu 14.04 LTS based box minimal/trusty64, hosted at https://atlas.hashicorp.com/minimal/boxes/trusty64
You need to have the following programmes installed on your local machine before you start to use this tool.
- Virtualbox latest (currently version 5.0.20)
- VirtualBox 5.0.20 Oracle VM VirtualBox Extension Pack, compatible with latest Virtualbox
- Vagrant, (currently version 1.8.1)
- Python 2.7
- Git Bash (only if you are on Windows)
If you are on Windows, restart your local machine after the installation of these programmes.
git clone --recursive https://github.com/DevBlend/zenias.git
- Navigate to the directory of this cloned repo.
cd your/path/to/zenias/ruby
vagrant up
in your bash-compliant terminal (Git Bash on Windows, regular terminal on Linux or Mac).- Inside the directory
your/path/to/zenias/ruby
runvagrant ssh
to start the session inside the development VM. - 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.
- 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/zenias
local git repo. That is how your local machine communicates with the Vagrant VM.
If you run into trouble, hit zenias help
inside the Vagrant ssh session.
Run these commands within your Vagrant ssh session.
zenias 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.zenias gitcreate private
orzenias gitcreate public
Create a private or public repository on Github via the GitHub API. You need to first have setup your git configurations withzenias 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
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 justvagrant up
to log all printouts ofvagrant up
into thelogfile.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 thelogfile.log
). Finally, inspectlogfile.log
to ensure no installation error occurred. - Run vagrant halt and restart with
vagrant up
andvagrant 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.
The Vagrant VM initiated by Zenias 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.