场景是这样的:开启多个线程访问外部 api ,过一段时间,发现所有线程死锁。 环境: python2.6.7 centos7.1 urllib2 , suse 下无此问题。 dump 如下:
Thread 161 (Thread 0x7f80de4e9700 (LWP 12459)):
#0 0x00007f80e4cacb6c in __lll_lock_wait_private () from /lib64/libc.so.6
#1 0x00007f80e4cc2efd in _L_lock_746 () from /lib64/libc.so.6
#2 0x00007f80e4cc2cb5 in __check_pf () from /lib64/libc.so.6
#3 0x00007f80e4c88f69 in getaddrinfo () from /lib64/libc.so.6
#4 0x00007f80e12faa3c in socket_getaddrinfo (self=<optimized out>, args=<optimized out>) at /home/basic/Python-2.7.6/Modules/socketmodule.c:4198
#5 0x00000000004b5726 in call_function (oparg=<optimized out>, pp_stack=0x7f80de4e6b30) at Python/ceval.c:4021
#6 PyEval_EvalFrameEx (f=f@entry=0x7f7fa403c980, throwflag=throwflag@entry=0) at Python/ceval.c:2666
看上去是 getaddrinfo 引发的死锁,不知道大家没有遇到这个坑,请大家帮忙给些建议,谢谢!
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.