Skip to main content

Azure Pipelines–Variable groups

I'm currently migrating an existing CI/CD pipeline build in Azure DevOps from the ‘classic’ build approach to YAML templates.

One of the building blocks you can use in Azure Pipelines are variable groups. Variable groups allow you to create and store values and secrets that can be used in multiple pipelines.

Create a variable group

To create a variable group, go to your Azure DevOps project. Open the Pipelines section from the left menu and click on Library.

Here you can click on + Variable Group to create a new variable group.

Enter a name and a description for the group.

Now you can start adding any variable you want by clicking on the + Add.

Using a variable group inside your YAML pipeline

Using a variable group inside a YAML pipeline, is quite easy. You just need to add a reference to the group inside the variable section:

It is still possible to include other variables as well by using the name/value syntax:

Scoping a variable group to a stage

One of the things you can do with the ‘classic’ release pipeline, is linking a variable group to a stage in a release pipeline. By doing that the variables from the variable group get scoped to these stages and aren't accessible in the other stages of the same release.

In the YAML pipeline, you can achieve something similar by setting the variable group at the stage level:

 

More information: https://learn.microsoft.com/en-us/azure/devops/pipelines/library/variable-groups?view=azure-devops&tabs=yaml

Popular posts from this blog

.NET 8–Keyed/Named Services

A feature that a lot of IoC container libraries support but that was missing in the default DI container provided by Microsoft is the support for Keyed or Named Services. This feature allows you to register the same type multiple times using different names, allowing you to resolve a specific instance based on the circumstances. Although there is some controversy if supporting this feature is a good idea or not, it certainly can be handy. To support this feature a new interface IKeyedServiceProvider got introduced in .NET 8 providing 2 new methods on our ServiceProvider instance: object? GetKeyedService(Type serviceType, object? serviceKey); object GetRequiredKeyedService(Type serviceType, object? serviceKey); To use it, we need to register our service using one of the new extension methods: Resolving the service can be done either through the FromKeyedServices attribute: or by injecting the IKeyedServiceProvider interface and calling the GetRequiredKeyedServic...

Azure DevOps/ GitHub emoji

I’m really bad at remembering emoji’s. So here is cheat sheet with all emoji’s that can be used in tools that support the github emoji markdown markup: All credits go to rcaviers who created this list.

Kubernetes–Limit your environmental impact

Reducing the carbon footprint and CO2 emission of our (cloud) workloads, is a responsibility of all of us. If you are running a Kubernetes cluster, have a look at Kube-Green . kube-green is a simple Kubernetes operator that automatically shuts down (some of) your pods when you don't need them. A single pod produces about 11 Kg CO2eq per year( here the calculation). Reason enough to give it a try! Installing kube-green in your cluster The easiest way to install the operator in your cluster is through kubectl. We first need to install a cert-manager: kubectl apply -f https://github.com/cert-manager/cert-manager/releases/download/v1.14.5/cert-manager.yaml Remark: Wait a minute before you continue as it can take some time before the cert-manager is up & running inside your cluster. Now we can install the kube-green operator: kubectl apply -f https://github.com/kube-green/kube-green/releases/latest/download/kube-green.yaml Now in the namespace where we want t...