For Drone CI installation auxilincom.drone Ansible role is used.
- Ansible
- Ubuntu 16.04 server & ssh access to that server
❕ deploment tested on the latest DigitalOcean Ubuntu dropet. Some changes might be required to run other linux distributives.
High level deployment steps:
- Docker installation
- Nginx proxy installation & configuration to work with Drone
- PostgreSQL installation for Drone to persist build information
- Running Drone & Drone CI inside Docker containers
- Optional configuration of SSL certificate
Prepare for deployment:
- Update server ip in
hosts
file. If you are planning to use same server for both drone and nginx - just put same ip for both, drone & nginx targets. - Install Ansible role dependencies with one command:
./bin/install-ansible-dependencies.sh
- Update github application callback url to either point to your server ip address or your domain. For example:
http://ci.myapp.com/login
or justhttp://server_ip/login
. - Set server ip variable or domain name in
vars/main.yml
(drone_server_host
variable). - Update
drone_user_create
invars/main.yml
- a comma separated list of github users, who will have admin access your continuous integration server. Read more here. - Rename
credentials-template.yml
intocredentials.yml
and update your github clientId, clientSecret, drone secrets, certbot dns data as well as username and password for PostgreSQL database.
Once you done all above, run the following command:
$ ./bin/setup-server.sh && ./bin/deploy-drone.sh
You should have Drone CI installed by now. The only step remaining is to make Drone work behind Nginx proxy.
If you would like to install nginx on a same server with Drone CI - just run following command:
$ ./bin/setup-nginx.sh
If you already have nginx installed somewhere else and just would like to attach drone nginx configuration to existing nginx server you can do following:
- Set nginx server ip in
hosts
file for the nginx target - Run same command
./bin/setup-nginx.sh
, but replyno
to the question about nginx installation.
In this case nginx configuration for Drone CI will be copied to the existing nginx server.
- Place your ssl keys into the
ssl-keys
directory as app.crt and app.key (they are in a.gitignore
) - Make sure that
server_setup_ssl
is set toyes
invars/main.yml
- Deploy ssl using
./bin/setup-server.sh --tags "nginx"
- Update callback url in the Github application to start from
https