Home

Awesome

Opshell

Overview

Opshell is a minimal Node.js "PaaS" used for running a single web app in a cluster consisting of a load balancer, scalable web tier and MongoDB database using Docker and CoreOS. It can be used as is or as a starting point for your own deployment. Opshell runs on any platform supported by CoreOS, including Vagrant (for development), Digital Ocean, AWS EC2 and your own hardware.

If you have 20 or so minutes, check this video of a talk introducing Opshell.

Current features include:

Planned features are:

Getting Started

First, clone this repo with git clone https://github.com/olegp/opshell.git and enter the directory with cd opshell. Next, configure your CoreOS machine:

To set up your cluster, simply run ./opshell core-01. The initial set up will take some time as the Docker images are built from scratch, but later runs will be faster as the builds are cached. Once everything is up and running, the URL at which you can access your web app will be printed out (http://localhost:8080 if using Vagrant).

Change to your Node webapp directory. Initialize Git with git init && git add * && git commit -m "hello opshell" if you haven't already, then add the Opshell cluster as a remote with git remote add opshell ssh://core-01/~/app.git. The database URL is provided via an environment variable, so change it to process.env.DATABSE_URL in your code (instead of the default 127.0.0.1:27017) and commit the change. Finally, deploy your app via:

git push opshell master

The first deployment will take a while as Node packages are downloaded for the first time, but later deployments will use cached packages.

Updating the Cluster

To update your cluster, simply edit this repo and run ./opshell core-01 to rebuild your Docker images and restart the cluster. You can optionally use Git to keep track of your changes.

License

(The MIT License)

Copyright (c) 2014+ Oleg Podsechin

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the 'Software'), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.