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

redis-py 导致 python CPU 占满?

  •  
  •   abcdabcd987 · 2015-11-15 23:21:48 +08:00 · 2265 次点击
    这是一个创建于 3085 天前的主题,其中的信息可能已经有所发展或是发生改变。

    用 tornado 架了个网站,发现在高并发的情况下 python 的 CPU 占用率很高,做了一下 profile ,发现所有通过 redis-py 操作 redis 的地方 CPU 占用率都特别高。如下图 r.xxx() 以及 lua_xxx()

    觉得很奇怪,如果说是阻塞住了,照道理来说 python 的 CPU 应该是空闲的呀?此外 redis-server 的负载很轻。求解这个是为什么?如何解决,或者如何查找问题?

    7 条回复    2015-11-16 19:48:47 +08:00
    wy315700
        1
    wy315700  
       2015-11-15 23:33:09 +08:00
    装个 hiredis 试试看
    aisk
        2
    aisk  
       2015-11-15 23:43:44 +08:00
    你选中的那项 30.1 ,确定没有算阻塞之后进程挂起的时间进去吗?
    abcdabcd987
        3
    abcdabcd987  
    OP
       2015-11-15 23:48:38 +08:00
    @aisk 呃,阻塞的话, top 看 python 也不应该是 100% 吧?
    abcdabcd987
        4
    abcdabcd987  
    OP
       2015-11-16 00:48:41 +08:00 via iPhone
    @wy315700 没有作用
    aisk
        5
    aisk  
       2015-11-16 11:16:14 +08:00
    @abcdabcd987 是不应该吃到 100 %。可以把 lua_place_order 发一下看看。
    abcdabcd987
        6
    abcdabcd987  
    OP
       2015-11-16 13:43:51 +08:00
    @aisk 咦, lua 不是在 redis-server 跑么?会占 python CPU?
    aisk
        7
    aisk  
       2015-11-16 19:48:47 +08:00
    @abcdabcd987 是,但是不看代码也不知道这个函数都在干嘛。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   950 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 27ms · UTC 20:43 · PVG 04:43 · LAX 13:43 · JFK 16:43
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.