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

当 AMQP 消息格式发生变化时,最好的部署方式是什么?

如何解决当 AMQP 消息格式发生变化时,最好的部署方式是什么?

我们开发了停机时间至关重要的系统。假设 1.0.0 版生产者产生的消息不能被 2.0.0 版消费者处理。

目前的部署方案如下:

  1. 生产中有 1.0.0 版
  2. RabbitMQ 队列具有路由键,例如“queue:ver1”
  3. Kubernetes 启动新服务,这些服务使用“queue:ver2”键声明和订阅队列,并将请求路由到此服务
  4. Kubernetes 停止了旧生产者
  5. 旧工人处理来自队列“queue:ver1”的剩余消息
  6. Kubernetes 停止了老员工
  7. 生产中有 2.0.0 版

这样的方案会产生几个问题:

  • 即使消息格式没有变化也会创建队列
  • 排队的人太多了
  • 复杂的 Kubernetes 配置
  • 我们不知道旧消息是否被老工人处理过,我们只是等待一段时间

我一直在寻找 message versioning 中的解决方案,但这种方式似乎需要实现一些一次性代码(例如将消息转换为新格式)或需要停机。并且没有相关的答案 herehere


有没有办法拒绝“队列版本控制”?

如何避免停机而不丢失数据?

是否有一些最佳做法?

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