问一个消息队列的问题

2019-05-09 11:50:00 +08:00
 Yuicon
现在有很多仓库本地电脑会创建一些例如设备这样的对象,需要发送消息到消息队列让云端管理也创建一个一样的对象。现在问题的两个对象在数据库里的 id 是不一样的,云端要用怎样的方式把云端数据库的 id 传给本地数据库比较好?本地没有公网 ip,所以无法回调。
4711 次点击
所在节点    Kafka
15 条回复
Yuicon
2019-05-09 11:56:03 +08:00
目前自己的想法是搞个新的队列让客户端订阅去存 id,但是这样就很浪费,可能这个消息只发给一个客户端,这样所有的客户端都收到了
Yuicon
2019-05-09 13:21:44 +08:00
没有人么。。
swuzjb
2019-05-09 13:35:13 +08:00
分布式主键生成策略? 没看懂你的问题
Yuicon
2019-05-09 13:40:41 +08:00
@swuzjb 依赖了框架的 orm 所以主键用的是数据库自动生成的
我的问题是客户端发送消息后,有什么好的方法拿到云端根据消息创建记录后生成的主键
coffeSlider
2019-05-09 14:06:35 +08:00
写一个接口做 id 映射。
h8743
2019-05-09 16:37:08 +08:00
啥数据库? mybatis mysql 自带新增返回 id
Yuicon
2019-05-09 16:39:43 +08:00
@coffeSlider 走消息队列后就是异步的了 新问题在于什么时候去做映射这一步
Yuicon
2019-05-09 16:40:40 +08:00
@h8743 兄弟 拿 id 是可以做到的 问题是怎么传给客户端
Yuicon
2019-05-09 16:43:23 +08:00
最后我的解决方案是搞个新队列,把带 id 的对象发布上去
Nasei
2019-05-09 16:49:16 +08:00
可以搞一个两边都能访问的数据库…云端建完了就写一个本地 id 和云端 id 的记录,本地间隔去查
Yuicon
2019-05-09 16:55:17 +08:00
@Nasei 这样感觉消耗有点大,本地有很多也怕这个数据库有性能问题

对象现在基本都有唯一的 code 字段,其实是一开始设计的问题,因为前期开发用的 orm 就依赖了数据库自动生成的 id,所以就有这么蛋疼的事情
Nasei
2019-05-09 16:58:43 +08:00
@Yuicon 从队列发回来也是可以的,就变了一个基于队列的 rpc 了
Yuicon
2019-05-09 17:01:20 +08:00
@Nasei 嗯 感觉唯一缺点就是我不需要广播 一个消息应该精准的发给需要的客户端
rrfeng
2019-05-09 17:03:52 +08:00
『两个对象在数据库里的 id 是不一样的』
你让他一样不就行了吗???

数据库里的自增 id 无所谓啊,加一个字段不就行了?关键是客户端生成的 id 是不是唯一的?
Yuicon
2019-05-09 21:21:48 +08:00
@rrfeng 你说的这个我是搞了一个唯一的 code 字段,问题是业务里用了很 orm 的东西,强依赖了这个自增 id
比如我要创建一个对象,必须要传入对应的外键 id 才行

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/562470

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX