Introduction
This guide will walk you through using CTO.ai and Docker to establish a CI/CD pipeline, automating your software delivery process.
What is CI/CD
CI/CD stands for Continuous Integration and Continuous Deployment:
- Continuous Integration (CI): This is an automated process for testing code changes to ensure they integrate smoothly with the existing codebase.
- Continuous Deployment (CD): This involves automatically deploying changes that have passed through CI to your production environment.
What is CTO.ai?
CTO.ai is a cloud-based platform that facilitates the CI/CD process. It runs your software tests and deploys your code automatically whenever there are changes.
What is Docker?
Docker is a tool for creating containers for your applications. Containers ensure that your application and all its dependencies work the same across various environments.
Setting Up a CI/CD Pipeline Using CTO.ai and Docker
Create a Dockerfile
A Dockerfile is a script containing instructions to build your Docker container. Here’s an example:
# Use a specific version of node based on Debian for better control and compatibility FROM node:14-buster-slim # Set work directory in the Docker image WORKDIR /app # Copy package.json and package-lock.json (or yarn.lock) to leverage Docker cache COPY package*.json yarn.lock* /app/ # Install build tools and Python for node-gyp, then install node modules # and remove build tools to keep the image small RUN apt-get update && \ apt-get install -y python make g++ && \ npm install --production || yarn install --production && \ apt-get purge -y python make g++ && \ apt-get autoremove -y && \ apt-get clean && \ rm -rf /var/lib/apt/lists/* # Copy the rest of the application COPY . /app # Expose the port the app runs on EXPOSE 8080 # Command to run the application CMD ["node", "app.js"]
You can also use the sample Dockerfile template in our opensource workflow repository .
The Dockerfile is used for an Express.js application and is built for both build performance (using Docker's caching mechanism) and image size (removing unnecessary build tools after installation).
Set Up CTO.ai
- Create a CTO.ai Account: Sign up and connect your GitHub repository with CTO.ai.
- Install the Ops CLI by running the
npm install -g @cto.ai/ops
in your local machine.
The CTO.ai ops CLI acts as the integration point between your command line workflows and the CTO.ai platform, providing a framework for implementing ChatOps-based workflows that integrate with your existing processes. It allows you to build, publish, and run Commands, Pipelines, and Services workflows from the comfort of your terminal, manage your Configs and Secrets stores, and invite members to your CTO.ai team. - Log in to your account using
ops account:signin
Running this command triggers a browser-based signin flow that allows you to log in to your account as your would on the web, as well as sign in with OAuth providers like GitHub. - In your GitHub repository, create a Config File called
ops.yml
: This file contains CTO.ai's instructions, steps, and commands for your project.
Example ops.yml:
version: "1" pipelines: - name: sample-expressjs-pipeline-do-k8s-cdktf:0.2.5 description: Build and Publish an image in a DigitalOcean Container Registry env: static: - DEBIAN_FRONTEND=noninteractive - STACK_TYPE=do-k8s-cdktf - ORG=cto-ai - GH_ORG=workflows-sh - REPO=sample-expressjs-do-k8s-cdktf - BIN_LOCATION=/tmp/tools secrets: - GITHUB_TOKEN - DO_TOKEN events: - "github:workflows-sh/sample-expressjs-do-k8s-cdktf:pull_request.opened" - "github:workflows-sh/sample-expressjs-do-k8s-cdktf:pull_request.synchronize" - "github:workflows-sh/sample-expressjs-do-k8s-cdktf:pull_request.merged" jobs: - name: sample-expressjs-build-do-k8s-cdktf description: Build step for sample-expressjs-do-k8s-cdktf packages: - git - unzip - wget - tar steps: - mkdir -p $BIN_LOCATION - export PATH=$PATH:$BIN_LOCATION - ls -asl $BIN_LOCATION - tar xf doctl.tar.gz -C $BIN_LOCATION - doctl version - git version - git clone https://oauth2:$GITHUB_TOKEN@github.com/$GH_ORG/$REPO - cd $REPO && ls -asl - git fetch -a && git checkout "${REF}" - doctl auth init -t $DO_TOKEN - doctl registry login - CLEAN_REF=$(echo "${REF}" | sed 's/[^a-zA-Z0-9]/-/g' ) - docker build -f Dockerfile -t one-img-to-rule-them-all:latest . - docker tag one-img-to-rule-them-all:latest registry.digitalocean.com/$ORG/$REPO:$CLEAN_REF - docker push registry.digitalocean.com/$ORG/$REPO:$CLEAN_REF services: - name: sample-expressjs-service-do-k8s-cdktf:0.1.6 description: Preview of image built by the pipeline run: node /ops/index.js port: [ '8080:8080' ] sdk: off domain: "" env: static: - PORT=8080 events: - "github:workflows-sh/sample-expressjs-do-k8s-cdktf:pull_request.opened" - "github:workflows-sh/sample-expressjs-do-k8s-cdktf:pull_request.synchronize" - "github:workflows-sh/sample-expressjs-do-k8s-cdktf:pull_request.merged" trigger: - build - publish - start
This configuration defines a job to build your application using Docker.
Automate Deployment
Automate your deployment process:
- Add Deployment Scripts: In the
ops.yml
file, we included commands for deploying your application, like pushing the Docker image to DigitalOcean registry. - Set Environment Variables: In the
ops.yml
file above, we also included secrets and sensitive information passwords, DigitalOcean tokens, and GitHub tokens.
Conclusion
With these steps, you've created a basic CI/CD pipeline using CTO.ai and Docker. This setup automates the build and test process, making your software delivery efficient.
Comments