Skip to content

Latest commit

 

History

History

client

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Deis Client

The Deis client is a Python CLI that issues API calls to a private Deis controller, providing a Heroku-inspired PaaS workflow.

https://badge.fury.io/py/deis.png https://travis-ci.org/deis/deis.png?branch=master Downloads License

What is Deis?

Deis is an open source PaaS that makes it easy to deploy and scale containers to host applications, databases, middleware and other services. Deis leverages Docker, CoreOS and Heroku Buildpacks to provide a private PaaS that is lightweight and flexible.

Deis comes with out-of-the-box support for Ruby, Python, Node.js, Java, Clojure, Scala, Play, PHP, Perl, Dart and Go. However, Deis can deploy anything using Docker images or Heroku Buildpacks. Deis is designed to work with any cloud provider. Currently Amazon EC2, Rackspace, DigitalOcean, and Google Compute Engine are supported.

Why Deis?

Deploy anything

Deploy a wide range of languages and frameworks with a simple git push using Heroku Buildpacks or Dockerfiles.

Control everything

Choose your hosting provider configuration. Define a cluster to meet your own needs. Retain full root access to every node. Manage your platform with a private Deis controller.

Scale effortlessly

Add nodes automatically and scale containers with a single command. Smart scheduling, container balancing and proxy reconfiguration are completely automated.

100% Open Source

Free, transparent and easily customized. Join the open-source PaaS and DevOps community by using Deis and complimentary projects like Docker, CoreOS and Heroku Buildpacks.

Get Started

  1. Install the Client:

Your Deis client should match your server's version. For development, an easy way to ensure this is to run client/deis.py in the code repository you used to provision the server. You can make a symlink or shell alias for deis to that file:

$ pip install docopt==0.6.2 python-dateutil==2.2 requests==2.3.0 termcolor==1.1.0
$ sudo ln -fs $(pwd)/client/deis.py /usr/local/bin/deis
$ deis
Usage: deis <command> [<args>...]

If you don't have Python installed, you can download a binary executable version of the Deis client for Mac OS X, Linux amd64, or Windows:

  1. Register a User:
$ deis register http://deis.local.deisapp.com
$ deis keys:add
  1. Deploy an Application:
$ deis create
Creating application... done, created peachy-waxworks
Git remote deis added
$ git push deis master
       Java app detected
-----> Installing OpenJDK 1.6... done
...
-----> Compiled slug size: 63.5 MB
       Launching... done, v2

-----> peachy-waxworks deployed to Deis
       http://peachy-waxworks.example.com ...

$ curl -s http://peachy-waxworks.example.com
Powered by Deis!
  1. Manage an Application:
$ deis config:set DATABASE_URL=postgres://user:[email protected]:5432/db
$ deis scale web=8
$ deis run ls -l  # the view from inside a container
total 28
-rw-r--r-- 1 root root  553 Dec  2 23:59 LICENSE
-rw-r--r-- 1 root root   60 Dec  2 23:59 Procfile
-rw-r--r-- 1 root root   33 Dec  2 23:59 README.md
-rw-r--r-- 1 root root 1622 Dec  2 23:59 pom.xml
drwxr-xr-x 3 root root 4096 Dec  2 23:59 src
-rw-r--r-- 1 root root   25 Dec  2 23:59 system.properties
drwxr-xr-x 6 root root 4096 Dec  3 00:00 target

To learn more, use deis help or browse the documentation.

License

Copyright 2013, OpDemand LLC

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.