V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
NobodyVe2x
V2EX  ›  Node.js

Node 使用 Redis 如何处理因异步取值不准确的问题?

  •  
  •   NobodyVe2x · 2023-09-21 10:16:04 +08:00 · 1635 次点击
    这是一个创建于 366 天前的主题,其中的信息可能已经有所发展或是发生改变。

    大概描述一下应用场景:

    app.get("/handle-work/:workid", async (req, res) => {
    	const workid = req.params.workid;
        
        const work = await client.get(workid);
        if (!work) {
        	res.send("The work already done:" + workid);
            return;
        }
        
        // do something sync
        
        // clean redis cache
    	await client.del(workid);
        
      	res.send("Handle:" + workid);
    });
    

    这种写法可能会导致一个 workid 被处理两次。 应该如何避免呢? 谢谢

    9 条回复    2023-09-23 21:28:25 +08:00
    lsk569937453
        1
    lsk569937453  
       2023-09-21 10:29:31 +08:00
    你需要搜索的关键字可能是"redis 分布式锁"
    cloud107202
        2
    cloud107202  
       2023-09-21 10:38:54 +08:00   ❤️ 1
    1. do something sync 这里看下能否设计成幂等的. 偶尔调用端抖动一下请求了两次,无碍
    2. 如果 1 不可以,要在 handle 之前对 workid 上锁,这里的锁也可以顺势复用 redis 的能力 https://redis.io/docs/manual/patterns/distributed-locks/
    luin
        3
    luin  
       2023-09-21 10:45:42 +08:00   ❤️ 1
    把 client.get 换成 client.getdel
    amlee
        4
    amlee  
       2023-09-21 12:46:44 +08:00   ❤️ 1
    op, 这有个大佬,@luin ,快逮着问
    nodejsexpress
        5
    nodejsexpress  
       2023-09-21 13:30:06 +08:00
    用原子操作的 pop spop
    ChevalierLxc
        6
    ChevalierLxc  
       2023-09-21 13:35:33 +08:00
    大哥,你这不是普通的 get ,而是你要上锁啊,拿某个资源,就得锁,让别人竞争不到
    maocat
        7
    maocat  
       2023-09-21 16:10:43 +08:00
    幂等,防抖
    acerphoenix
        8
    acerphoenix  
       2023-09-22 08:45:31 +08:00
    你这问题不是异步处理带来的。
    NobodyVe2x
        9
    NobodyVe2x  
    OP
       363 天前
    @luin 感谢大佬~~~ 解开了我的困惑,谢谢
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2412 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 11:29 · PVG 19:29 · LAX 04:29 · JFK 07:29
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.