Warning This repository has been archived and is no longer supported.
To create a self-hosted runner, please use the
refactr/runner
Docker image on DockerHub.
This repository hosts various utilities for executing self-hosted Sophos Factory runner agents.
Sophos Factory runners can be deployed in several ways:
- As a Docker container
- As a virtual machine
The following components are provided:
- Docker Image: A prebuilt Docker image is hosted on DockerHub at
refactr/runner
. - Dockerfile: Clone or fork this repository and edit the Dockerfile to build your own custom Sophos Factory Runner container image.
- Install Script: The install script is used to install the runner on a virtual machine.
Docker is required to build or run the container image.
Click here for Docker installation instructions.
Regardless of the method used, the agent requires a configuration file to start. This file contains the runner authentication details.
To create a config file:
- Retrieve your
AGENT_ID
andAGENT_KEY
from the application. - An example file is provided in
config/config-example.json
. Make a copy of this file inconfig/config.json
. - Add your
AGENT_ID
andAGENT_KEY
to the file.
The config file should be placed in /etc/runner-agent.json
on the runner machine.
Tip: It's also possible to provide the
AGENT_ID
andAGENT_KEY
values using environment variables.
To run the runner container, mounting your config file as a volume, execute the following command:
docker run --rm -it --name my-runner -v $(pwd)/config/config.json:/etc/runner-agent.json refactr/runner
This command assumes your config file is located in config/config.json
on the Docker host machine.
If the runner initializes and connects successfully, you should see it begin to poll for new pipeline runs.
While the Docker runner is quick to get started, sometimes we need a full virtual machine to run pipelines (e.g., if the pipeline itself runs Docker). We provide an installation script which can be run on a virtual machine to install the runner as a service.
Note:
- The only supported operating system is CentOS 8.
- The runner and install script can and will modify your system. It's highly recommended to use dedicated VM instances for Sophos Factory runners. For testing/dev runners, use the Docker image instead.
- As a root user, run the following command to download and execute the installation script:
curl https://raw.githubusercontent.com/sophos-factory/runner-utils/master/scripts/install-refactr-agent.sh | bash
- Create a configuration file (described above) and place it in
/etc/runner-agent.json
:
echo $'{\n "AGENT_ID": "<agent id>",\n "AGENT_KEY": "<agent key>"\n}' > /etc/runner-agent.json
- Enable and start the runner service
systemctl enable refactr.agentd
systemctl start refactr.agentd
- Confirm that the service started:
systemctl status refactr.agentd
- Check the log file to ensure the runner is connected and polling for new runs:
journalctl -u refactr.agentd -f
The Dockerfile can be used to build your own runner agent Docker image. It is meant to be a reasonable base image to start from when building a custom runner.
To build the image:
- Clone this repository:
git clone git@github.com:sophos-factory/runner-utils.git runner-utils
cd runner-utils
- Build the image:
docker build -t my-runner .
- Run the container (with a config file, described above):
docker run --rm -it --name my-runner -v $(pwd)/config/config.json:/etc/runner-agent.json my-runner
The Docker image and install script do not install all tools necessary to run all aspects of every tool supported by the Sophos Factory Platform. For example, many supported tools require extra dependencies to use plugins or modules (e.g., Ansible).
In most cases, it's recommended to install these extra dependencies as part of your pipelines, however there are some scenarios where it makes sense to preinstall tools when using a self-hosted runner.
Runners hosted by Sophos Factory provide a larger set of preinstalled packages and additional operating system setup, which allows more supported tools to work out of the box.
Please see Sophos Services Agreement and Sophos Privacy Notice.