Linux多线程对同一个redisClusterAsyncContext对象并发执行redisClusterAsyncCommand命令,redis回调函数失效

qing20130604 2018-03-14 01:32:55
环境描述:libevent2.1.8+hirediscluster(使用redis异步来代替现有同步方式,从而提高服务查询效率),一个线程负责业务处理(执行redisClusterAsyncCommand),另一个线程负责事件循环,不过回调函数中也会存在redisClusterAsyncCommand执行。
问题描述:服务中会存在多线程对同一个redisClusterAsyncContext对象并发执行redisClusterAsyncCommand命令,而redis回调函数会失效,但执行redisClusterAsyncCommand命令都是成功的,就是收不到回调,有在项目中碰到此问题的,可以帮忙分析,万分感谢!
...全文
549 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
qing20130604 2018-03-14
  • 打赏
  • 举报
回复
qing20130604 2018-03-14
  • 打赏
  • 举报
回复
补充:单个请求串行处理,异步能正常工作,如果批量redisClusterAsyncCommand就有问题,不知是不是redisClusterAsyncCommand实现中没有加锁原因导致?
qing20130604 2018-03-14
  • 打赏
  • 举报
回复

64,637

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧