Skip to content

Latest commit

 

History

History
194 lines (140 loc) · 9.89 KB

README.md

File metadata and controls

194 lines (140 loc) · 9.89 KB

O3DE Jenkins Pipeline

This project automates the deployment of the O3DE Jenkins Pipeline that runs the checks on all pull requests submitted to the Open 3D Engine (O3DE).

Jenkins Configuration Components:

  • Dockerfile: Generates a custom image from the Jenkins Docker Image.
  • Jenkins Configuration as Code (JCasC): This automates the configuration of the Jenkins server.
  • Job DSL: Pipeline jobs defined using Job DSL will be configured automatically using JCasC.
  • Plugins Manager: The plugin installation manager tool provided in the parent image will install the plugins defined in the repo.

Hosting Components:

  • AWS Cloud Development Kit (CDK) Stacks: This will setup stacks using CodePipeline and ECS to host Jenkins and automate its deployment.

Jenkins Docker Image

We use the Jenkins Docker Image as the parent in our dockerfile to generate our custom image. This allows us to install our required plugins and load other custom options.

JCasC

Jenkins is configured using the JCasC plugin. This allows the settings to be defined using yaml files stored in the repo and prevents users from having to manually configure Jenkins on startup.

These files should be located in the configs directory so that they are found by the plugin.. There is a main jenkins.yaml file that contains the recommended default settings. You can customize your Jenkins setup by editing this file.

There are also template files that can be used for other optional settings. The plugin also supports having multiple yaml files and will locate all files having the .yml/.yaml extension.

Job DSL

JCasC provides support for the Job DSL plugin to automatically configure pipeline jobs. It's recommended to store the config files in the jobdsl directory at the root of the project and reference them in configs/jobs.yaml.

Directory Structure:

PROJECT_ROOT/
|
|- configs/jobs.yaml
|
|- jobdsl/
    |
    |- job1.groovy
    |- job2.groovy

Example jobs.yaml file:

jobs:
  - file: ${JENKINS_LOCAL}/jobdsl/job1.groovy
  - file: ${JENKINS_LOCAL}/jobdsl/job2.groovy

Note: The jobdsl directory is copied into $JENKINS_LOCAL when the docker image is created.

To get started the basic Job DSL API reference can be found here: https://jenkinsci.github.io/job-dsl-plugin/ The complete API reference which includes all installed plugins can be found on your Jenkins server: $JENKINS_URL/plugin/job-dsl/api-viewer/index.html

Installing Plugins

The list of plugins installed on the Jenkins server is maintained in the plugins.txt file. Plugins added/removed from this list will be installed/uninstalled when a new image is created and deployed.

Running your own Jenkins Pipeline

This Jenkins Pipeline can be used to run the AR on your O3DE projects. Create a fork of this repo to customize the setup.

Requirements:

  • Create a GitHub OAuth App

The Jenkins server is setup to use GitHub for authentication. It's also possible to customize the auth for your own setup (e.g. ldap, saml, etc.). Follow the steps below to use the built-in config.

GitHub OAuth App

  1. Visit one of these pages to create the OAuth app:
  2. Click on New OAuth App.
    • Add Application Name: This will be displayed when users login for the first time.
    • Add Homepage URL: This is your Jenkins server URL.
    • Add Authorization callback URL: HOMEPAGE-URL/securityRealm/finishLogin (replace HOMEPAGE-URL with your Homepage URL)
  3. Click Register Application
  4. Note the client ID and secret, this will be used in the following steps.

Option 1: Self-hosted

This can be used to host the docker container on your own server or run a local instance for testing.

Requirements:

  • Install docker on your target platform: https://docs.docker.com/get-docker/
  • Update configs/jenkins.yaml and provide the require values for the GitHub client ID and secret. Also add additional config files if required. See Jenkins Configuration section above.

⚠️ Do not commit secrets to the repo. Edit the file locally for testing or store secrets in environment variables. Use -e key=value with docker run to pass the env vars to the container. For other options see: https://github.com/jenkinsci/configuration-as-code-plugin/blob/master/docs/features/secrets.adoc

Docker Container Setup:

  1. Clone the repo and cd into the repo root
  2. Build the docker image: docker build -t jenkins .
  3. Create a volume to store the JENKINS_HOME directory.
  4. Run the docker image: docker run -d -p 8080:8080 --mount type=volume,target=/var/jenkins_home,source=<volume-name> jenkins

After the Jenkins service starts up, go to http://HOST:8080

Option 2: Deploy to the cloud

AWS

CDK Pipelines is used to automatically build the docker image and deploy a stack to host the container in ECS. The pipeline is self-mutating and allows developers to completely manage the pipeline from the git repo after performing the initial bootstrapping step.

Stacks

Stack Path Description
CDK Pipeline cdk Automates the deployment of the Jenkins server. This stack only needs to be bootstrapped and deployed once by the user. All further deployments and updates to the pipeline will be automated.
Jenkins Server cdk/jenkins_server This stack is configured to host the Jenkins service in ECS/Fargate.

Requirements:

ℹ️ CDK packages are written in python and the instructions below utilize python3 and venv.

  • AWS CDK prerequisites: https://docs.aws.amazon.com/cdk/v2/guide/work-with.html#work-with-prerequisites
    • Setup AWS credentials
    • Install Node.js and the AWS CDK Toolkit
  • Required context values (passed via cdk.context.json or cdk deploy --context)
    • repo: org/repo name of the Github repo (e.g. o3de/o3de-jenkins-pipeline)
    • branch: name of the branch used for pipeline deployments
    • cert-arn: This can be an SSL cert created by or imported into AWS Certificate Manager (ACM). See ACM SSL Certificate Setup below
    • codestar-connection: This grants access to CodePipeline to access the GitHub repo hosting your config files. See CodeStar Connection Setup below.
  • Optional context values
    • vpc-id: Provide an ID to use an existing VPC for the Jenkins Server stack instead of creating a new one.
ACM SSL Certificate Setup

Follow one of the steps below to request or import a cert. ACM will be used to associate the cert with the Jenkins service.

CodeStar Connection Setup

This allows AWS services to connect to third-party repos.

Deployment Steps:

  1. Perform a one-time bootstrap step in the AWS account/region you'll deploy this pipeline.
cdk bootstrap aws://<accountid>/<region>
  1. Create a fork of this repo and create a target branch for deployments.
  2. Add your configs
    • Update cdk/cdk.context.json with the required context values (alternatively you can provide these values using --context when running cdk deploy)
    • Update configs/jenkins.yaml and provide the require values for the GitHub client ID and secret. Also add additional config files if required. See Jenkins Configuration section above.

    ⚠️ Do not commit secrets to the repo. Store secrets in AWS Parameter Store and enter the parameter names instead (e.g. ${parameter-name}). For other options see: https://github.com/jenkinsci/configuration-as-code-plugin/blob/master/docs/features/secrets.adoc

  3. Push these changes to your branch used for deployments
  4. Deploy: This is a one-time manual deployment. Further updates will be deployed through the CDK pipeline. Follow the steps in the CDK Deployment Steps section below.

CDK Deployment Steps

Run these steps within the cdk directory.

  1. Recommended: Create a virtualenv
python3 -m venv .venv
  1. Activate the virtualenv
  • Mac/Linux:
source .venv/bin/activate
  • Windows:
.venv\Scripts\activate.bat
  1. Install the required dependencies
pip install -r requirements.txt
  1. Run cdk deploy and confirm the deployment when prompted
    • Use --profile to use a named config
    • Use --context to provide values not added to cdk.context.json

⚠️ Review the items listed under IAM Statement Changes prior to confirming and deploying the CDK stack. During the bootstrap step CloudFormation was granted IAM permissions required to create and assign roles for deployments. Pay attention to this section especially if you've customized the IAM permissions in the stack.

cd cdk
cdk deploy

Example cdk deploy command with context values:

cdk deploy --context codestar-connection=arn:aws:codestar-connections:us-west-2:123456789012:connection/abcd-efgh-1234-5678 --context repo=o3de/o3de-jenkins-pipeline --context branch=prod --context cert-arn=arn:aws:acm:us-west-2:123456789012:certificate/abcd-efgh-1234-5678

Deploying Updates

Further updates to the CDK Pipeline or the Jenkins config will be made by merging in commits to the target branch configured earlier.

Additional info on Jenkins deployments, including troubleshooting steps, can be found here: Jenkins Deployment Guide

Recommended: Set branch protection on your target branch to require pull request approvals before deploying changes.