Migration utility will help you migrate from a Drone 0.8.x database to a Drone 1.0.x database.
Please note the migration utility may require manual database cleanup. For example, in 0.8 the same repository can be listed in the database twice if it has been renamed, however, in 1.0 this will cause unique key violations. These edge cases require manual intervention. You should therefore be comfortable with sql and database troubleshooting before you proceed.
- create a full backup of your 0.8.x Drone database
- create a new database for your 1.0.x server
- do not create or start your drone 1.0 container until this is complete
docker pull drone/migrate
The migration utility will copy data from your 0.8.x database to your new 1.0.x database. You will need to provide the migration tool with the connection string for both the old and new database.
-e SOURCE_DATABASE_DRIVER=sqlite3|mysql|postgres
-e TARGET_DATABASE_DRIVER=sqlite3|mysql|postgres
-e SOURCE_DATABASE_DATASOURCE=/path/to/old/database.sqlite
-e TARGET_DATABASE_DATASOURCE=/path/to/new/database.sqlite
Configure the Drone 1.0 server address:
-e DRONE_SERVER=https://drone.company.com
If you are using GitHub, configure the GitHub driver:
-e SCM_DRIVER=github
-e SCM_SERVER=https://api.github.com
If you are using GitHub Enterprise, configure the GitHub driver:
-e SCM_DRIVER=github
-e SCM_SERVER=https://github.company.com/api/v3
If you are using Gogs, configure the Gogs driver:
-e SCM_DRIVER=gogs
-e SCM_SERVER=https://gogs.company.com
If you are using Gitea, configure the Gitea driver:
-e SCM_DRIVER=gitea
-e SCM_SERVER=https://gitea.company.com
If you are using Stash, configure the Stash driver:
-e SCM_DRIVER=stash
-e SCM_SERVER=https://stash.company.com
-e STASH_CONSUMER_KEY=OauthKey
-e STASH_PRIVATE_KEY_FILE=/path/to/private/key.pem
If you are using Bitbucket Cloud, configure the Bitbucket driver:
-e SCM_DRIVER=bitbucket
-e BITBUCKET_CLIENT_ID=$your_client_id
-e BITBUCKET_CLIENT_SECRET=$your_client_secret
$ docker run -e [...] drone/migrate setup-database
$ docker run -e [...] drone/migrate migrate-users
$ docker run -e [...] drone/migrate migrate-repos
$ docker run -e [...] drone/migrate migrate-secrets
$ docker run -e [...] drone/migrate migrate-registries
$ docker run -e [...] drone/migrate migrate-builds
$ docker run -e [...] drone/migrate migrate-stages
$ docker run -e [...] drone/migrate migrate-steps
$ docker run -e [...] drone/migrate migrate-logs
$ docker run -e [...] drone/migrate update-repos
This should be run before the final step
You may optionally run the following commands to purge repositories from the 1.0 database where the repository no longer exists, the repository owner no longer has access, or where the repository has been renamed. We recommend running after migrate-repos
.
$ docker run -e [...] drone/migrate remove-renamed
You can also optionally configure secret encryption in Drone 1.0. If yuo enable encryption you will need to encrypt the secrets before you complete the migration.
$ export TARGET_DATABASE_ENCRYPTION_KEY=....
$ docker run -e [...] -e drone-drone/migrate encrypt-secrets
The final step is to re-activate your repositories. At this time it is safe to start your Drone server. Once the server is started you can execute the final migration command:
$ docker run -e [...] drone/migrate activate-repos
This can be helpful if a particular migration step fails. You can safely truncate the impacted database table and then re-try the migration.
$ docker run -e [...] drone/migrate setup-database
$ docker run -e [...] drone/migrate migrate-users
$ docker run -e [...] drone/migrate migrate-repos
$ docker run -e [...] drone/migrate migrate-builds
$ docker run -e [...] drone/migrate migrate-stages
$ docker run -e [...] drone/migrate migrate-steps
$ docker run -e [...] drone/migrate migrate-logs
you can optionally migrate logs to s3 storage. Note that the migration utility authenticates with aws using standard authentication methods, including aws_access_key_id and aws_secret_access_key
$ docker run -e S3_BUCKET=<bucket> -e [...] drone/migrate migrate-logs-s3
Secrets stored within Drone can be migrated, if you use some external tool to store your secrets like Vault you can skip this step.
$ docker run -e [...] drone/migrate migrate-secrets
If you haven't used ayn private images within the pipeline you can skip this step, this is only needed if you are using private Docker images for your Drone steps.
$ docker run -e [...] drone/migrate migrate-registries
Drone 1.0 stores addition repository metadata that needs to be fetched from the source code management system. This additional metadata is required.
$ docker run -e [...] drone/migrate update-repos
The final step is to ensure all repositories are activated and have a valid web-hook configured in the source code management system.
$ docker run -e [...] drone/migrate activate-repos
You can optionally dump 0.8 user API tokens for use with 1.0 as described here. If your team heavily uses Drone tokens in their build process (to trigger downstream builds, etc) you may find this helpful.
$ docker run -e [...] drone/migrate dump-tokens