Skip to content

Latest commit

 

History

History
84 lines (67 loc) · 2.69 KB

README.md

File metadata and controls

84 lines (67 loc) · 2.69 KB

circleci-runners

Example code for CircleCI Runners

CircleCI Runner Docs

Installing the CircleCI Runner

Create a CircleCI Namespace

Create a CircleCI Personal API Token

Install circleci cli

sudo curl -fLSs https://raw.githubusercontent.com/CircleCI-Public/circleci-cli/master/install.sh | bash
``
# Create a CircleCI namespace you can have only one namespace per Organization
```shell
circleci namespace create ***<Name for namespace>*** github ***<VCS Organization>***

Create a resource class in the CircleCI CLI (eg. namespace/)

circleci runner resource-class create ***namespace/<name for resource-class>*** "digital ocean runner"

Create a token for authenticating the resource-class - Copy the token and save it

NOTE: Save the Runner Token value upon creating. This will be the only time the token will be visible. You will have to regenerate the token if you don't capture it on previous creation attempts. I suggest you assign the token value to a $RUNNER_TOKEN environment variable locally on the machine executing and provisioning your CircleCI Runners. This will prevent exposing this sensitive data in command line executions.

circleci runner token create ***namespace/<resource-class name>*** ***"<description>"***

Terraform execution commands for Digital Ocean provider

These are the commands for the terraform execution commands.

Execute Plan

terraform plan \
  -var "do_token=${DIGITAL_OCEAN_TOKEN}" \
  -var "runner_token=${RUNNER_TOKEN}" \
  -var "runner_name=dorunner" \
  -var "ssh_key_file=${HOME}/.ssh/id_rsa"

Execute Apply

terraform apply \
  -var "do_token=${DIGITAL_OCEAN_TOKEN}" \
  -var "runner_token=${RUNNER_TOKEN}" \
  -var "runner_name=dorunner" \
  -var "ssh_key_file=${HOME}/.ssh/id_rsa"

Execute Apply with --auto-approve

terraform apply \
  -var "do_token=${DIGITAL_OCEAN_TOKEN}" \
  -var "runner_token=${RUNNER_TOKEN}" \
  -var "runner_name=dorunner" \
  -var "ssh_key_file=${HOME}/.ssh/id_rsa" \
  -auto-approve

Execute Destroy

terraform destroy \
  -var "do_token=${DIGITAL_OCEAN_TOKEN}" \
  -var "runner_token=${RUNNER_TOKEN}" \
  -var "runner_name=dorunner" \
  -var "ssh_key_file=${HOME}/.ssh/id_rsa"

Execute Destroy with --auto-approve

terraform destroy \
  -var "do_token=${DIGITAL_OCEAN_TOKEN}" \
  -var "runner_token=${RUNNER_TOKEN}" \
  -var "runner_name=dorunner" \
  -var "ssh_key_file=${HOME}/.ssh/id_rsa" \
  -auto-approve