繁体   English   中英

调度程序是否可以通过`sched_setaffinity`自动将亲和性已设置为非常繁忙的cpu的线程迁移到空闲cpu?

[英]Could scheduler automatically migrate the thread whose affinity has been set to a very busy cpu through `sched_setaffinity` to a free cpu?

调度器是否可以通过sched_setaffinity自动将亲和度设置为非常繁忙的 cpu 的线程迁移到空闲的 cpu 上?

sched_setaffinity是实现“硬关联”还是“软关联”?

我所说的“软亲和力”是它告诉调度程序线程更喜欢在特定的 cpu 上运行,并且可以在必要时迁移到其他 cpu。

我所说的“硬关联”是它告诉调度程序线程必须在特定的 cpu 上运行,无论线程必须等待 cpu 资源多长时间。

我清楚地记得确实有可以在windows下提供“软亲和力”和“硬亲和力”的api。api可以在linux下提供“软亲和力”吗?

不会。如果一个进程只与一个 CPU 有关联,那么无论如何它都只会在该 CPU 上运行。 换句话说,这符合您对“硬亲和力”的定义。

如果使用不当,此功能当然可能是一把双刃剑:如果 CPU 仅专用于该任务,则将任务的亲和性设置为单个 CPU 会带来很大好处,但如果 CPU 不是专用于该任务,则会降低性能并且它会以某种方式受到影响重物。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM