Configuring Your CI/CD Pipeline

Set up microservice discovery in your CI/CD pipeline using a manifest file and a Python script.

Overview

Implementing microservice discovery within your Continuous Integration and Continuous Deployment (CI/CD) pipeline allows your system to automatically detect and integrate any changes made to your microservices. This automated process ensures that your microservices are consistently updated and accurately represented within your system.

Establishing a CI/CD workflow within your repository is a key step in automating the discovery and update process of your microservices. This workflow reduces manual intervention and minimizes potential errors, resulting in a more reliable and efficient system.

Although it's possible to register microservices through API requests in an environment without a CI/CD pipeline, we recommend following the CI/CD approach. This recommendation stems from the need to maintain up-to-date data. In this setup, your manifest file serves as the source of truth, and any changes to it automatically reflect in your microservices. This approach simplifies the microservice discovery process and enhances the accuracy and consistency of your microservice fact sheets, improving overall system reliability and performance.

This guide details how to set up microservice discovery in the CI/CD pipeline using a manifest file and a Python script.

Prerequisites

Prepare the following:

  • YAML manifest file
  • Relevant Python script

To learn how to create a YAML file and a Python script, see Microservice Discovery in Your CI/CD Pipeline.

To view the manifest file and schema, refer to Manifest File and Schema.

Configuration

This section details how to set up microservice discovery in the CI/CD pipeline for specific Git providers.

The pipeline in this guide includes the following steps:

  1. Checking out your code.
  2. Setting up Python.
  3. Installing the necessary Python dependencies.
  4. Invoking the SAP LeanIX service discovery Python helper.

Azure CI/CD Discovery

The Azure pipeline outlined here automatically updates your microservices on each push to the main branch, ensuring your microservice fact sheets remain current.

To set up this pipeline, create a new azure-pipelines.yml file in your repository root. The following YAML script outlines the pipeline:

trigger:
- main

pool:
  vmImage: 'ubuntu-latest'

steps:
- task: UsePythonVersion@0
  inputs:
    versionSpec: '3.12'
    addToPath: true

- script: |
    python -m pip install --upgrade pip
    pip install requests pyyaml
  displayName: 'Install dependencies'

- script: python leanix_service_discovery.py
  displayName: 'Invoke Manifest Parser'

Bitbucket CI/CD Discovery

The Bitbucket pipeline outlined here automatically updates your microservices on each push to the main branch, ensuring your microservice fact sheets remain current.

To set up this pipeline, create a new bitbucket-pipelines.yml file in your repository root. The following YAML script outlines the pipeline:

pipelines:
  default:
    - step:
        name: Update Microservice
        image: python:3.12
        script:
          - pip install --upgrade pip
          - pip install requests pyyaml
          - python leanix_service_discovery.py

GitHub CI/CD Discovery

The GitHub pipeline outlined here automatically updates your microservices on each push or pull request to the main branch, ensuring your microservice fact sheets remain current.

To set up this workflow, create a new GitHub workflow in your repository under .github/workflows. For instructions, refer to the GitHub documentation.

The following YAML script outlines the workflow:

name: Microservice Workflow
on:
  pull_request:
    types:
      - closed
    branches: [main]
env:
  LEANIX_API_TOKEN: ${{ secrets.LEANIX_API_TOKEN }}
  LEANIX_SUBDOMAIN: ${{ vars.LEANIX_SUBDOMAIN }}

jobs:
  update_microservice:
    runs-on: ubuntu-latest
    env:
      REPOSITORY_URL: ${{ github.repositoryUrl }}
    steps:
      - name: Checkout code
        uses: actions/checkout@v2
      - name: Set up Python
        uses: actions/setup-python@v2
        with:
          python-version: "3.12"
      - name: Install Python dependencies
        run: |
          python -m pip install --upgrade pip
          pip install requests pyyaml
      - name: Invoke Manifest Parser
        run: python leanix_service_discovery.py

GitLab CI/CD Discovery

The GitLab CI/CD pipeline outlined here automatically updates your microservices on each push or merge request to the main branch, ensuring your microservice fact sheets remain current.

To set up this pipeline, create or update your .gitlab-ci.yml file in your repository root. The following YAML script outlines the pipeline:

stages:
  - update_microservice

update_microservice:
  image: python:3.12
  script:
    - pip install --upgrade pip
    - pip install requests pyyaml
    - python leanix_service_discovery.py
  only:
    - main