之前因为线程内出现异常导致Python部分线程退出,程序以单线程方式运行了好几个星期,浪费了很多时间。
如何查看当前进程有多少个存活线程呢?
方法1)pstree -p 4761(进程ID)。如下截图所示:
data:image/s3,"s3://crabby-images/8ddeb/8ddebb9360ef353b34a1401d26a8f01d0ac1d8c2" alt=""
方法2)cat /proc/4761(进程ID)/status。如下图所示:
data:image/s3,"s3://crabby-images/9f847/9f84707945c45111fd50bf6d85b34add680f8a15" alt=""
方法3)top -p 4761(进程ID),然后按H。如下图所示:
data:image/s3,"s3://crabby-images/fe3e7/fe3e7e2a597a1c2079784fa5b278d891b0233971" alt=""
为什么只有1个线程在running呢? 由于
GIL的缘故,Python同时只能使用一个CPU核心,线程间要轮换执行,所以同时最多有一个线程在运行。
看下图,MySQL的多个线程就可以同时处于running状态,因为C++可以使用多个CPU核心。