6

我正在试验,SCHED_FIFO我看到了一些意想不到的行为。我使用的服务器有 12 个内核,禁用了超线程。所有可配置的中断都已设置为在 CPU 0 上运行。

我的程序开始使用 pthreads 库为低优先级任务创建一个线程,而不更改调度策略,并将 CPU 亲和性设置为核心 0。然后父线程将其 CPU 亲和性设置为核心 3,并将其自己的调度策略设置为SCHED_FIFO使用sched_setscheduler()pid 零和优先级1 然后开始运行非阻塞循环。

程序本身运行良好。但是,如果我在程序运行时第二次尝试登录服务器,终端将无响应,直到我停止程序。这就像调度程序试图在与实时进程相同的核心上运行其他进程。

  1. 我错过了什么?
  2. 调度程序是否仍会尝试在运行实时进程的核心上运行其他进程?如果是这样,有没有办法防止这种情况?
  3. 在父级中设置调度策略会sched_setscheduler()改变之前创建的子级的行为吗?

提前致谢。

4

1 回答 1

6

sched_setscheduler设置进程的调度程序,而不是线程。看:

http://pubs.opengroup.org/onlinepubs/9699919799/functions/sched_setscheduler.html

如果要为线程设置调度程序,则需要在创建新线程之前对新线程的属性对象使用pthread_attr_setschedpolicy和函数。pthread_attr_setschedparam

我不确定 Linux 在满足这些要求方面的一致性如何,但您至少应该首先确保您的代码符合规范,然后根据需要进行调整...

于 2012-05-12T12:19:54.700 回答