The documentation you are viewing is for Dapr v1.12 which is an older version of Dapr. For up-to-date documentation, see the latest version.

MongoDB

MongoDB 状态存储组件的详细信息

配置

要设置 MongoDB 状态存储,请创建一个类型为 state.mongodb 的组件。 请参阅本指南,了解如何创建和应用状态存储配置。

apiVersion: dapr.io/v1alpha1
kind: Component
metadata:
  name: <NAME>
  namespace: <NAMESPACE>
spec:
  type: state.mongodb
  version: v1
  metadata:
  - name: server
    value: <REPLACE-WITH-SERVER> # Required unless "host" field is set . Example: "server.example.com"
  - name: host
    value: <REPLACE-WITH-HOST> # Required unless "server" field is set . Example: "mongo-mongodb.default.svc.cluster.local:27017"
  - name: username
    value: <REPLACE-WITH-USERNAME> # Optional. Example: "admin"
  - name: password
    value: <REPLACE-WITH-PASSWORD> # Optional.
  - name: databaseName
    value: <REPLACE-WITH-DATABASE-NAME> # Optional. default: "daprStore"
  - name: collectionName
    value: <REPLACE-WITH-COLLECTION-NAME> # Optional. default: "daprCollection"
  - name: writeconcern
    value: <REPLACE-WITH-WRITE-CONCERN> # Optional.
  - name: readconcern
    value: <REPLACE-WITH-READ-CONCERN> # Optional.
  - name: operationTimeout
    value: <REPLACE-WITH-OPERATION-TIMEOUT> # Optional. default: "5s"

如果您想要使用 MongoDB 作为 Actor 存储,请在 yaml 上附上以下内容。

  - name: actorStateStore
    value: "true"

元数据字段规范

字段 必填 详情 示例
服务器 Y* 使用 DNS SRV 记录时要连接的服务器 "server.example.com"
host Y* 要连接的主机 "mongo-mongodb.default.svc.cluster.local:27017"
username 用于连接的用户的用户名 (适用于 host) "admin"
password 用于连接的用户的密码 (适用于 host) "password"
databaseName N 要使用的数据库名称。 默认值为 "daprStore" "daprStore"
collectionName N 要使用的收藏名称 默认值为 "daprCollection" "daprCollection"
writeconcern N 要使用的写入保证 "majority"
readconcern N 要使用的读取保证 "majority", "local","available", "linearizable", "snapshot"
operationTimeout N 操作超时。 默认为 "5s" "5s"

[*] serverhost 的字段是互斥的。 如果两者都未设置,Dapr 将返回错误。

配置 MongoDB


您可以使用 Docker 在本地运行 MongoDB :

docker run --name some-mongo -d mongo

然后您可以使用 localhost:27017 与服务器交互。

如果在您的组件定义中未指定 databaseName 值,请确保创建了一个名为 daprStore 的数据库。


在 Kubernetes 上安装MongoDB 最简单的方法是使用 Helm chart

helm install mongo stable/mongodb

这将MongoDB安装到 default 命名空间。 要与 MongoDB 交互,请通过 kubectl get svc mongo-mongodb 找到 service。

例如,如果使用上面的例子安装,MongoDB 主机地址将是:

mongo-mongodb.default.svc.cluster.local:27017

按照屏幕指示获取 MongoDB 的 root 密码。 用户名默认是 admin

相关链接