1.8 KiB
Setup etcd
Locally
You can run etcd locally using Docker:
docker run -d --name etcd bitnami/etcd
You can then interact with the server using localhost:2379
.
Kubernetes
The easiest way to install etcd on Kubernetes is by using the Helm chart:
helm repo add incubator http://storage.googleapis.com/kubernetes-charts-incubator
helm install etcd incubator/etcd
This will install etcd into the default
namespace.
To interact with etcd, find the service with: kubectl get svc etcd-etcd
.
For example, if installing using the example above, the etcd host address would be:
etcd-etcd.default.svc.cluster.local:2379
Create a Dapr component
The next step is to create a Dapr component for etcd.
Create the following YAML file named etcd.yaml
:
apiVersion: dapr.io/v1alpha1
kind: Component
metadata:
name: <NAME>
namespace: <NAMESPACE>
spec:
type: state.etcd
metadata:
- name: endpoints
value: <REPLACE-WITH-COMMA-DELIMITED-ENDPOINTS> # Required. Example: "etcd-etcd.default.svc.cluster.local:2379"
- name: dialTimeout
value: <REPLACE-WITH-DIAL-TIMEOUT> # Required. Example: "5s"
- name: operationTimeout
value: <REPLACE-WITH-OPERATION-TIMEOUT> # Optional. default: "10S"
The above example uses secrets as plain strings. It is recommended to use a secret store for the secrets as described here
Apply the configuration
In Kubernetes
To apply the etcd state store to Kubernetes, use the kubectl
CLI:
kubectl apply -f etcd.yaml
Running locally
To run locally, create a components
dir containing the YAML file and provide the path to the dapr run
command with the flag --components-path
.