Skip to content
Snippets Groups Projects

infra-azure-provisioning

This repository contains the infrastructure as code implementation and pipelines necessary for the required infrastructure to host OSDU on Azure.

The osdu - R3 MVP Architecture solution template is intended to provision Managed Kubernetes resources like AKS and other core OSDU cloud managed services like Cosmos, Blob Storage and Keyvault.

Cloud Resource Architecture

Architecture

Cost

Azure environment cost ballpark estimate. This is subject to change and is driven from the resource pricing tiers configured when the template is deployed.

Prerequisites

  1. Azure Subscription
  2. Terraform and Go are locally installed.
  3. Requires the use of direnv.
  4. Install the required common tools (kubectl, helm, and terraform).

Install the required tooling

This document assumes one is running a current version of Ubuntu. Windows users can install the Ubuntu Terminal from the Microsoft Store. The Ubuntu Terminal enables Linux command-line utilities, including bash, ssh, and git that will be useful for the following deployment. Note: You will need the Windows Subsystem for Linux installed to use the Ubuntu Terminal on Windows.

Currently the versions in use are Terraform 0.12.29 and GO 1.12.14.

Note: Terraform and Go are recommended to be installed using a Terraform Version Manager and a Go Version Manager

Install the Azure CLI

For information specific to your operating system, see the Azure CLI install guide. You can also use the single command install if running on a Unix based machine.

curl -sL https://aka.ms/InstallAzureCLIDeb | sudo bash

# Login to Azure CLI and ensure subscription is set to desired subscription
az login
az account set --subscription <your_subscription>

Configure and Work with an Azure Devops Project

Configure an Azure Devops Project in your Organization called osdu-mvp and set the cli command to use the organization by default.

export ADO_ORGANIZATION=<organization_name>
export ADO_PROJECT=osdu-mvp

# Ensure the CLI extension is added
az extension add --name azure-devops

# Setup a Project Space in your organization
az devops project create --name $ADO_PROJECT --organization $ADO_ORGANIZATION

# Configure the CLI Defaults to work with the organization and project
az devops configure --defaults organization=https://dev.azure.com/$ADO_ORGANIZATION project=$ADO_PROJECT

Clone the repository

It is recommended to work with this repository in a WSL Ubuntu directory structure.

git clone git@community.opengroup.org:osdu/platform/deployment-and-operations/infra-azure-provisioning.git

cd infra-azure-provisioning

Create a Flux Manifest Repository

Create an empty git repository with a name that clearly signals that the repo is used for the Flux manifests. For example k8-gitops-manifests.

Flux requires that the git repository have at least one commit. Initialize the repo with an empty commit.

export ADO_REPO=k8-gitops-manifests

# Initialize a Git Repository
(mkdir k8-gitops-manifests \
  && cd k8-gitops-manifests \
  && git init \
  && git commit --allow-empty -m "Initializing the Flux Manifest Repository")

# Create an ADO Repo
az repos create --name $ADO_REPO
export GIT_REPO=git@ssh.dev.azure.com:v3/${ADO_ORGANIZATION}/${ADO_PROJECT}/k8-gitops-manifests

# Push the Git Repository
(cd k8-gitops-manifests \
  && git remote add origin $GIT_REPO \
  && git push -u origin --all)

In order for Automated Pipelines to be able to work with this repository the following Permissions must be set in the ADO Project for All Repositories/Permissions on the user osdu-mvp Build Service.

  • Create Branch Allow
  • Contribute Allow
  • Contribute to Pull requests Allow

Provision the Common Resources

The script common_prepare.sh script is a helper script designed to help setup some of the common things that are necessary for infrastructure.

  • Ensure you are logged into the azure cli with the desired subscription set.
  • Ensure you have the access to run az ad commands.
# Execute Script
export UNIQUE=demo

./infra/common_prepare.sh $(az account show --query id -otsv) $UNIQUE

Integration Tests requires 2 Azure AD User Accounts, a tenant user and a guest user to be setup in order to use for integration testing. This activity needs to be performed by someone who has access as an AD User Admin.

  • ad-guest-email (ie: integration.test@email.com)
  • ad-guest-oid (OID of the user)
  • ad-user-email (ie: integration.test@{tenant}.onmicrosoft.com
  • ad-user-oid (OID of the user)
USER_EMAIL=""
USER_EMAIL_OID=""
GUEST_EMAIL=""
GUEST_EMAIL_OID=""

az keyvault secret set --vault-name $COMMON_VAULT --name "ad-user-email" --value $USER_EMAIL
az keyvault secret set --vault-name $COMMON_VAULT --name "ad-user-oid" --value $USER_EMAIL_OID
az keyvault secret set --vault-name $COMMON_VAULT --name "ad-guest-email" --value $GUEST_EMAIL
az keyvault secret set --vault-name $COMMON_VAULT --name "ad-guest-oid" --value $GUEST_EMAIL_OID

Istio Configuration setups a Dashboard that requires some admin credentials. Automation Pipelines uses settings out of the common keyvault for applying the values of the Istio Dashboard default credentials.

ISTIO_USERNAME=""
ISTIO_PASSWORD=""


az keyvault secret set --vault-name $COMMON_VAULT --name "istio-username" --value $(echo $ISTIO_USERNAME |base64)
az keyvault secret set --vault-name $COMMON_VAULT --name "istio-password" --value $(echo $ISTIO_PASSWORD |base64)

Local Script Output Resources

The script creates some local files to be used.

  1. .envrc_{UNIQUE} -- This is a copy of the required environment variables for the common components.
  2. .envrc -- This file is used directory by direnv and requires direnv allow to be run to access variables.
  3. ~/.ssh/osdu_{UNIQUE}/azure-aks-gitops-ssh-key -- SSH key used by flux.
  4. ~/.ssh/osdu_{UNIQUE}/azure-aks-gitops-key.pub -- SSH Public Key used by flux.
  5. ~/.ssh/osdu_{UNIQUE}/azure-aks-node-ssh-key -- SSH Key used by AKS
  6. ~/.ssh/osdu_{UNIQUE}/azure-aks-node-ssh-key.pub -- SSH Public Key used by AKS
  7. ~/.ssh/osdu_{UNIQUE}/azure-aks-node-ssh-key.passphrase -- SSH Key Passphrase used by AKS

Ensure environment variables are loaded direnv allow

Installed Azure Resources

  1. Resource Group
  2. Storage Account
  3. Key Vault
  4. A principal to be used for Terraform (Requires Grant Admin Approval)
  5. A principal to be used for the OSDU environment (Requires Grant Admin Approval)
  6. An application to be used for the OSDU environment (future)
  7. An application to be used for negative integration testing

Removal would require deletion of all AD elements osdu-mvp-{UNIQUE}-*, unlocking and deleting the resource group then purging the KV.

Azure AD Admin Consent

2 service principals have been created that need to have an AD Admin grant admin consent on.

  1. osdu-mvp-{UNIQUE}-terraform (Azure AD Application Graph - Application.ReadWrite.OwnedBy)
  2. osdu-mvp-{UNIQUE}-principal (Microsoft Graph - Directory.Read.All)

Elastic Search Setup

Infrastructure requires a bring your own Elastic Search Instance of a version of 6.8.x with a valid https endpoint and the access information must now be stored in the Common KeyVault. The recommended method of Elastic Search is to use the Elastic Cloud Managed Service from the Marketplace.

Note: Elastic Cloud Managed Service requires a Credit Card to be associated to the subscription for billing purposes.

ES_ENDPOINT=""
ES_USERNAME=""
ES_PASSWORD=""
az keyvault secret set --vault-name $COMMON_VAULT --name "elastic-endpoint-dp1-${UNIQUE}" --value $ES_ENDPOINT
az keyvault secret set --vault-name $COMMON_VAULT --name "elastic-username-dp1-${UNIQUE}" --value $ES_USERNAME
az keyvault secret set --vault-name $COMMON_VAULT --name "elastic-password-dp1-${UNIQUE}" --value $ES_PASSWORD


cat >> .envrc << EOF

# https://cloud.elastic.co
# ------------------------------------------------------------------------------------------------------
export TF_VAR_elasticsearch_endpoint="$ES_ENDPOINT"
export TF_VAR_elasticsearch_username="$ES_USERNAME"
export TF_VAR_elasticsearch_password="$ES_PASSWORD"

EOF

cp .envrc .envrc_${UNIQUE}

Configure Key Access in Manifest Repository

The public key of the azure-aks-gitops-ssh-key previously created needs to be added as a deploy key in your Azure DevOPS Project, follow these steps to add your public SSH key to your ADO environment.

# Retrieve the public key
az keyvault secret show \
  --id https://$COMMON_VAULT.vault.azure.net/secrets/azure-aks-gitops-ssh-key-pub \
  --query value \
  -otsv

Install OSDU

There are 2 methods that can be chosen to perform installation at this point in time.

  1. Manual Installation -- Typically used when the desire is to manually make modifications to the environment and have full control all updates and deployments.

  2. Pipeline Installation -- Typically used when the need is to only access the Data Platform but allow for automatic upgrades of infrastructure and services.

Manual Installation

This typically takes about 2 hours to complete.

  1. Install the Infrastructure following directions here.

  2. Setup DNS to point to the deployed infrastructure following directions here.

  3. Upload the Integration Test Data following directions here.

  4. Deploy the application helm charts following the directions here.

  5. Register your partition with the Data Partition API by following the instructions here to configure your IDE to make authenticated requests to your OSDU instance and send the API request located here (createPartition).

  6. Setup Environment Variables for IDE Development and Integration Testing following the directions here.

Automated Pipeline Installation

This typically takes about 3 hours to complete.

  1. Setup Code Mirroring following directions here.

  2. Setup Infrastructure Automation following directions here.

  3. Setup DNS to point to the deployed infrastructure following directions here.

  4. Upload the Integration Test Data following directions here.

  5. Setup Service Automation following directions here.

  6. Register your partition with the Data Partition API by following the instructions here to configure your IDE to make authenticated requests to your OSDU instance and send the API request located here (createPartition).

  7. Enable Integration Tests for the pipelines.

Developer Activities

  1. To onboard new services follow the process located here.