Component spec

The basic spec for a Dapr component

Dapr defines and registers components using a resource specifications. All components are defined as a resource and can be applied to any hosting environment where Dapr is running, not just Kubernetes.

Typically, components are restricted to a particular namepsace and restricted access through scopes to any particular set of applications. The namespace is either explicit on the component manifest itself, or set by the API server, which derives the namespace through context with applying to Kubernetes.

Note

The exception to this rule is in self-hosted mode, where daprd ingests component resources when the namespace field is omitted. However, the security profile is mute, as daprd has access to the manifest anyway, unlike in Kubernetes.

Format

  1. apiVersion: dapr.io/v1alpha1
  2. kind: Component
  3. auth:
  4. secretstore: <REPLACE-WITH-SECRET-STORE-NAME>
  5. metadata:
  6. name: <REPLACE-WITH-COMPONENT-NAME>
  7. namespace: <REPLACE-WITH-COMPONENT-NAMESPACE>
  8. spec:
  9. type: <REPLACE-WITH-COMPONENT-TYPE>
  10. version: v1
  11. initTimeout: <REPLACE-WITH-TIMEOUT-DURATION>
  12. ignoreErrors: <REPLACE-WITH-BOOLEAN>
  13. metadata:
  14. - name: <REPLACE-WITH-METADATA-NAME>
  15. value: <REPLACE-WITH-METADATA-VALUE>
  16. scopes:
  17. - <REPLACE-WITH-APPID>
  18. - <REPLACE-WITH-APPID>

Spec fields

FieldRequiredDetailsExample
apiVersionYThe version of the Dapr (and Kubernetes if applicable) API you are callingdapr.io/v1alpha1
kindYThe type of resource. For components is must always be ComponentComponent
authNThe name of a secret store where secretKeyRef in the metadata lookup the name of secrets used in the componentSee How-to: Reference secrets in components
scopesNThe applications the component is limited to, specified by their app IDsorder-processor, checkout
metadata-Information about the component registration
metadata.nameYThe name of the componentprod-statestore
metadata.namespaceNThe namespace for the component for hosting environments with namespacesmyapp-namespace
spec-Detailed information on the component resource
spec.typeYThe type of the componentstate.redis
spec.versionYThe version of the componentv1
spec.initTimeoutNThe timeout duration for the initialization of the component. Default is 5s5m, 1h, 20s
spec.ignoreErrorsNTells the Dapr sidecar to continue initialization if the component fails to load. Default is falsefalse
spec.metadata-A key/value pair of component specific configuration. See your component definition for fields
spec.metadata.nameYThe name of the component-specific property and its value- name: secretsFile
value: secrets.json

Templated metadata values

Metadata values can contain template tags that are resolved on Dapr sidecar startup. The table below shows the current templating tags that can be used in components.

TagDetailsExample use case
{uuid}Randomly generated UUIDv4When you need a unique identifier in self-hosted mode; for example, multiple application instances consuming a shared MQTT subscription
{podName}Name of the pod containing the Dapr sidecarUse to have a persisted behavior, where the ConsumerID does not change on restart when using StatefulSets in Kubernetes
{namespace}Namespace where the Dapr sidecar resides combined with its appIdUsing a shared clientId when multiple application instances consume a Kafka topic in Kubernetes
{appID}The configured appID of the resource containing the Dapr sidecarHaving a shared clientId when multiple application instances consumer a Kafka topic in self-hosted mode

Below is an example of using the {uuid} tag in an MQTT pubsub component. Note that multiple template tags can be used in a single metadata value.

  1. apiVersion: dapr.io/v1alpha1
  2. kind: Component
  3. metadata:
  4. name: messagebus
  5. spec:
  6. type: pubsub.mqtt3
  7. version: v1
  8. metadata:
  9. - name: consumerID
  10. value: "{uuid}"
  11. - name: url
  12. value: "tcp://admin:public@localhost:1883"
  13. - name: qos
  14. value: 1
  15. - name: retain
  16. value: "false"
  17. - name: cleanSession
  18. value: "false"

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