Files
dokku/README.md

121 lines
4.7 KiB
Markdown
Raw Normal View History

# Dokku
Docker powered mini-Heroku. The smallest PaaS implementation you've ever seen.
2013-06-29 16:13:00 -05:00
[![Build Status](https://travis-ci.org/progrium/dokku.png?branch=master)](https://travis-ci.org/progrium/dokku)
## Requirements
Assumes Ubuntu 13 right now. Ideally have a domain ready to point to your host. It's designed for and is probably
2013-06-08 12:39:29 -07:00
best to use a fresh VM. The bootstrapper will install everything it needs.
## Installing
2013-06-20 22:59:55 +02:00
$ wget -qO- https://raw.github.com/progrium/dokku/master/bootstrap.sh | sudo bash
2013-06-08 04:29:46 -07:00
This may take around 5 minutes. Certainly better than the several hours it takes to bootstrap Cloud Foundry.
2013-06-08 04:29:46 -07:00
## Configuring
Set up a domain and a wildcard domain pointing to that host. Make sure `/home/git/VHOST` is set to this domain.
2013-06-08 04:29:46 -07:00
By default it's set to whatever the hostname the host has.
You'll have to add a public key associated with a username as it says at the end of the bootstrapper. You'll do something
2013-06-08 12:39:29 -07:00
like this from your local machine:
2013-06-08 04:29:46 -07:00
$ cat ~/.ssh/id_rsa.pub | ssh progriumapp.com "sudo gitreceive upload-key progrium"
2013-06-08 04:29:46 -07:00
That's it!
## Deploy an App
2013-06-20 09:48:18 -07:00
Right now Buildstep supports buildpacks for Node.js, Ruby, Python, [and more](https://github.com/progrium/buildstep#supported-buildpacks). It's not hard to add more, [go add more](https://github.com/progrium/buildstep#adding-buildpacks)! Let's deploy
2013-06-08 12:39:29 -07:00
the Heroku Node.js sample app. All you have to do is add a remote to name the app. It's created on-the-fly.
2013-06-08 04:29:46 -07:00
$ cd node-js-sample
$ git remote add progrium git@progriumapp.com:node-js-app
$ git push progrium master
Counting objects: 296, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (254/254), done.
Writing objects: 100% (296/296), 193.59 KiB, done.
Total 296 (delta 25), reused 276 (delta 13)
remote: -----> Building node-js-app ...
remote: Node.js app detected
2013-06-08 04:29:46 -07:00
remote: -----> Resolving engine versions
... blah blah blah ...
remote: -----> Application deployed:
remote: http://node-js-app.progriumapp.com
You're done!
2013-06-09 16:08:35 -07:00
## Advanced installation (for development)
If you plan on developing dokku, the easiest way to install from your own repository is cloning
the repository and calling the install script. Example:
2013-06-09 16:08:35 -07:00
$ git clone https://github.com/yourusername/dokku.git
2013-07-03 09:06:08 +02:00
$ cd dokku
$ sudo make all
The `Makefile` allows source URLs to be overridden to include customizations from your own
repositories. The DOCKER_URL, GITRECEIVE_URL, PLUGINHOOK_URL, SSHCOMMAND_URL and STACK_URL
environment variables may be set to override the defaults (see the `Makefile` for how these
apply). Example:
$ sudo GITRECEIVE_URL=https://raw.github.com/yourusername/gitreceive/master/gitreceive make all
## Advanced installation (bootstrap a server from your own repository)
The bootstrap script allows the dokku repository URL to be overridden to bootstrap a host from
your own clone of dokku using the DOKKU_REPO environment variable. Example:
$ wget https://raw.github.com/progrium/dokku/master/bootstrap.sh
2013-06-09 16:08:35 -07:00
$ chmod +x bootstrap.sh
$ sudo DOKKU_REPO=https://github.com/yourusername/dokku.git ./bootstrap.sh
## Upgrading
Dokku is in active development. You can update the deployment step and the build step separately.
To update the deploy step (this is updated less frequently):
$ cd ~/dokku
$ git pull origin master
$ sudo make install
Nothing needs to be restarted. Changes will take effect on the next push / deployment.
2013-06-09 16:08:35 -07:00
2013-06-19 17:43:51 -07:00
## Support
You can use [Github Issues](https://github.com/progrium/dokku/issues), check [Troubleshooting](https://github.com/progrium/dokku/wiki/Troubleshooting) on the wiki, or join us on Freenode in #dokku
2013-06-08 04:29:46 -07:00
## Components
* [Docker](https://github.com/dotcloud/docker) - Container runtime and manager
* [Buildstep](https://github.com/progrium/buildstep) - Buildpack builder
* [gitreceive](https://github.com/progrium/gitreceive) - Git push interface
2013-07-02 21:51:24 +02:00
* [pluginhook](https://github.com/progrium/pluginhook) - Shell based plugins and hooks
2013-06-11 20:51:48 -07:00
* [sshcommand](https://github.com/progrium/sshcommand) - Fixed commands over SSH
2013-06-08 04:29:46 -07:00
2013-06-08 12:39:29 -07:00
## Ideas for Improvements
* Custom domain support for apps
* HTTPS support on default domain
* Support more buildpacks (see Buildstep)
* Use dokku as the system user instead of git
* Heroku-ish commands to be run via SSH (like [Dokuen](https://github.com/peterkeen/dokuen#available-app-sub-commands))
Looking to keep codebase as simple and hackable as possible, so try to keep your line count down.
## Things this project won't do
2013-06-12 14:02:36 -06:00
* **Multi-host.** Not a huge leap, but this isn't the project for it. Maybe as Super Dokku.
2013-06-08 12:39:29 -07:00
* **Multitenancy.** It's ready for it, but again, probably for Super Dokku.
* **Client app.** Given the constraints, running commands remotely via SSH is fine.
2013-06-08 04:29:46 -07:00
## License
MIT