问一个并发上座的问题?
问题描述
我是用 hash 表来表示座位上的人的( key 表示座位位置,value 就是具体的 uid ),然后用 hsetnx 处理并发上座,
但是有个问题是,在上座成功后,我要把这条信息投递到消息队列里去(为了通知客户端),但是这里可能有网络原因(或者其他原因),
导致投递失败,但是 redis 又没有事务,没办法回滚,这样就会出问题,不知道大家有什么好思路,冒昧请教下。
伪代码类似于:
res = cache.setnx(pos, uid)
if (!res) {
throw new Exception('上座失败!')
}
mq.send({
pos: pos,
uid: uid,
time: new Date()
})
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
还是需要结合具体场景来看这个问题。
SET key value [expiration EX seconds|PX milliseconds] [NX|XX]
。不仅实现了setnx的功能,同时还加上了过期时间。跟map唯一的区别就是没有统一管理key值。仅供参考,需要结合实际需要来处理
消息队列本身就是解耦的,如果投递失败就回滚那就相当于强依赖了?