如何知道Linux Scheduler时间片?

我正在寻找我的Linux内核的时间片(或量子)的值。

是否存在/proc公开此类信息的文件?

(或者)在我的发行版的Linux标头中是否定义明确?

(或者)是否存在公开此值的Linux API的C函数(也许是sysinfo)?

提前致谢。


MMMHUHU
浏览 4294回答 3
3回答

RISEBY

分配给特定过程的数量可能有所不同:您可以通过调整sched_latency_ns和 sched_min_granularity_ns来调整“切片” ,但请注意,“切片”不是固定的量。还要注意,CFS抢占决策是基于瞬时状态的。一个任务可能已经收到了完整的(可变)CPU时间“分片”,但是仅当有更多应得的任务可用时,抢占才会被触发,因此“分片”不是您期望的“最大不间断CPU时间”会..但是有点相似。对于使用SCHED_RR专用实时进程,默认的时间片是在Linux内核定义为RR_TIMESLICE在在include / linux /排程/ rt.h。/* * default timeslice is 100 msecs (used only for SCHED_RR tasks). * Timeslices get refilled after they expire. */#define RR_TIMESLICE            (100 * HZ / 1000)您可以sched_rr_get_interval()用来获取特定SCHED_RR进程的SCHED_RR间隔。

有只小跳蛙

CFS(进程的默认调度程序)没有固定的时间片,它是在运行时根据目标等待时间(sysctl_sched_latency)和正在运行的进程数进行计算的。时间片永远不能小于最小粒度(sysctl_sched_min_granularity)。Timeslice将始终在sysctl_sched_min_granularity和之间sysctl_sched_latency,默认值分别为0.75 ms和6 ms,并在kernel / sched / fair.c中定义。但是实际的时间片不会导出到用户空间。

慕沐林林

SCHED_OTHER进程(即在(默认)非实时循环分时策略下运行的SCHED_RR进程)与进程之间的可接受答案存在一些混淆。的sched_latency_ns和sched_min_granularity_ns文件(其旨在用于调试目的,可见仅在内核配置有CONFIG_SCHED_DEBUG)影响的调度SCHED_OTHER过程。正如Alexey Shmalko的回答所指出的那样,CFS下的时间片是不固定的(并且不会导出到用户空间),并且将取决于内核参数和诸如进程的良好值之类的因素。sched_rr_get_interval()返回一个固定值,该值SCHED_RR是保证进程获得的数量,除非抢占或阻塞。在传统的Linux上,时间SCHED_RR间隔为0.1秒。从Linux 3.9开始,该限制可通过/proc/sys/kernel/sched_rr_timeslice_ms文件进行调整,该文件的量子表示为毫秒值,默认值为100。
打开App,查看更多内容
随时随地看视频慕课网APP