首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将Python多处理限制为每个内核10%?

将Python多处理限制为每个内核10%?
EN

Stack Overflow用户
提问于 2017-03-14 18:36:54
回答 1查看 262关注 0票数 1

我有一个循环,我一直在努力加快速度。我注意到Python只使用了一个内核,所以我导入了多处理包并设置了一个池。现在,整个过程分布在多个核心上,但它们似乎被限制在10%左右。

这是预期的/最佳的吗?或者,有没有办法从每个核心中利用更多?

代码:

代码语言:javascript
复制
from multiprocessing.dummy import Pool as ThreadPool

//...more code here...

pool = ThreadPool(os.cpu_count())
pool.starmap(getSubject, zip(range(1, Nsub)))
pool.close()
pool.join()

ps。在使用Pool之前,htop会显示一个内核为100 %,其他内核为~0 %。

EN

回答 1

Stack Overflow用户

发布于 2017-03-14 18:43:03

multiprocessing.dummy.Pool是一个线程池。由于GIL,您不会充分使用多个内核。如果您希望使用进程,请将其更改为multiprocessing.Pool

请注意,内核的总使用率还取决于getSubject到底做了什么。如果您正在进行一些同步(例如锁定),那么您可能也会看到性能损失。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42783645

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档