Central (on-prem) Install

In this simple guide, we’ll go over the basic steps required to move beyond local deployment and get Digma up and running in a Kubernetes cluster that multiple people can connect to.

Understanding the Deployment Architecture

Digma is deployed into the K8s cluster into its own namespace. Depending on your application deployment architecture you may want to deploy Digma with different parameters to enable the right connectivity.

You should pay attention to the following regarding the deployment architecture:

  • Collector-API – This architecture assumes that the application can send observability data to the IP/DNS of this endpoint. You may need to configure your setup to allow this traffic. You may also choose to expose it as a public IP in your deployment (see below under Cloud Deployment)

  • Analytics-API – This endpoint needs to be accessible to the IDE plugin. If you are deploying Digma into your internal network and use a VPN to access that IP you can choose not to expose this service as a public IP (see below under Cloud Deployment).

  • Jaeger – Digma bundles its own Jaeger service that aggregates sample traces for various insights, performance metrics, and exceptions. If you do not wish to expose this endpoint or prefer to configure your APM as the trace source, you can choose to disable this endpoint. Digma does offer enhancements over Jaeger such as a two-way mapping between the code and the trace.

Deploying the Digma backend

Prerequisites:

The recommended way to install Digma in your org is using our Helm chart.

Step 1: Add the Digma Helm repo

helm repo add digma https://digma-ai.github.io/helm-chart/
helm repo update

Step 2: Deploy Digma using Helm

You’ll need to provide the following parameters in the example below:

  • DIGMA_LICENSE (string) - If you've signed up for a free Digma account you should have received a Digma license to use. You can use this link to sign up: Create a free Digma Account

helm install digma digma/digma --set digma.licenseKey=[DIGMA_LICENSE] --namespace digma --create-namespace

Other optional parameters:

  • --set size (small | medium | large) - The cluster can be deployed in multiple scales, depending on the expected load. The default sizing is medium. If you select a size that is too small to handle the number of spans per second, you'll get a message from the Digma plugin prompting you to upgrade to a bigger size. Please consult the Resource Requirements page for allocating the relevant nodes.

  • --set digmaAnalytics.accesstoken(any string): This is a unique key you’ll need to provide any IDE that connects to this Digma instance, you can choose any token you'd like.

  • --set embeddedJaeger.enabled (true/false) – Setting this to False will not expose the port for the Jaeger instance included with Digma. If you’re using your own APM and want to link to that instead, you can leave that at the default value (false)

  • --set imagePullSecretName=my-secret will configure the specs in the helm chart to use the provided secret when pulling images from DockerHub to avoid pull rate limits.

Cloud Deployment

In order to ease the process of setting up cloud-specific resources such as load balancers, we've created some value files you can use to set up the intended networking.

AWS

Digma can be set up to use either a public or an internal DNS. You should choose the option that better suits your requirements.

Deploying an EKS cluster

If you'd like to create an EKS cluster from scratch, we created a simple Terraform file to help automate that process. You can find it in this repo.

Internal DNS

Use the below values file to set up your AWS deployment using internal load balancers.

helm install digma digma/digma --values https://raw.githubusercontent.com/digma-ai/helm-chart/main/src/digma-configs/aws-internal.yaml --set digma.licenseKey=[DIGMA_LICENSE] --namespace digma --create-namespace

External DNS

Use the below values file to set up your AWS deployment using external facing load balancers.

helm install digma digma/digma --values https://raw.githubusercontent.com/digma-ai/helm-chart/main/src/digma-configs/aws-internet.yaml --set digma.licenseKey=[DIGMA_LICENSE] --namespace digma --create-namespace
GKE

Internal passthrough

Using this value file will set up the GKE deployment using an internal load balancer service

helm install digma digma/digma --values https://raw.githubusercontent.com/digma-ai/helm-chart/main/src/digma-configs/gcp-internal.yaml --set digma.licenseKey=[DIGMA_LICENSE] --namespace digma --create-namespace

External DNS

If you need to create an external internet-facing load balancer service instead, use the following value file:

helm install digma digma/digma --values https://raw.githubusercontent.com/digma-ai/helm-chart/main/src/digma-configs/gcp-internet.yaml --set digma.licenseKey=[DIGMA_LICENSE] --namespace digma --create-namespace

Using Ingresses instead of Load Balancers for the Digma services

In order to use Ingresses instead of load balancers, you need the following prerequistes to be set up:

To install Digma using Ingresses first disable load balancers:

helm install digma digma/digma --set digmaAnalytics.loadbalancer=false --set digmaCollectorApi.loadbalancer=false --set embeddedJaeger.loadbalancer=false --set digma.licenseKey=[DIGMA_LICENSE] --namespace digma --create-namespace 

You can then set the Ingress resources in a separate YAML file. Here is an example:

https://github.com/digma-ai/helm-chart/blob/main/examples/digma-with-nginx/templates/ingress.yaml

Step 3: Validating the deployment

To check everything is working properly we can check the pod status and make sure they are all in the ‘Running’ state:

kubectl get pods -n digma

For example, this is the expected output:

Step 4: Get the IP/DNS value for the Digma deployment

Run the following command to get the address assigned to the Collector, Plugin-API, and Jaeger endpoints (if enabled). You’ll need these to complete the setup. Note that external load balancers for public IPs may take additional time to set up the address.

kubectl get services --namespace digma

Depending on your setup type get the public or internal IP for the following services:

  • Collector-API: digma-collector-api or digma-collector-api-service-lb if you have selected to expose this service externally

  • Analytics-API: digma-analytics-service-lb

  • Jaeger: digma-embedded-jaeger-lb

Capture these addresses as you’ll need them later to setup your IDE plugin.

Step 5: Final validation

You can try calling the following API to validate connectivity and ensure Digma is up and running. You’ll need to use the ANALYTICS-API address you’ve captured in the above step. If you've set an access token, you need to provide it as well as a header for the request, as seen in the example below:

curl -k -sS -w "%{http_code}" --location "https://<ANALYTICS-API]/about"

If you are using the optional digmaAnalytics.accesstoken parameter, add the following argument: -H 'Digma-Access-Token: Token <ACCESS_TOKEN> to the curl command.

If you received a non-error response back you’re good to go for the next step!

Connecting your IDE to the Org Digma deployment

Once Digma is up and running you can now set your IDE plugin to connect to it. To do that, open the plugin settings (Go to IntelliJ IDEA -> Settings/Preferences and search for ‘Digma’)

  • Set the Digma API URL parameter using the ANALYTICS-API value you’ve captured previously (By default this should be prefixed as ‘https’ and use port 5051)

  • Set the Runtime observability backend URL parameter using the ‘COLLECTOR-API’ value you’ve captured previously

  • Set the Api token parameter using the string value you used as an access token if you've provided one during setup.

  • Set the Jaeger Query URL(if this option was enabled) using the JAEGER address you’ve captured previously.

Click Apply/OK to enable the changes and check that the Digma UI is not showing any connection errors.

Last updated