Automating repetitive processes like building, testing, and deploying applications can significantly enhance productivity and reduce human errors. This is where Continuous Integration (CI) and Continuous Delivery (CD) come into play.
For Node.js applications, Azure DevOps provides a powerful platform to automate these processes. It allows developers to focus more on writing code than manually handling deployments.
In this guide, you will learn configuring a CI/CD pipeline for a Node.js application using Azure DevOps. By the end of this guide, you’ll be able to set up a pipeline that automatically builds, tests, and deploys your Node.js application to Azure App Service whenever you make changes to the code.
Before starting, ensure you have the following:
- Azure DevOps account: If you don't have one, create an account at [Azure DevOps](https://dev.azure.com).
- Azure Subscription: You can sign up for a free Azure account if you don't have one.
- Node.js: Install Node.js from the official [Node.js website](https://nodejs.org).
- Git: Ensure Git is installed and configured.
- Visual Studio Code: Install VS Code, and optionally install the Azure App Service extension.
First, we’ll create a basic Node.js application using Express.js and initialize a Git repository for version control.
Bash
mkdir node-cicd-app
cd node-cicd-app
npm init -y
npm install express --save
Create an `app.js` file with the following content:
Javascript
const express = require('express');
const app = express();
app.get('/', (req, res) => {
res.send('Hello from CI/CD Pipeline!');
});
app.listen(3000, () => {
console.log('App listening on port 3000');
});
Bash
git init
git add .
git commit -m "Initial commit"
Now, let’s configure Azure DevOps to manage the CI/CD pipeline.
- Navigate to [Azure DevOps](https://dev.azure.com), create a new organization (if needed), and click New Project.
- Name your project (e.g., `node-cicd-app`) and set it to private.
- In the Azure DevOps project, go to Repos > Files and copy the Git commands to push your local repository.
- Run the following commands in your project’s folder:
Bash
git remote add origin <Azure Repo URL>
git push -u origin master
Next, we’ll create a build pipeline that automatically builds and tests the code every time it’s pushed to the repository.
- Go to Pipelines > New Pipeline
- Choose Azure Repos Git as the source, then select your repository.
- Select Classic Editor to set up the pipeline visually.
- Select Empty Job.
- Name the pipeline (`Node.js Build Pipeline`) and choose an agent pool based on your environment (e.g., Hosted Ubuntu 18.04 for Linux or Hosted Windows 2019 for Windows).
- Node.js Tool Installer: Use this task to specify the Node.js version for the pipeline.
- npm Task:
- Command: `install`
- Working directory: `${Build.SourcesDirectory}`
- npm Task:
- Command: `run build` (if you have a build script, otherwise skip).
- npm Task (Optional):
- Command: `run test` (if you have unit tests).
- Add an Archive Files task to compress the output folder into a `.zip` file for faster deployment.
- Specify the folder to archive (e.g., `public/`, `dist/`, or the relevant output folder).
- Add a Publish Build Artifacts task to store the build outputs.
- Artifact name: `drop`
- Path to publish: `${Build.ArtifactStagingDirectory}`
- In the pipeline settings, enable Continuous Integration to trigger the pipeline whenever code is pushed to the repository.
- Click Save and Queue to run the pipeline.
With the build pipeline in place, we’ll now configure a release pipeline to deploy the application to Azure App Service.
- In the [Azure Portal](https://portal.azure.com), create an App Service (select Node.js as the runtime stack).
- In Azure DevOps, go to Pipelines > Releases and create a new release pipeline.
- Select Empty Job and rename the stage to Dev Deployment (or similar).
- Click Add an Artifact, select the build pipeline, and choose the latest version.
- In the Tasks tab, add an Azure App Service Deploy task.
- Configure the task:
- Select your Azure subscription.
- Choose the App Service created in Azure.
- Set the package or folder path to `$(System.DefaultWorkingDirectory)/**/*.zip` (the `.zip` file generated in the build pipeline).
- In the Triggers tab, enable Continuous Deployment so that every successful build automatically triggers a deployment to Azure.
5. Run the Release Pipeline:
- Save the release pipeline and create a new release to deploy the application to Azure App Service.
Once the release pipeline has deployed your application, test it by visiting the App Service URL:
https://<your-app-service>azurewebsites.net
You should see the message: "Hello from CI/CD Pipeline!"
For production environments, it’s recommended to use deployment slots for zero-downtime releases.
- In the Azure Portal, navigate to your App Service and create a staging slot.
- In your release pipeline, add a task to deploy to the staging slot.
- After deployment, add a task to swap slots so that the app is deployed to the production slot with no downtime.
Pre-built Node.js Deployment Option for CI/CD Setup
Azure DevOps offers a pre-built Node.js deployment option that automatically configures all the necessary steps for your azure devops pipeline without requiring manual setup. With this feature, you can instantly generate a complete pipeline for your Node.js application, streamlining the deployment process.
By following this guide, you’ve set up a complete CI/CD pipeline for your Node.js application using Azure DevOps. This pipeline automates code building, testing, and deployment, ensuring consistent and reliable delivery of your application.
For more advanced workflows, explore multi-stage YAML pipelines and infrastructure as code (IaC) using tools like Terraform or Bicep.