用 tornado 架了个网站,发现在高并发的情况下 python 的 CPU 占用率很高,做了一下 profile ,发现所有通过 redis-py 操作 redis 的地方 CPU 占用率都特别高。如下图 r.xxx()
以及 lua_xxx()
。
觉得很奇怪,如果说是阻塞住了,照道理来说 python 的 CPU 应该是空闲的呀?此外 redis-server 的负载很轻。求解这个是为什么?如何解决,或者如何查找问题?
1
wy315700 2015-11-15 23:33:09 +08:00
装个 hiredis 试试看
|
2
aisk 2015-11-15 23:43:44 +08:00
你选中的那项 30.1 ,确定没有算阻塞之后进程挂起的时间进去吗?
|
3
abcdabcd987 OP @aisk 呃,阻塞的话, top 看 python 也不应该是 100% 吧?
|
4
abcdabcd987 OP @wy315700 没有作用
|
5
aisk 2015-11-16 11:16:14 +08:00
@abcdabcd987 是不应该吃到 100 %。可以把 lua_place_order 发一下看看。
|
6
abcdabcd987 OP @aisk 咦, lua 不是在 redis-server 跑么?会占 python CPU?
|
7
aisk 2015-11-16 19:48:47 +08:00
@abcdabcd987 是,但是不看代码也不知道这个函数都在干嘛。
|