deployment - 当 AMQP 消息格式发生变化时,最好的部署方式是什么?
问题描述
我们开发停机时间至关重要的系统。假设 1.0.0 版生产者生成的消息无法由 2.0.0 版消费者处理。
目前的部署方案如下:
- 生产中有 1.0.0 版本
- RabbitMQ 队列具有像“queue:ver1”这样的路由键
- Kubernetes 启动新服务,使用“queue:ver2”键声明和订阅队列,并将请求路由到该服务
- Kubernetes 停止旧生产者
- 老员工处理来自队列“queue:ver1”的剩余消息
- Kubernetes 停止老工人
- 生产中有 2.0.0 版本
这样的方案会产生几个问题:
- 即使消息格式没有变化,也会创建队列
- 真的很多队列
- 复杂的 Kubernetes 配置
- 我们不知道旧消息是否已被旧工人处理,我们只是等待一定时间
我一直在寻找消息版本控制的解决方案,但这种方式似乎需要实现一些一次性代码(例如将消息转换为新格式)或需要停机。而且这里和这里都没有相关的答案。
有没有办法拒绝“队列版本控制”?
如何避免停机而不丢失数据?
有一些最佳实践吗?
解决方案
推荐阅读
- symfony - Symfony Doctrine 字段类型转换 DC2Type:array -> DC2Type:json
- android - 如何在所有分支中更改 android 项目的包名?
- spring-boot - ObjectMapper 抛出 NullPointerException
- ios - 通知服务扩展 - 隐藏以前的通知
- python - 在 python 数据框列中查找下一个更高的值
- python - 找出 selenium 使用的当前代理
- java - JMS 使用消息选择器按时间戳过滤
- angular - 无法绑定到“授权”,因为它不是“li”的已知属性
- mysql - 在 MAMP 中通过 shell 导出数据库时获取 mysqldump:[错误] 未知变量 'column-statistics=0'
- boolean-logic - 仅使用 NAND、OR、XNOR 编写表达式