inertia

command module
v0.5.0-rc3 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 14, 2019 License: MIT Imports: 3 Imported by: 0

README ΒΆ

Inertia

An effortless, self-hosted continuous deployment platform.

Travis Build Status Appveyor Build Status Clean code GoDocs available Latest release


Getting Started Β· Motivation & Design Β· Contributing



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. The project is used, built, and maintained with ❀ by UBC Launch Pad, UBC's student-run software engineering club.

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
πŸ“¦ Easily provision VPS instances for your project with supported providers such as Amazon EC2
βš’ Deploy any Dockerfile or docker-compose project
πŸš„ Webhook integration for GitHub, GitLab, and Bitbucket allow your project to be automatically updated, rebuilt, and deployed as soon as you git push
πŸ›‚ Start up, shut down, and monitor your deployment with ease from the command line
🏷 Configure deployment to your liking with branch settings, build configuration, and more
πŸ”‘ Secured with tokens and HTTPS across the board

πŸ“¦ 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
Using an Existing Remote

To use an existing host, you must first add it to your Inertia configuration and initialize it - this will install Inertia on your remote.

$> inertia remote add $VPS_NAME
$> inertia $VPS_NAME init
$> inertia $VPS_NAME status
# Confirms that the daemon is online and accepting requests

See our wiki for more details on VPS platform compatibility.

Provisioning a New Remote

Inertia offers some tools to easily provision a new VPS instance and set it up for Inertia. For example, to create an EC2 instance and initialize it, just run:

$> inertia provision ec2 $VPS_NAME
$> inertia $VPS_NAME status
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

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

[![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.



πŸ“š 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.


0 1 2 3 4 5 6 7

Documentation ΒΆ

Overview ΒΆ

Inertia is the command line interface that helps you set up your remote for continuous deployment and allows you to manage your deployment through configuration options and various commands.

It can be installed in several ways:

# Mac users
brew install ubclaunchpad/tap/inertia

# Windows users
scoop bucket add ubclaunchpad https://github.com/ubclaunchpad/scoop-bucket
scoop install inertia

Users of other platforms can install the Inertia CLI from the Releases page, found here: https://github.com/ubclaunchpad/inertia/releases/latest

To help with usage, most relevant documentation can be seen by using the --help flag on any command:

inertia --help
inertia init --help
inertia [remote] up --help

Documentation can also be triggered by simply entering a command without the prerequisite arguments or additional commands:

inertia remote               # documentation about remote configuration

Inertia has two "core" sets of commands - one that primarily handles local configuration, and one that allows you to control your remote VPS instances and their associated deployments.

For local configuration, most commands will build off of the root "inertia ..." command. For example, a typical set of commands to set up a project might look like:

inertia init                 # initiates Inertia configuration
inertia remote add my_cloud  # adds configuration for a remote VPS instance

The other set of commands are based on a remote VPS configuration, and the available commands can be seen by running:

inertia [remote] --help

In the previous example, the next steps to set up a deployment might be:

inertia my_cloud init        # bootstraps remote and installs Inertia daemon
inertia my_cloud up          # deploys your project

Some of these commands offer a --stream flag that allows you to view realtime log feedback from the daemon.

More documentation on Inertia, how it works, and how to use it can be found in the project repository: https://github.com/ubclaunchpad/inertia/tree/master

Directories ΒΆ

Path Synopsis
Package api contains definitions for Inertia API requests and responses
Package api contains definitions for Inertia API requests and responses
Package cfg provides configuration structs and types
Package cfg provides configuration structs and types
Package client provides the interface through which Inertia communicates with a serverside daemon
Package client provides the interface through which Inertia communicates with a serverside daemon
internal
Package internal provides compiled scripts and other internal assets
Package internal provides compiled scripts and other internal assets
cmd
Package inertiacmd provides a parent class for the root 'inertia' command
Package inertiacmd provides a parent class for the root 'inertia' command
config
Package configcmd implements the 'inertia config' subcommands
Package configcmd implements the 'inertia config' subcommands
host
Package hostcmd implements the 'inertia [host]' subcommands
Package hostcmd implements the 'inertia [host]' subcommands
inpututil
Package inpututil provides input parsing utilities for the Inertia CLI
Package inpututil provides input parsing utilities for the Inertia CLI
printutil
Package printutil provides output utilities for the Inertia CLI
Package printutil provides output utilities for the Inertia CLI
provision
Package provisioncmd implements the 'inertia provision' subcommands
Package provisioncmd implements the 'inertia provision' subcommands
remote
Package remotecmd implements the 'inertia remote' subcommands
Package remotecmd implements the 'inertia remote' subcommands
Package common provides utilities, shared variables, and types for both the client and the daemon
Package common provides utilities, shared variables, and types for both the client and the daemon
daemon
inertiad
Inertiad is Inertia's daemon component.
Inertiad is Inertia's daemon component.
inertiad/auth
Package auth provides the Inertia daemon's authentication and security framework
Package auth provides the Inertia daemon's authentication and security framework
inertiad/build
Package build implements Inertia's build procedures
Package build implements Inertia's build procedures
inertiad/build/mocks
Code generated by counterfeiter.
Code generated by counterfeiter.
inertiad/cfg
Package cfg provides the daemon's core configuration
Package cfg provides the daemon's core configuration
inertiad/containers
Package containers provides utilities for interacting with Docker containers
Package containers provides utilities for interacting with Docker containers
inertiad/crypto
Package crypto provides functions for managing encryption, keys, etc.
Package crypto provides functions for managing encryption, keys, etc.
inertiad/daemon
Package daemon provides Inertiad's core server and API
Package daemon provides Inertiad's core server and API
inertiad/git
Package git provides functions for interacting with git repositories
Package git provides functions for interacting with git repositories
inertiad/log
Package log provides logging utilities
Package log provides logging utilities
inertiad/project
Package project contains Inertia's build and project management code
Package project contains Inertia's build and project management code
inertiad/project/mocks
Code generated by counterfeiter.
Code generated by counterfeiter.
inertiad/util
Package util provides miscellaneous utility functions
Package util provides miscellaneous utility functions
inertiad/webhook
Package webhook contains Inertia's webhook parsing code
Package webhook contains Inertia's webhook parsing code
Package local provides access to local assets for the CLI
Package local provides access to local assets for the CLI
Package provision contains Inertia's VPS instance provisioning API
Package provision contains Inertia's VPS instance provisioning API

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL