dapr-pluggable-components-operator

command module
v0.1.0-beta.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 26, 2022 License: Apache-2.0 Imports: 11 Imported by: 0

README

Dapr Pluggable Components Operator

A custom Kubernetes Pod Controller for automatically inject Dapr pluggable components in your pods.

TLDR

Step 1: Install the Operator

Step 2: Annotate your deployments

Your deployment annotations tells if the pluggable components operator should take your pod and inject the containers or not. This is achieved by annotating them with components.dapr.io/enabled: "true". That way your deployments the operator will consider your deployment eligible to inject component containers.

apiVersion: apps/v1
kind: Deployment
metadata:
  name: app
  labels:
    app: app
spec:
  replicas: 1
  selector:
    matchLabels:
      app: app
  template:
    metadata:
      labels:
        app: app
      annotations:
        components.dapr.io/enabled: "true" # required
        dapr.io/app-id: "my-app"
        dapr.io/enabled: "true"
    spec:
      containers:
        - name: "my-app"
          image: "MY_APP_IMAGE"

Step 3: Annotate your components

Your component is the entrypoint for defining container images for pluggable components, you must set the components.dapr.io/container-image annotation pointing to the desired image that should be used for the pluggable component container.

apiVersion: dapr.io/v1alpha1
kind: Component
metadata:
  name: redis-pluggable
  annotations:
    components.dapr.io/container-image: "DOCKER_REPO/state-redis:latest" # required
spec:
  type: state.redis-pluggable
  initTimeout: 1m
  version: v1
  metadata:
    - name: redisHost
      value: redis-svc.default.svc.cluster.local:6379
    - name: redisPassword
      value: ""
    - name: processingTimeout
      value: 1m
    - name: redeliverInterval
      value: 10s
    - name: idleCheckFrequency
      value: 5s
    - name: readTimeout
      value: 5s

Optionally you can mount volumes and add env variables into the containers by using the components.dapr.io/container-volume-mounts and components.dapr.io/container-env annotations and use ; to separate the volume name and its path and , to separate volume mount.

apiVersion: dapr.io/v1alpha1
kind: Component
metadata:
  name: redis-pluggable
  annotations:
    components.dapr.io/container-image: "DOCKER_REPO/state-redis:latest" # required
    components.dapr.io/container-volume-mounts: "volume-name;/volume-path,volume-name-2;/volume-path-2" # optional
    components.dapr.io/container-env: "env-var;env-var-value,env-var-2;env-var-value-2"
spec:
  type: state.redis-pluggable
  initTimeout: 1m
  version: v1
  metadata:
    - name: redisHost
      value: redis-svc.default.svc.cluster.local:6379
    - name: redisPassword
      value: ""
    - name: processingTimeout
      value: 1m
    - name: redeliverInterval
      value: 10s
    - name: idleCheckFrequency
      value: 5s
    - name: readTimeout
      value: 5s

By default the operator creates undeclared volumes as emptyDir volumes, if you want a different volume type you should declare it by yourself in your deploments.

Contributing

Dependencies

  1. Operator-sdk

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL