Skip to content
This repository has been archived by the owner on Mar 5, 2022. It is now read-only.

Latest commit

 

History

History
151 lines (101 loc) · 7.07 KB

README.md

File metadata and controls

151 lines (101 loc) · 7.07 KB

Provision a Linux Docker VSTS agent with the AWS CLI capability

This project automates the creation of a Linux Docker VSTS agent with the AWS CLI capability.

The provisioning rely on the Azure Resource Manager.

A use case for this setup would be an ASP.NET Core codebase using VSTS as a source control, build and deployment system and having the requirement to deploy the web application to AWS Beanstalk.

.NET being a second class citizen on Beanstalk, I recommend to create Docker images so that you can take full advantage of the platform.

Prerequisites

Create:

Install:

Generate a SSH public and private key pair

You can read detailed instructions here if required but this section should be sufficient.

Create a new key

ssh-keygen -t rsa -b 2048 -f ~/.ssh/<filename-for-the-private-key> -C "<human-name-for-the-key>" -N <super-strong-passphrase>
ssh-add ~/.ssh/<filename-for-the-private-key>

Azure requires at least 2048-bit, ssh-rsa format public and private keys. This is handled by the options -t rsa -b 2048.

  • <filename-for-the-private-key>: you might end up having multiple key pairs for different purpose / environments. Choose a meaningful name.
  • <human-name-for-the-key>: will be part of the public key. It's useful to identify what a SSH public key is used for.
  • <super-strong-passphrase>: generate it randomly and store it securely. The longer the passphrase is the better.

Import existing key

  • Create a new file in the ~/.ssh/ directory with the content of the Private Key.
  • Type ssh-add ~/.ssh/<filename-for-the-private-key>.

Troubleshooting adding the key pair

If you get this error when typing ssh-add:

Could not open a connection to your authentication agent.

Run this:

eval "$(ssh-agent -s)"

Create a config file

This section is optional. It allows you to SSH into the build agent by using an alias (i.e. ssh <build-agent-alias>).

You can refer to the Azure documentation.

Retrieve the required parameters

These parameters will need to be configured in .src/parameters.json.

Admin account for Virtual Machine

  • adminUsername: favor a randomly generated name.
  • adminPublicKey:
    • ssh-keygen -y -f ~/.ssh/<filename-for-the-private-key> > ~/.ssh/<filename-for-the-private-key>.pub
    • cat <filename-for-the-private-key>.pub
    • Copy the output to the parameter value

Collect VSTS information

  • vstsUrl: base URL of your VSTS account (https://<your-account>.visualstudio.com/ for example).
  • agentName: give your agent a meaningful name (docker-linux for example).
  • agentPool: name of the the VSTS pool.
  • personalAccessToken:
  • virtualMachineName: give your Virtual Machine a meaningful name (docker-build-agent-vm for example).

Optional configurations

Depending on your requirements you can change the value of storageAccountType and diagnosticsStorageAccountType.

The build agent has been configured to use a static public IP address so that it can be whitelisted if you wish to run databases migrations from it when deploying. It also makes it easier to SSH into it.

The post deployment script needs to be publicly accessible on the internet. I'm using a Gist, if you decide to modify it you'll need to host it somewhere and modify the ./src/template.json accordingly. Warning: do not harcode any credentials in this file!

Deploy the build agent

./src/deploy.sh -s <azure-subscription-id> -r <desired-resource-group-name> -l <location>
  • azure-subscription-id: you can find your subscription id in the Azure portal, select the Subscriptions blade on the left.
  • desired-resource-group-name: give your Resource Group a meaningful name (docker-build-rg for example).

Note: the script will prompt you to sign in into Azure.

Get a cup of coffee, the script will take around 5 minutes to deploy all the required components!

Uninstall and unregister a build agent

If you don't want your build agent to remain as Offline in the Agent Pool when deleting the Virtual Machine you can uninstall and unregister the build agent.

SSH into the build agent and type:

cd myagent
./uninstall.sh

Note: you'll need to provide your PAT.

Troubleshooting the extension

If the extensions (the post deployment script contained in ./src/post-deployment-configuration.sh) fail to execute you can refer to this troubleshooting section.

TLDR:

  • ssh into the build agent
  • sudo su
  • cat /var/lib/waagent/custom-script/download/0/stderr
  • cat /var/lib/waagent/custom-script/download/0/stdout