MongoDB

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

配置

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

  1. apiVersion: dapr.io/v1alpha1
  2. kind: Component
  3. metadata:
  4. name: <NAME>
  5. namespace: <NAMESPACE>
  6. spec:
  7. type: state.mongodb
  8. version: v1
  9. metadata:
  10. - name: host
  11. value: <REPLACE-WITH-HOST> # Required. Example: "mongo-mongodb.default.svc.cluster.local:27017"
  12. - name: username
  13. value: <REPLACE-WITH-USERNAME> # Optional. Example: "admin"
  14. - name: password
  15. value: <REPLACE-WITH-PASSWORD> # Optional.
  16. - name: databaseName
  17. value: <REPLACE-WITH-DATABASE-NAME> # Optional. default: "daprStore"
  18. - name: collectionName
  19. value: <REPLACE-WITH-COLLECTION-NAME> # Optional. default: "daprCollection"
  20. - name: writeconcern
  21. value: <REPLACE-WITH-WRITE-CONCERN> # Optional.
  22. - name: readconcern
  23. value: <REPLACE-WITH-READ-CONCERN> # Optional.
  24. - name: operationTimeout
  25. value: <REPLACE-WITH-OPERATION-TIMEOUT> # Optional. default: "5s"

Warning

以上示例将 Secret 明文存储。 更推荐的方式是使用 Secret 组件, 这里

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

  1. - name: actorStateStore
  2. value: "true"

元数据字段规范

字段必填详情示例
hostY要连接的主机“mongo-mongodb.default.svc.cluster.local:27017”
usernameN要连接的用户名“admin”
passwordN用户密码“password”
databaseNameN要使用的数据库名称。 默认值为 “daprStore”“daprStore”
collectionNameN要使用的收藏名称 默认值为 “daprCollection”“daprCollection”
writeconcernN要使用的写入保证“majority”
readconcernN要使用的读取保证“majority”, “local”,“available”, “linearizable”, “snapshot”
operationTimeoutN操作超时。 默认为 “5s”“5s”

配置 MongoDB

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

  1. docker run --name some-mongo -d mongo

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

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

  1. 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

相关链接