微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

dapr 发布/订阅消息组件由 redis 改为 rabbitmq

刚开始测试 dapr 时为了图省事,使用了 pubsub.redis,现在准备上生产环境,改用支持消息持久化的 pubsub.rabbitmq。

之前使用的 pubsub.redis 资源清单如下

apiVersion: dapr.io/v1alpha1
kind: Component
Metadata:
  name: pubsub
  namespace: production
spec:
  type: pubsub.redis
  version: v1
  Metadata:
    - name: redisHost
      value: redis-master.production.svc.cluster.local:6379
    - name: redisPassword
      secretKeyRef:
        name: redis
        key: redis-password

用 helm 安装 rabbitmq,使用 chart 的是 bitnami/rabbitmq

$ helm repo add bitnami https://charts.bitnami.com/bitnami
$ helm install rabbitmq bitnami/rabbitmq

Persistent volume 是通过 kubernets dynamic volume provisioning 动态创建,StorageClass 用的是阿里云 nas。

apiVersion: storage.k8s.io/v1
kind: StorageClass
Metadata:
  name: sc-nas-production-pvs
  annotations:
    storageclass.kubernetes.io/is-default-class: "true"
mountOptions:
  - nolock,tcp,noresvport
  - vers=3
parameters:
  volumeAs: subpath
  server: xxxxxx.cn-hangzhou.extreme.nas.aliyuncs.com:/production/k8s-pvs/
provisioner: nasplugin.csi.alibabacloud.com
reclaimPolicy: Retain

pubsub.rabbitmq 的资源清单如下

apiVersion: dapr.io/v1alpha1
kind: Component
Metadata:
  name: pubsub
  namespace: production
spec:
  type: pubsub.rabbitmq
  version: v1
  Metadata:
    - name: host
      value: "amqp://user:[email protected]:5672"
    - name: durable
      value: true

需要注意的是 host 参数部分,user:password 是连接 rabbitmq 的用户名密码, 用 bitnami/rabbitmq chart 创建的 rabbitmq 用户名就是 user密码在 secret 中,可以通过下面的命令获取

kubectl get secret --namespace "production" rabbitmq -o jsonpath="{.data.rabbitmq-password}" | base64 --decode

Apply 上面的 rabbitmq-pubsub.yaml,发布/订阅消息组件就变成 rabbitmq,不用改1行应用代码,dapr 的优势立马体现。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐