Capistrano::Uberspace
Deploy your Rails App to uberspace with Capistrano 3.
Has support for MySQL, Potsgresql, and sqlite3 databases. Runs your app with any ruby version available at your uberpace.
Installation
Add this line to your application's Gemfile:
gem 'capistrano', '~> 3.4.0'
gem 'capistrano-uberspace', github: 'tessi/capistrano-uberspace'
If you do not install capistrano-uberspace
in the production
-group, then add passenger
as a production dependency:
gem 'passenger', group: :production
And then execute:
$ bundle install
In your config/deploy.rb
file specify some app properties:
set :application, 'MyGreatApp'
set :repo_url, '[email protected]:tessi.my_great_app.git'
Also specify how to reach the uberspace server in your stage definition (e.g. production.rb
):
server 'your-host.uberspace.de',
user: 'uberspace-user',
roles: [:app, :web, :cron, :db],
primary: true,
ssh_options: {
keys: %w{~/.ssh/your_uberspace_private_key},
forward_agent: true,
auth_methods: %w(publickey)
}
set :user, 'uberspace-user'
set :branch, :production
set :domain, 'my-subdomain.example.tld'
Optionally, you may specify HTTP BASIC AUTH authentication in your stage definition:
set :htaccess_username, "username"
set :htaccess_password, "password"
# instead of the :htaccess_password you may set the hashed password directly:
# set :htaccess_password_hashed, "bi2wsSekmG6Yw"
Be sure to setup the ssh-connection to your uberspace and make sure that your uberspace is able to checkout your repository.
Require the following parts in your Capfile
:
require 'capistrano/bundler'
require 'capistrano/rails'
require 'capistrano/rails/assets'
require 'capistrano/rails/migrations'
require 'capistrano/uberspace'
# in the following line replace <database> with mysql, postgresql, or sqlite3
require 'capistrano/uberspace/<database>'
Please bundle the appropriate database-gem in your Gemfile
.
Usage
Execute bundle exec cap <stage> deploy
to deploy to your uberspace.
Configurable options:
set :ruby_version, '2.2' # default is '2.2', can be set to every ruby version supported by uberspace.
set :domain, nil # if you want to deploy your app as a subdomain, configure it here. Use the full URI. E.g. my-custom.example.tld
set :add_www_domain, true # default: true; set this to false if you do not want to also use your subdomain with prefixed www.
Useful tasks:
deploy:start # starts the server
deploy:stop # stops the server
deploy:restart # restarts the server (automatically done after deploy)
deploy:status # shows the current status of the deamon which runs passenger
Contributing
- Fork it
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create new Pull Request
Thanks
This gem was inspired by the awesome uberspacify gem, which lets you deploy your Rails app to uberspace with Capistrano 2.
License
This project is licensed under the MIT License. See the LICENSE
file for details.