If you are building your side project or startup and want to avoid spending too much money on popular commercial solutions like Travic CI (which costs $69/month), you can use your own self-hosted Drone CI on your laptop, AWS free tier, or any other servers.
Drone CI features:
- Multi-platform support
- Yaml-based configuration
- Multi pipelines and complex build step logic support
- Docker based
- Free
- Github, Gitlab, Bitbucket support
We will run Drone CI on a single host and using Github, but you could use a multimachine configuration or Kubernetes, and different VCS providers. Find more information here.
Get the Host
For the purposes of this test, we use an AWS EC2 free tier instance, but you can use whatever you want. To use our approach, follow these steps:
- Go to the AWS page;
- Add your SSH pub key to Key Pairs section on the EC2 page (to access your - instance via SSH);
- Create a new Ubuntu 18.04 free tier instance on AWS;
- Allow 80 and 443 ports for the Security Group of your instance; if it’s a fresh account, use launch-wizard-1, or find it in description of your EC2 instance.
Install Docker
You only need Docker to start using Drone. Just follow the instructions here. Check that you installed everything right by running “docker -v”.
root@ip-172-31-23-205:~# docker -v
Docker version 18.09.3, build 774a1f4
Create an OAuth Application
We use Github for examples, but you can also run it on Gitlab, Bitbucket, Gitea, and Gogs. More information here.
- Go to https://github.com/settings/developers and sign in to your personal account, if you have one, or set up an account if you don’t.
- Click “new oAuth app”.
- Fill out the form, as per the example below.
You can use the IP of your server or assign a domain to it to correctly fill this form. If you do this, you can use the Client ID and Client Secret in the next steps.
Install Drone
This is very simple, just use the following:
docker pull drone/drone:1
Followed by:
--volume=/var/run/docker.sock:/var/run/docker.sock \
--volume=/var/lib/drone:/data \
--env=DRONE_GITHUB_SERVER=https://github.com \
--env=DRONE_GITHUB_CLIENT_ID=652d1he1a62b6336bf0 \
--env=DRONE_GITHUB_CLIENT_SECRET=c8990176a4bfywe55ekj8c3cf6d0ffccb8e3a213e \
--env=DRONE_RUNNER_CAPACITY=2 \
--env=DRONE_SERVER_HOST=drone1.pixelpoint.io \
--env=DRONE_SERVER_PROTO=https \
--env=DRONE_TLS_AUTOCERT=true \
--env=DRONE_USER_FILTER=lnikell \
--env=DRONE_USER_CREATE=username:lnikell,admin:true \
--publish=80:80 \
--publish=443:443 \
--restart=always \
--detach=true \
--name=drone \
drone/drone:1
Using this configuration, Drone generates SSL certificates with Let’s Encrypt, which then lets us use https for accessing the Drone UI. Your user account will have admin privileges (DRONE_USER_CREATE), which you should lose to lock access to the server for anyone else(DRONE_USER_FILTER). You can find explanations of other variables here.
Your instance should now be up and running, simply log in and use it!
Define Your Pipeline
Once you have your Drone CI instance ready, it’s time to activate the repository and create your pipeline. First, find the repository using the search bar and activate it.
On the settings page, you can change your project visibility settings, add secrets(sensitive information required for build steps) or add a cron job.
Defining build steps and pipelines in Drone is a simple process. Just add to your repository .drone.yml file and use yaml syntax to describe the steps. Here’s a simple example:
kind: pipeline
name: default
steps:
- name: frontend
image: node
commands:
- npm ci
- npm run test:unit
The example above is also available here: https://github.com/lnikell/hello-world/tree/master
Now, when you push to the repository, it will trigger a new build on Drone CI.
But you can do much more, depending of the complexity of your project. Here are few typical things that this process can be used for:
- Sending Slack notifications
- Deploying to Kubernetes
- Pushing images to a Docker registry
- Running database or other service instances required for tests
- Running multiple pipelines and using multiplatforms
Drone is an everyday helper which greatly improves the stability, flexibility and ease when our team runs tests and deploys code. For more information about Drone CI, visit https://drone.io/ and check out our story about how did we make Drone 1.0 better.