abcdabcd987
V2EX  ›  问与答

redis-py 导致 python CPU 占满?

  •  
  •   abcdabcd987 · Nov 15, 2015 · 2722 views
    This topic created in 3858 days ago, the information mentioned may be changed or developed.

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

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

    7 replies    2015-11-16 19:48:47 +08:00
    wy315700
        1
    wy315700  
       Nov 15, 2015
    装个 hiredis 试试看
    aisk
        2
    aisk  
       Nov 15, 2015
    你选中的那项 30.1 ,确定没有算阻塞之后进程挂起的时间进去吗?
    abcdabcd987
        3
    abcdabcd987  
    OP
       Nov 15, 2015
    @aisk 呃,阻塞的话, top 看 python 也不应该是 100% 吧?
    abcdabcd987
        4
    abcdabcd987  
    OP
       Nov 16, 2015 via iPhone
    @wy315700 没有作用
    aisk
        5
    aisk  
       Nov 16, 2015
    @abcdabcd987 是不应该吃到 100 %。可以把 lua_place_order 发一下看看。
    abcdabcd987
        6
    abcdabcd987  
    OP
       Nov 16, 2015
    @aisk 咦, lua 不是在 redis-server 跑么?会占 python CPU?
    aisk
        7
    aisk  
       Nov 16, 2015
    @abcdabcd987 是,但是不看代码也不知道这个函数都在干嘛。
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   3121 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 30ms · UTC 14:44 · PVG 22:44 · LAX 07:44 · JFK 10:44
    ♥ Do have faith in what you're doing.