首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
snal123
V2EX  ›  Redis

redis-lua 访问缓慢的问题

  •  
  •   snal123 · 161 天前 · 8471 次点击
    这是一个创建于 161 天前的主题,其中的信息可能已经有所发展或是发生改变。

    小弟试着用了 redis-lua 实现分布式锁,测试脚本发现一次请求需要 1s,一直没有找到原因,请各位大佬们看看。 (我也用了 sha 方法先提前注册到 redis,结果依然是 1s 返回)

    import redis
    import time
    conn = redis.Redis()
    
    lua="""
        local ret = redis.call("get", KEYS[1])
        if (ret ~= ARGV[1]) then
            redis.call("set", KEYS[1], ARGV[1])
            return 1
        else
            return 0
        end 
    """
    def test2():
        start_time = time.time()
        script = conn.register_script(lua)
        print(script(keys=["iii"], args=["0"]))
        print(time.time() - start_time)   # 返回需要 1s
    
    test2()
    
    7 回复  |  直到 2019-08-09 12:30:37 +08:00
    wccc
        1
    wccc   161 天前   ♥ 1
    redis 连接不用时间?
    keakon
        2
    keakon   161 天前   ♥ 1
    我这返回 5 毫秒。
    snal123
        3
    snal123   161 天前
    @wccc 我懂了。。感谢!
    snal123
        4
    snal123   161 天前
    已解决,1s 的原因是第一次连接,一开始一直没懂因为以为连接的时间在创建对象的时候,我的理解是事实上 conn 只是一个描述符,类似一个指针,真正和 redis 建立连接是在第一次发起请求的时候,在 test2()上加 100 个循环就能得出只有第一次需要 1s,后面每次都是毫秒级别的响应。
    qipan0321
        5
    qipan0321   161 天前 via iPhone
    要加连接池的吧
    aliipay
        6
    aliipay   161 天前
    可以用 redis client 或者 telnet 连接看是否要很久
    vtychx
        7
    vtychx   161 天前
    楼主萌新。很多之前做前端的没有长连接的概念,不了解 connect 的代价。
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   1774 人在线   最高记录 5168   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 21ms · UTC 00:50 · PVG 08:50 · LAX 16:50 · JFK 19:50
    ♥ Do have faith in what you're doing.