improving installation docs

This commit is contained in:
Brad Rydzewski 2015-10-07 17:17:15 -07:00
parent 5ba7dad0dc
commit a63f942c1f
19 changed files with 93 additions and 104 deletions

View file

@ -1,4 +1,4 @@
* [Overview](overview.md) * [Overview](index.md)
* [Variables](env.md) * [Variables](env.md)
* [Secrets](secrets.md) * [Secrets](secrets.md)
* [Cache](cache.md) * [Cache](cache.md)

View file

@ -1,3 +1,3 @@
* [Overview](overview.md) * [Overview](index.md)
* [Example](example.md) * [Example](example.md)
* [Publish](publish.md) * [Publish](publish.md)

View file

@ -1,9 +1,11 @@
* Install * Install
* [Ubuntu](ubuntu.md) * [Install](index.md)
* [Docker](install.md) * [Upgrade](upgrade.md)
* Setup * [Plugins](plugins.md)
* Server
* [Server](server.md) * [Server](server.md)
* [Docker](docker.md) * [Nginx](nginx.md)
* Remotes
* [GitHub](github.md) * [GitHub](github.md)
* [GitLab](gitlab.md) * [GitLab](gitlab.md)
* [Bitbucket](bitbucket.md) * [Bitbucket](bitbucket.md)

View file

@ -3,8 +3,8 @@
Drone comes with built-in support for Bitbucket. To enable Bitbucket you should configure the Bitbucket driver using the following environment variables: Drone comes with built-in support for Bitbucket. To enable Bitbucket you should configure the Bitbucket driver using the following environment variables:
```bash ```bash
REMOTE_DRIVER="bitbucket" REMOTE_DRIVER=bitbucket
REMOTE_CONFIG="https://bitbucket.org?client_id=${client_id}&client_secret=${client_secret}" REMOTE_CONFIG=https://bitbucket.org?client_id=${client_id}&client_secret=${client_secret}
``` ```
## Bitbucket configuration ## Bitbucket configuration

View file

@ -1,6 +1,6 @@
# Docker # Docker
Drone uses the local Docker daemon (at `unix:///var/run/docker.sock`) to execute your builds with 1x concurrency. This section describes how to customize your Docker configuration and concurrency settings using the `DOCKER_*` environment variables. Drone uses the local Docker daemon (at `unix:///var/run/docker.sock`) to execute your builds with 2x concurrency. This section describes how to customize your Docker configuration and concurrency settings using the `DOCKER_*` environment variables.
Configure a single Docker host (1x build concurrency): Configure a single Docker host (1x build concurrency):

View file

@ -3,8 +3,8 @@
Drone comes with built-in support for GitHub and GitHub Enterprise. To enable GitHub you should configure the GitHub driver using the following environment variables: Drone comes with built-in support for GitHub and GitHub Enterprise. To enable GitHub you should configure the GitHub driver using the following environment variables:
```bash ```bash
REMOTE_DRIVER="github" REMOTE_DRIVER=github
REMOTE_CONFIG="https://github.com?client_id=${client_id}&client_secret=${client_secret}" REMOTE_CONFIG=https://github.com?client_id=${client_id}&client_secret=${client_secret}
``` ```
## GitHub configuration ## GitHub configuration
@ -37,4 +37,4 @@ This section lists all connection options used in the connection string format.
You must register your application with GitHub in order to generate a Client and Secret. Navigate to your account settings and choose Applications from the menu, and click Register new application. You must register your application with GitHub in order to generate a Client and Secret. Navigate to your account settings and choose Applications from the menu, and click Register new application.
Please use `/authorize` as the Authorization callback URL path. Please use `http://drone.mycompany.com/authorize` as the Authorization callback URL.

View file

@ -3,8 +3,8 @@
Drone comes with built-in support for GitLab version 8.0 and higher. To enable Gitlab you should configure the Gitlab driver using the following environment variables: Drone comes with built-in support for GitLab version 8.0 and higher. To enable Gitlab you should configure the Gitlab driver using the following environment variables:
```bash ```bash
REMOTE_DRIVER="gitlab" REMOTE_DRIVER=gitlab
REMOTE_CONFIG="https://gitlab.hooli.com?client_id=${client_id}&client_secret=${client_secret}" REMOTE_CONFIG=https://gitlab.hooli.com?client_id=${client_id}&client_secret=${client_secret}
``` ```
## Gitlab configuration ## Gitlab configuration
@ -37,4 +37,4 @@ This section lists all connection options used in the connection string format.
You must register your application with GitLab in order to generate a Client and Secret. Navigate to your account settings and choose Applications from the menu, and click New Application. You must register your application with GitLab in order to generate a Client and Secret. Navigate to your account settings and choose Applications from the menu, and click New Application.
Please use `/authorize` as the Authorization callback URL path. Please use `http://drone.mycompany.com/authorize` as the Authorization callback URL.

View file

@ -37,62 +37,18 @@ Here are some of the Docker options, explained:
Drone uses environment variables for runtime settings and configuration, such as GitHub, GitLab, plugins and more. These settings can be provided to Docker using an `--env-file` as seen above. Drone uses environment variables for runtime settings and configuration, such as GitHub, GitLab, plugins and more. These settings can be provided to Docker using an `--env-file` as seen above.
Once you have your drone container created, then you can start/stop/restart it in below ways.
## Starting, Stopping, Logs ## Starting, Stopping, Logs
Commands to start, stop and restart Drone: Commands to start, stop and restart Drone:
``` ```
docker start drone sudo docker start drone
docker stop drone sudo docker stop drone
docker restart drone sudo docker restart drone
``` ```
And to view the Drone logs: And to view the Drone logs:
``` ```
docker logs drone sudo docker logs drone
```
## Upstart
Drone can be configured to work with process managers, such as **Ubuntu** Upstart, to automatically start when the operating system initializes. Here is an example upstart script that can be placed in `/etc/init/drone.conf`:
```
description "Drone container"
start on filesystem and started docker
stop on runlevel [!2345]
respawn
script
/usr/bin/docker start -a drone
end script
```
Commands to start and stop Drone:
```
sudo start drone
sudo stop drone
```
## Systemd
Drone can be configured to work with Systemd to automatically start when the operating system initializes. Here is an example systemd file:
```
[Unit]
Description=Drone container
Requires=docker.service
After=docker.service
[Service]
Restart=always
ExecStart=/usr/bin/docker start -a drone
ExecStop=/usr/bin/docker stop -t 2 drone
[Install]
WantedBy=local.target
``` ```

20
docs/setup/nginx.md Normal file
View file

@ -0,0 +1,20 @@
# Nginx
Using a proxy server is **not necessary**. Drone serves most static content from a CDN and uses the Go standard librarys high-performance net/http package to serve dynamic content.
If using Nginx to proxy traffic to Drone, please ensure you have version 1.3.13 or greater. You also need to configure nginx to write `X-Forwarded_*` headers:
```
location / {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $remote_addr;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Host $http_host;
proxy_set_header Origin "";
proxy_pass http://127.0.0.1:8000;
proxy_redirect off;
}
```
Our installation instructions recommend running Drone in a Docker container with port `:80` published. When behind a reverse proxy, you should run the Drone Docker container with `--publish=8000:8000`. This will publish Drone to port `:8000` allowing you to proxy from `:80`.

View file

@ -2,29 +2,20 @@
Plugins are Docker containers, executed during your build process. Plugins are downloaded automatically, on-demand as they are encountered in your `.drone.yml` file. Plugins are Docker containers, executed during your build process. Plugins are downloaded automatically, on-demand as they are encountered in your `.drone.yml` file.
Plugin examples include:
* `git` plugin to clone your repository
* `gh_pages` plugin to publish documentation to GitHub pages
* `slack` plugin to notify your Slack channel when a build completes
* `s3` plugin to push files or build artifacts to your S3 bucket
See the [plugin marketplace](http://addons.drone.io) for a full catalog of official plugins. See the [plugin marketplace](http://addons.drone.io) for a full catalog of official plugins.
## Security ## Security
For security reasons you must whitelist plugins. The default whitelist matches the official Drone plugins -- `plugins/drone` hosted in the [Docker registry](https://registry.hub.docker.com/repos/plugins/). For security reasons you must whitelist plugins. The default whitelist includes the official Drone plugins hosted in the [Docker registry](https://registry.hub.docker.com/repos/plugins/). Customize your whitelist by setting the `PLUGIN_FILTER` environment variable. This is a space-separated list and includes glob matching capabilities.
You can customize your whitelist by setting the `PLUGINS` environment variable. Note that you can use globbing to whitelist all Docker images with a defined prefix: Whitelist official Drone plugins
**Example 1:** whitelist official Drone plugins
``` ```
PLUGINS=plugins/* PLUGIN_FILTER=plugins/*
``` ```
**Example 2:** whitelist plugins for registry user `octocat` Whitelist official Drone plugins and registry user `octocat`
``` ```
PLUGINS=octocat/* PLUGIN_FILTER=plugins/* octocat/*
``` ```

View file

@ -4,8 +4,8 @@
Drone comes with support for Postgres as an alternate database engine. To enable Postgres, you should specify the following environment variables: Drone comes with support for Postgres as an alternate database engine. To enable Postgres, you should specify the following environment variables:
``` ```
DATABASE_DRIVER="postgres" DATABASE_DRIVER=postgres
DATABASE_CONFIG="postgres://root:pa55word@127.0.0.1:5432/postgres" DATABASE_CONFIG=postgres://root:pa55word@127.0.0.1:5432/postgres
``` ```
## Postgres configuration ## Postgres configuration

View file

@ -13,22 +13,22 @@ This section lists all environment variables used to configure the server.
This example changes the default port to `:80`: This example changes the default port to `:80`:
```bash ```bash
SERVER_ADDR=":80" SERVER_ADDR=:80
``` ```
## Server SSL ## Server SSL
Drone uses the `ListenAndServeTLS` function in the Go standard library to accept `https` connections. If you experience any issues configuring `https` please contact us on [gitter](https://gitter.im/drone/drone). Please do not log an issue saying `https` is broken in Drone (it isn't). Drone uses the `ListenAndServeTLS` function in the Go standard library to accept `https` connections. If you experience any issues configuring `https` please contact us on [gitter](https://gitter.im/drone/drone). Please do not log an issue saying `https` is broken in Drone.
This example accepts `HTTPS` connections: This example accepts `HTTPS` connections:
```bash ```bash
SERVER_ADDR=":443" SERVER_ADDR=:443
SERVER_KEY="/path/to/key.pem" SERVER_KEY=/path/to/key.pem
SERVER_CERT="/path/to/cert.pem" SERVER_CERT=/path/to/cert.pem
``` ```
> **NOTE** if the certificate is signed by a certificate authority, the cert should be the concatenation of the server's certificate followed by the CA's certificate. > When your certificate is signed by an authority, the certificate should be the concatenation of the server's certificate followed by the CA certificate.
When running Drone inside Docker, you'll need to mount a volume containing the certificate: When running Drone inside Docker, you'll need to mount a volume containing the certificate:

View file

@ -3,8 +3,8 @@
Drone uses SQLite as the default database with zero configuration required. In order to customize the SQLite database configuration you should specify the following environment variables: Drone uses SQLite as the default database with zero configuration required. In order to customize the SQLite database configuration you should specify the following environment variables:
```bash ```bash
DATABASE_DRIVER="sqlite3" DATABASE_DRIVER=sqlite3
DATABASE_CONFIG="/var/lib/drone/drone.sqlite" DATABASE_CONFIG=/var/lib/drone/drone.sqlite
``` ```
## Sqlite3 configuration ## Sqlite3 configuration
@ -23,12 +23,4 @@ The components of the datasource connection string are:
## Sqlite3 options ## Sqlite3 options
This section lists all connection options used in the connection string format. Connection options are pairs in the following form: `name=value`. The value is always case sensitive. Separate options with the ampersand (i.e. &) character: See the official [driver documentation](https://www.sqlite.org/uri.html#coreqp) for a full list of driver options.
* `vfs` opens the database connection using the VFS value.
* `mode` opens the database as `ro`, `rw`, `rwc` or `memory`.
* `cache` opens the database with `shared` or `private` cache.
* `psow` overrides the powersafe overwrite property of the database file being opened.
* `_loc` sets the location of the time format. Use `auto` to auto-detect.
* `_busy_timeout` sets the value of the `sqlite3_busy_timeout`
* `_txlock` sets the locking behavior to `immediate`, `deferred`, or `exclusive`

28
docs/setup/upgrade.md Normal file
View file

@ -0,0 +1,28 @@
# Upgrading
Drone is built continuously, with updates available daily. In order to upgrade Drone you must first stop and remove your running Drone instance:
```
sudo docker stop drone
sudo docker rm drone
```
Pull the latest Drone image:
```
sudo docker pull drone/drone:0.4
```
Run the container using the latest Drone image:
```
sudo docker run \
--volume /var/lib/drone:/var/lib/drone \
--volume /var/run/docker.sock:/var/run/docker.sock \
--env-file /etc/drone/dronerc \
--restart=always \
--publish=80:8000 \
--detach=true \
--name=drone \
drone/drone:0.4
```

View file

@ -8,19 +8,19 @@ block header
li Documentation li Documentation
ul.nav.nav-tabs ul.nav.nav-tabs
li.nav-item li.nav-item
a[class="nav-link"][href="../setup/ubuntu.html"] a[class="nav-link"][href="../setup/"]
.active ? Site.Name == "Install" .active ? Site.Name == "Install"
| Install | Install
li.nav-item li.nav-item
a[class="nav-link"][href="../build/overview.html"] a[class="nav-link"][href="../build/"]
.active ? Site.Name == "Builds" .active ? Site.Name == "Builds"
| Builds | Builds
li.nav-item li.nav-item
a[class="nav-link"][href="../plugin/overview.html"] a[class="nav-link"][href="../plugin/"]
.active ? Site.Name == "Plugins" .active ? Site.Name == "Plugins"
| Plugins | Plugins
li.nav-item li.nav-item
a.nav-link[href="../api/index.html"] API Reference a.nav-link[href="../api/i"] API Reference
block content block content
div.container-fluid.docs.docs-usage div.container-fluid.docs.docs-usage

View file

@ -33,7 +33,7 @@ block content
form form
fieldset.form-group fieldset.form-group
label[for="addr"] Address label[for="addr"] Address
input.form-control[type="text"][placeholder="unix:///var/run/docker/docker.sock"]#addr input.form-control[type="text"][placeholder="unix:///var/run/docker.sock"]#addr
fieldset.form-group fieldset.form-group
label[for="key"] Key label[for="key"] Key
textarea.form-control#key textarea.form-control#key

View file

@ -8,11 +8,11 @@ block header
li Documentation li Documentation
ul.nav.nav-tabs ul.nav.nav-tabs
li.nav-item li.nav-item
a.nav-link[href="../setup/ubuntu.html"] Install a.nav-link[href="../setup/"] Install
li.nav-item li.nav-item
a.nav-link[href="../build/overview.html"] Builds a.nav-link[href="../build/"] Builds
li.nav-item li.nav-item
a.nav-link[href="../plugin/overview.html"] Plugins a.nav-link[href="../plugin/"] Plugins
li.nav-item li.nav-item
a.nav-link.active[href="#"] API Reference a.nav-link.active[href="#"] API Reference