Debug daprd on Kubernetes

How to debug the Dapr sidecar (daprd) on your Kubernetes cluster

Overview

Sometimes it is necessary to understand what’s going on in the Dapr sidecar (daprd), which runs as a sidecar next to your application, especially when you diagnose your Dapr application and wonder if there’s something wrong in Dapr itself. Additionally, you may be developing a new feature for Dapr on Kubernetes and want to debug your code.

This guide covers how to use built-in Dapr debugging to debug the Dapr sidecar in your Kubernetes pods. To learn how to view logs and troubleshoot Dapr in Kubernetes, see the Configure and view Dapr logs guide

Pre-requisites

  • Refer to this guide to learn how to deploy Dapr to your Kubernetes cluster.
  • Follow this guide to build the Dapr debugging binaries you will be deploying in the next step.

Initialize Dapr in debug mode

If Dapr has already been installed in your Kubernetes cluster, uninstall it first:

  1. dapr uninstall -k

We will use ‘helm’ to install Dapr debugging binaries. For more information refer to Install with Helm.

First configure a values file named values.yml with these options:

  1. global:
  2. registry: docker.io/<your docker.io id>
  3. tag: "dev-linux-amd64"

Then step into ‘dapr’ directory from your cloned dapr/dapr repository and execute the following command:

  1. helm install dapr charts/dapr --namespace dapr-system --values values.yml --wait

To enable debug mode for daprd, you need to put an extra annotation dapr.io/enable-debug in your application’s deployment file. Let’s use quickstarts/hello-kubernetes as an example. Modify ‘deploy/node.yaml’ like below:

  1. diff --git a/hello-kubernetes/deploy/node.yaml b/hello-kubernetes/deploy/node.yaml
  2. index 23185a6..6cdb0ae 100644
  3. --- a/hello-kubernetes/deploy/node.yaml
  4. +++ b/hello-kubernetes/deploy/node.yaml
  5. @@ -33,6 +33,7 @@ spec:
  6. dapr.io/enabled: "true"
  7. dapr.io/app-id: "nodeapp"
  8. dapr.io/app-port: "3000"
  9. + dapr.io/enable-debug: "true"
  10. spec:
  11. containers:
  12. - name: node

The annotation dapr.io/enable-debug will hint Dapr injector to inject Dapr sidecar into the debug mode. You can also specify the debug port with annotation dapr.io/debug-port, otherwise the default port will be “40000”.

Deploy the application with the following command. For the complete guide refer to the Dapr Kubernetes Quickstart:

  1. kubectl apply -f ./deploy/node.yaml

Figure out the target application’s pod name with the following command:

  1. $ kubectl get pods
  2. NAME READY STATUS RESTARTS AGE
  3. nodeapp-78866448f5-pqdtr 1/2 Running 0 14s

Then use kubectl’s port-forward command to expose the internal debug port to the external IDE:

  1. $ kubectl port-forward nodeapp-78866448f5-pqdtr 40000:40000
  2. Forwarding from 127.0.0.1:40000 -> 40000
  3. Forwarding from [::1]:40000 -> 40000

All done. Now you can point to port 40000 and start a remote debug session to daprd from your favorite IDE.

Commonly used kubectl commands

Use the following common kubectl commands when debugging daprd and applications running on Kubernetes.

Get all pods, events, and services:

  1. kubectl get all
  2. kubectl get all --n <namespace>
  3. kubectl get all --all-namespaces

Get each specifically:

  1. kubectl get pods
  1. kubectl get events --n <namespace>
  2. kubectl get events --sort-by=.metadata.creationTimestamp --n <namespace>
  1. kubectl get services

Check logs:

  1. kubectl logs <podId> daprd
  2. kubectl logs <podId> <myAppContainerName>
  3. kuebctl logs <deploymentId> daprd
  4. kubectl logs <deploymentId> <myAppContainerName>
  1. kubectl describe pod <podId>
  2. kubectl describe deploy <deployId>
  3. kubectl describe replicaset <replicasetId>

Restart a pod by running the following command:

  1. kubectl delete pod <podId>

This causes the replicaset controller to restart the pod after the delete.

Watch the demo

See the presentation on troubleshooting Dapr on Kubernetes in the Dapr Community Call #36.

Last modified October 11, 2024: Fixed typo (#4389) (fe17926)