目前的项目有一个订单模块,客户付款后将付款数据放到 redis 消息队列中,然后通过定时任务每秒去执行对应的逻辑去消费该队列。我认为这样很不合理,请问大家有什么好办法吗?
用到的技术是 PHP+redis+mongodb+Swoole
用到的技术是 PHP+redis+mongodb+Swoole
1
Orenoid Feb 15, 2019
redis 队列不是有个 blpop/brpop 吗,不用定时吧
|
2
hilbertz Feb 15, 2019
付款这种要求高安全性的行为,竟然还放在 redis 里,至少要用 sql 数据库
|
3
wo642436249 OP @Orenoid 定时任务去执行的 blpop/brpop 操作
|
4
wo642436249 OP @hilbertz sql 没用到,用到了 mongodb,没办法,我受限于 PHP+redis+mongodb+Swoole,想抽出一部分换 go 和 mq 的,但是不行,只能在 PHP+redis+mongodb+Swoole 这个圈子里
|
5
q4336431 Feb 15, 2019
用 mq 呗
|
6
juneszh Feb 15, 2019
如果客户交易相互有影响的,例如挂单系统,这么做是没有问题的。高并发业务用 redis 处理热数据,拿数据库做备份是一种提高性能的解决方案,主要做好 redis 的日志 /灾备 /回溯。
|