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

redis-lua 访问缓慢的问题

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

    小弟试着用了 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
        1
    wccc   128 天前   ♥ 1
    redis 连接不用时间?
        2
    keakon   128 天前   ♥ 1
    我这返回 5 毫秒。
        3
    snal123   128 天前
    @wccc 我懂了。。感谢!
        4
    snal123   128 天前
    已解决,1s 的原因是第一次连接,一开始一直没懂因为以为连接的时间在创建对象的时候,我的理解是事实上 conn 只是一个描述符,类似一个指针,真正和 redis 建立连接是在第一次发起请求的时候,在 test2()上加 100 个循环就能得出只有第一次需要 1s,后面每次都是毫秒级别的响应。
        5
    qipan0321   128 天前 via iPhone
    要加连接池的吧
        6
    aliipay   128 天前
    可以用 redis client 或者 telnet 连接看是否要很久
        7
    vtychx   128 天前
    楼主萌新。很多之前做前端的没有长连接的概念,不了解 connect 的代价。
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   1817 人在线   最高记录 5043   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 18ms · UTC 16:13 · PVG 00:13 · LAX 08:13 · JFK 11:13
    ♥ Do have faith in what you're doing.