Effortless, self-hosted continuous deployment.
Inertia is a simple cross-platform command line application that enables quick and easy setup and management of continuous, automated deployment of a variety of project types on any virtual private server. It is used, built, and maintained with β€ by UBC Launch Pad.
|
Main Features |
π |
Simple setup from your computer without ever having to manually SSH into your remote |
π° |
Use any Linux-based remote virtual private server platform you want |
β |
Deploy a wide range of supported project types (including Dockerfile, docker-compose, and Heroku projects) |
π |
Have your project automatically updated, rebuilt, and deployed as soon as you git push |
π |
Start up, shut down, and monitor your deployment with ease |
π· |
Configure deployment to your liking with branch settings and more |
π |
Add users and check on your deployment anywhere through Inertia Web |
π |
Secured with tokens and HTTPS across the board |
Contents
π¦ Getting Started
All you need to get started is a compatible project, the Inertia CLI, and access to a virtual private server.
MacOS users can install the CLI using Homebrew:
$> brew install ubclaunchpad/tap/inertia
Windows users can install the CLI using Scoop:
$> scoop bucket add ubclaunchpad https://github.com/ubclaunchpad/scoop-bucket
$> scoop install inertia
For other platforms, you can download the appropriate binary from the Releases page.
Setup
Initializing a project for use with Inertia only takes a few simple steps:
$> inertia init
$> inertia remote add $VPS_NAME
After adding a remote, you can bring the Inertia daemon online on your VPS:
$> inertia $VPS_NAME init
$> inertia $VPS_NAME status
# Confirms that the daemon is online and accepting requests
This daemon will be used to manage your deployment.
See our wiki for more details on VPS platform compatibility.
Deployment Management
To manually deploy your project, you must first grant Inertia permission to clone your repository. This can be done by adding the GitHub Deploy Key that is displayed in the output of inertia $VPS_NAME init
to your repository settings:
GitHub Deploy Key (add here https://www.github.com/<your_repo>/settings/keys/new):
ssh-rsa <...>
Once this is done, you can use Inertia to bring your project online on your remote VPS:
$> inertia $VPS_NAME up --stream
Run inertia $VPS_NAME --help
to see the other commands Inertia offers for managing your deployment.
Inertia also offers a web application - this can be accessed at https://$ADDRESS:4303/web
once users have been added through the inertia $VPS_NAME user
commands.
Continuous Deployment
To enable continuous deployment, you need the webhook URL that is printed during inertia $VPS_NAME init
:
GitHub WebHook URL (add here https://www.github.com/<your_repo>/settings/hooks/new):
http://myhost.com:4303/webhook
Github WebHook Secret: inertia
The daemon will accept POST requests from GitHub at the URL provided. Add this webhook URL in your GitHub settings area (at the URL provided) so that the daemon will receive updates from GitHub when your repository is updated. Once this is done, the daemon will automatically build and deploy any changes that are made to the deployed branch.
Release Streams
The version of Inertia you are using can be seen in Inertia's .inertia.toml
configuration file, or by running inertia --version
. The version in .inertia.toml
is used to determine what version of the Inertia daemon to use when you run inertia $VPS_NAME init
.
You can manually change the daemon version used by editing the Inertia configuration file. If you are building from source, you can also check out the desired version and run make inertia-tagged
or make RELEASE=$STREAM
. Inertia daemon releases are tagged as follows:
v0.x.x
denotes official, tagged releases - these are recommended.
latest
denotes the newest builds on master
.
canary
denotes experimental builds used for testing and development - do not use this.
The daemon component of an Inertia release can be patched separately from the CLI component - see our wiki for more details.
Swag
Add some bling to your Inertia-deployed project π
[![Deployed with Inertia](https://img.shields.io/badge/Deploying%20with-Inertia-blue.svg)](https://github.com/ubclaunchpad/inertia)
π‘ Motivation and Design
UBC Launch Pad is a student-run software engineering club at the University of British Columbia that aims to provide students with a community where they can work together to build a all sorts of cool projects, ranging from mobile apps and web services to cryptocurrencies and machine learning applications.
Many of our projects rely on hosting providers for deployment. Unfortunately we frequently change hosting providers based on available funding and sponsorship, meaning our projects often need to be redeployed. On top of that, deployment itself can already be a frustrating task, especially for students with little to no experience setting up applications on remote hosts. Inertia is a project we started to address these problems, with the goal of developing an in-house deployment system that can make setting up continuously deployed applications simple and painless, regardless of the hosting provider.
The primary design goals of Inertia are to:
- minimize setup time for new projects
- maximimise compatibility across different client and VPS platforms
- offer an easy-to-learn interface for managing deployed applications
How It Works
There is a detailed Medium post that goes over the project, its motivations, the design choices we made, and Inertia's implementation. The team has also made a few presentations about Inertia that go over its design in some more detail:
In summary, Inertia consists of two major components: a deployment daemon and a command line interface.
The deployment daemon runs persistently in the background on the server, receiving webhook events from GitHub whenever new commits are pushed. The CLI provides an interface to adjust settings and manage the deployment - this is done through HTTPS requests to the daemon, authenticated using JSON web tokens generated by the daemon. Remote configuration is stored locally in .inertia.toml
.
Inertia is set up serverside by executing a script over SSH that installs Docker and starts an Inertia daemon image with access to the host Docker socket. This Docker-in-Docker configuration gives the daemon the ability to start up other containers alongside it, rather than within it, as required. Once the daemon is set up, we avoid using further SSH commands and execute Docker commands through Docker's Golang API. Instead of installing the docker-compose toolset, we use a docker-compose image to build and deploy user projects. Inertia also supports projects configured for Heroku buildpacks using the gliderlabs/herokuish Docker image for builds and deployments.
π Contributing
Any contribution (pull requests, feedback, bug reports, ideas, etc.) is welcome!
Please see our contribution guide for contribution guidelines as well as a detailed guide to help you get started with Inertia's codebase.