Azure Deployment

Prerequisites

  1. On a workstation with access to your Azure cloud, install the following tools if you don’t already have them available:

  2. Create a new AKS cluster, or choose an existing cluster to install Violet into. The cluster must have at least 2 nodes with at least 8GB of RAM. Standard DS2_V3 or bigger is a good choice. No other settings beyond the defaults are necessary. The recommended node has the minimum following properties:

    1. architecture: amd64

    2. osImage: Ubuntu 22.04.5 LTS or greater

  3. Connect your workstation kubectl to the new AKS cluster. Substitute <resource-group-name> and <aks-cluster-name> with your new AKS cluster in the following:

az login --scope https://management.core.windows.net//.default
az aks get-credentials --resource-group <resource-group-name> --name <aks-cluster-name>

Violet Helm Chart Installation

  1. Add the Violet AWS Credentials to your current terminal environment. These values are provided by Violet Labs and are specific to your installation:

export AWS_ACCESS_KEY_ID=<your-access-key>
export AWS_SECRET_ACCESS_KEY=<your-access-key-secret>
export AWS_DEFAULT_REGION=us-west-1 
  1. Create a new file violet-values.yml containing your AWS credentials and specific application configuration:

Deploying or Updating Version-Locked Violet [OPTIONAL]

If you would like to lock the version of Violet that you are using and not automatically pull the latest version, add the following entry to your violet-values.yml file:

image:
  versionTag: # use correct version tag to lock a version and not always pull latest. Provided by Violet for initial deployment.

Violet changelog (& version tags) can be found here VioletLabs changelog | Productlane

If you are deploying Violet in this environment for the first time, continue to step 3.

If you have already deployed Violet and are just locking the version or updating to a specific version of Violet, enter that versionTag in the violet-values.yml file and then skip to step 8.

  1. Create a new kubernetes namespace for the Violet installation:

  1. Install the nginx ingress controller chart which allows AKS to set up a load balancer to route traffic from the internet to the new Violet deployment:

  1. Install the mezmo logging agent. This streams logs from your cluster to the violet team for troubleshooting and monitoring assistance.

  1. Install the external-secrets chart. This is used to load some customer-specific secrets from AWS into the Violet deployment:

  1. Create a secret that allows Kubernetes to access the Violet Helm Chart repository:

  1. Login to the Helm repository:

  1. Install the Violet Helm Chart:

Note that it may take up to 5 minutes to run the database provisioning scripts. You can check the status of the deployment by looking at the pods:

After installation is complete the helm chart will print our some information and commands including the URL to access your new deployment, how to get the IP Address that the deployment is served at (for setting up DNS rules) and how to obtain the auto-generated password for the [email protected] account.

Last updated

Was this helpful?