forked from mattbrictson/rails-template
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPROVISIONING.md.tt
91 lines (57 loc) · 3.59 KB
/
PROVISIONING.md.tt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
# How to provision a new environment for <%= app_name %>
This project uses the open source [capistrano-mb](https://github.com/mattbrictson/capistrano-mb) set of tasks for capistrano to provision new environments. This document contains a quick overview of the provisioning process.
In capistrano terminology, *stage* refers to an environment like `staging` or `production`. These instructions will use the *stage* term for the remainder of the document.
In this document, *provisioning* refers to preparing a server for deployment, including the following steps:
* Installing Nginx, Redis, and PostgreSQL
* Compiling Ruby
* Creating the database
* Setting passwords and other configuration
## Prerequisites
Capistrano runs on your local machine and uses SSH to perform the deployment on the remote server. Therefore:
* The Capistrano gem must be installed (see `README.md` for project setup instructions).
* You must have SSH access to the server.
* Your SSH key must be installed on the server.
* Your account on the server must have `sudo` access.
* Your account must be able to run `sudo` without be prompted for a password. See [How to run sudo command with no password?](http://askubuntu.com/questions/192050/how-to-run-sudo-command-with-no-password).
Furthermore, the server itself must meet the following requirements:
* Ubuntu 16.04 LTS (64 bit).
## 1. Create a new stage (or edit an existing one)
Stages are defined as `.rb` files in the `config/deploy/` directory. The name of the file becomes the name of the stage when executing capistrano commands. For example, the production stage is defined in `config/deploy/production.rb`.
Create a new stage (or modify an existing one to move that stage to a new server address, for example) using the existing stage files as examples. The stage file describes the IP address of the server and other stage-specific information.
## 2. Run the provision command
`bundle exec cap <stage> provision`
Replace `<stage>` with the name of the stage you wish to provision (e.g. `production`).
You will be prompted to choose passwords and enter other configuration values as the script runs.
It is safe to run the provision command multiple times on the same stage (the scripts are generally idempotent).
## 3. Install a custom SSL key and certificate using Let's Encrypt with auto-renewal
Perform the following commands as root.
```
mkdir -p /opt/certbot
cd /opt/certbot/
wget https://dl.eff.org/certbot-auto
chmod a+x certbot-auto
./certbot-auto certonly
```
When prompted:
* Select the *webroot* option
* Enter domains to secure (for example): `<%= production_hostname %>`
* Enter webroot path: `/home/deployer/apps/<%= capistrano_app_name %>/shared/public/`
The `.pem` files created by `certbot-auto` need to be linked so Nginx can see them:
```
ln -s /etc/letsencrypt/live/<%= production_hostname %>/fullchain.pem /etc/ssl/<%= capistrano_app_name %>.crt
ln -s /etc/letsencrypt/live/<%= production_hostname %>/privkey.pem /etc/ssl/<%= capistrano_app_name %>.key
```
Restart Nginx to enable the certificate:
```
service nginx restart
```
Verify auto-renewal works by doing a dry run:
```
/opt/certbot/certbot-auto renew --webroot-path /home/deployer/apps/<%= capistrano_app_name %>/shared/public/ --dry-run
```
Finally, add this to the root crontab to enable auto-renewal:
```
<%= rand(60) %> <%= h=rand(11); "#{h},#{h+12}" %> * * * /opt/certbot/certbot-auto renew --quiet --no-self-upgrade --webroot-path /home/deployer/apps/<%= capistrano_app_name %>/shared/public/
```
## 4. Deploy
Once provisioning is complete, deploy the application using the capistrano instructions in `DEPLOYMENT.md`.