V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
tianxin8431
V2EX  ›  问与答

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

  •  
  •   tianxin8431 · 2021-12-16 09:49:50 +08:00 · 1206 次点击
    这是一个创建于 833 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

    6 条回复    2021-12-16 11:11:38 +08:00
    WhereverYouGo
        1
    WhereverYouGo  
       2021-12-16 09:59:19 +08:00
    那就引入消息队列
    cominghome
        2
    cominghome  
       2021-12-16 10:05:40 +08:00
    redis 本来也可以实现简单的“消息队列”功能,但是我们没有用过,建议你自己看文档然后评估
    securityCoding
        3
    securityCoding  
       2021-12-16 10:08:13 +08:00
    高并发下你的思路没错,同步转异步通过队列做缓冲。
    但是我还是建议你评估一下数据库的性能,没你想的那么弱。
    NeverNot
        4
    NeverNot  
       2021-12-16 10:19:35 +08:00
    redis 的 lpush 和 rpop 这两个函数,可实现消息队列功能
    awalkingman
        5
    awalkingman  
       2021-12-16 11:06:17 +08:00
    在高并发下用 redis 做消息队列,要么你就开启每次写都落盘,要么你就祈祷 redis 别出意外别挂
    konakona
        6
    konakona  
       2021-12-16 11:11:38 +08:00
    高并发下用 redis 做消息队列要保证原子性,应该是需要用 PUA 脚本写的,关于 LUA 脚本和保证原子性操作的 LUA 的阅读可以看一下这里:
    https://learnku.com/articles/60217
    阅读 6.3 小节
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   946 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 43ms · UTC 21:01 · PVG 05:01 · LAX 14:01 · JFK 17:01
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.