请教一个关于高并发写的问题

2021-12-16 09:49:50 +08:00
 tianxin8431

最近要搞活动,大概就是领优惠券,券是第三方提供的接口,领完之后要写到数据库记录一下。领完券写库的这一步该怎么做比较合适呢?没有消息队列,我能想到比较好的办法是先写到 redis ,然后每分钟从 redis 同步到数据库一次,想问问各位有没有更好的办法

1251 次点击
所在节点    问与答
6 条回复
WhereverYouGo
2021-12-16 09:59:19 +08:00
那就引入消息队列
cominghome
2021-12-16 10:05:40 +08:00
redis 本来也可以实现简单的“消息队列”功能,但是我们没有用过,建议你自己看文档然后评估
securityCoding
2021-12-16 10:08:13 +08:00
高并发下你的思路没错,同步转异步通过队列做缓冲。
但是我还是建议你评估一下数据库的性能,没你想的那么弱。
NeverNot
2021-12-16 10:19:35 +08:00
redis 的 lpush 和 rpop 这两个函数,可实现消息队列功能
awalkingman
2021-12-16 11:06:17 +08:00
在高并发下用 redis 做消息队列,要么你就开启每次写都落盘,要么你就祈祷 redis 别出意外别挂
konakona
2021-12-16 11:11:38 +08:00
高并发下用 redis 做消息队列要保证原子性,应该是需要用 PUA 脚本写的,关于 LUA 脚本和保证原子性操作的 LUA 的阅读可以看一下这里:
https://learnku.com/articles/60217
阅读 6.3 小节

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

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

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

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

© 2021 V2EX