Setup Self Hosted Linux Agent in Azure DevOps

Let us learn how to create and configure a Self-Hosted Agent in Azure DevOps (ADO).

What is an Agent?

An agent is computing infrastructure with installed agent software that runs one job at a time.

To build your code or deploy your software using Azure Pipelines, you need at least one agent. As you add more code and people, you’ll eventually need more.

When your pipeline runs, the system begins one or more jobs. 

In Azure pipelines, there are two types of build agents:

  1. Microsoft-hosted agents – This is a service totally managed by Microsoft and it’s cleared on every execution of the pipeline (on each pipeline execution, you have a fresh new environment).
  2. Self-hosted agents – This is a service that you can to set up and manage by yourself. This can be a custom virtual machine on Azure or a custom on-premise machine inside your infrastructure. In a self-hosted agent, you can install all the software you need for your builds, and this is persisted on every pipeline execution. A self-hosted agent can be on Windows, Linux, macOS, or in a Docker container.

Pre-requisites:

  • Microsoft account setup
  • Azure account and subscription setup
  • Create a VM(Ubuntu 18.0.4) in Azure Cloud
  • Create Personal Access Token in Azure DevOps

How to configure Self-hosted build agent?

1. Go to Azure DevOps dashboard – https://dev.azure.com/

2. Select your project dashboard

3. Go to your project settings

4. Click on Agent pools

Create a new Agent pool name

Enter name as Ubuntu18-VM-Pool or any name

Make sure you select Grant access permission to all pipelines

click on Ubuntu18-VM-Pool, Agents, New agent

Click on Linux

Note down the steps to configure Linux build agent.

Login to your Azure VM now.

Step #1 – Create the Agent

mkdir myagent && cd myagent

Step #2 – Download the agent

wget https://vstsagentpackage.azureedge.net/agent/2.214.1/vsts-agent-linux-x64-2.214.1.tar.gz

Step #3 – Configure the Agent

tar zxvf vsts-agent-linux-x64-2.214.1.tar.gz

List the files in the directory after extracting.

ls -al


Step #4:

Run the below command:

./config.sh

Accept the Team Explorer Everywhere license agreement now?

Type Y and enter

Step #5:

Enter server URL >
https://dev.azure.com/yourorganization

Step #6:

Enter authentication type (press enter for PAT) > PAT

Step #7:

Enter personal access token, generated from this step

Step #8:

Enter Agent pool

Give some name

Step #9:

Enter Agent name –> myBuildAgent_1

Step #10:

Enter work folder > enter

that’s it agent is successfully configured.

Configure the Agent to run as a Service

sudo ./svc.sh install &

Execute now to run as a service

./runsvc.sh &

Check the status of build Agent

Click on Ubuntu-18-VM pool name

Click on Agents

This confirms that Build agent is successfully configured in Azure DevOps and is available to run builds.

Steps for removing Agent from the agent pool

Remove the service first

sudo ./svc.sh uninstall

./config.sh remove

To Perform Java related builds on this Agent, make sure you install Java and Maven on this VM.

Install Java 11

sudo apt-get install default-jdk -y

Maven Installation
Maven is a popular build tool used for building Java applications. You can install Maven by executing below command:

sudo apt update && sudo apt install maven -y

Check if Maven got installed

mvn –version