python 指定cpu运行_为进程python多处理指定特定的CPU

这篇博客介绍如何在Python中确保多进程任务不会在运行服务器或调度器的CPU核心上运行,以避免性能问题。通过使用`psutil`库,可以设置进程的CPU亲和性,限制它们在特定核心上运行。示例代码展示了一个多处理池的使用,展示了如何在子进程中修改CPU亲和性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我刚刚在这个项目中遇到了类似的问题,3个服务器/调度器在各自的CPU核心上运行,产生了CPU密集型的工作人员——同时,这些工作人员被设计成使用他们正在运行的特定核心,以充分发挥其潜力。在

我需要确保这样的工作进程永远不会在运行服务器/调度器的CPU核心上产生(或使用——因为一些工作线程也使用多处理),因为这会导致后面的操作出现问题。在

我使用了Ioannis Filippidis'sanswer中的以下代码,它非常适合将任何进程限制为任何核心。我在这个例子中使用了多处理池,但是来自child的代码可以在任何multiprocessing.Process中工作。注意:它在macOS上不起作用。在import multiprocessing as mp

def child(worker: int) -> None:

import psutil

import time

p = psutil.Process()

print(f"Child #{worker}: {p}, affinity {p.cpu_affinity()}", flush=True)

time.sleep(1)

p.cpu_affinity([worker])

print(f"Child #{worker}: Set my affinity to {worker}, affinity now {p.cpu_affinity()}", flush=True)

time.sleep(1 + 3 * worker)

print(f"Child #{worker}: Starting CPU intensive task now for 4 seconds on {p.cpu_affinity()}...", flush=

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值