【linux软件基础知识】完全公平调度

2024-05-13 06:12

本文主要是介绍【linux软件基础知识】完全公平调度,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

完全公平调度(CFS)

CFS根据每个进程相对于所有可运行线程总权重的权重为每个进程分配一个“时间片”。

CFS 的目标是近似“无限小”的调度持续时间,称为目标延迟。 较小的目标延迟可以提高交互性并接近完美的多任务处理,但其代价是更高的切换开销和可能更低的总体吞吐量。

假设目标延迟设置为 20 毫秒,并且有两个具有相同优先级的可运行任务,则每个任务将运行 10 毫秒,然后被另一个任务抢占。 这种时间片的平等分配确保了任务之间的公平性,无论其各自的优先级如何。

如果有四个相同优先级的任务,则每个任务的时间片将减少到5毫秒。 如果有 20 个相同优先级的任务,每个任务的时间片为 1 毫秒。

通过根据可运行任务的数量动态调整时间片,CFS 旨在为多任务环境提供公平且响应迅速的调度。

最小时间片

但是随着可运行任务的数量接近无穷大,分配给每个任务的处理器时间及其分配的时间片的比例接近零。 这可能会导致过多的切换成本,为了缓解此问题,完全公平调度程序 (CFS) 施加了称为最小粒度的最小时间片。 默认情况下,此最小粒度设置为 1 毫秒。

因此,即使可运行任务的数量变得非常大,每个任务的最小时间片仍然为1毫秒。 这确保了频繁上下文切换所产生的切换成本受到限制。

需要注意的是,当进程数量增长到计算比例比最小粒度还小时,CFS的公平性就会受到影响。 虽然可以对公平排队算法进行修改来解决具有大量进程的场景中的公平问题,但 CFS 的设计目的是在这种情况下进行权衡。 面对大量进程时,CFS 优先考虑低延迟、交互性和响应性,而不是完美的公平性。 在只有少量可运行进程的常见情况下,CFS 保持了完美的公平性。

这篇关于【linux软件基础知识】完全公平调度的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/984898

相关文章

Linux命令之firewalld的用法

《Linux命令之firewalld的用法》:本文主要介绍Linux命令之firewalld的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux命令之firewalld1、程序包2、启动firewalld3、配置文件4、firewalld规则定义的九大

Linux之计划任务和调度命令at/cron详解

《Linux之计划任务和调度命令at/cron详解》:本文主要介绍Linux之计划任务和调度命令at/cron的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux计划任务和调度命令at/cron一、计划任务二、命令{at}介绍三、命令语法及功能 :at

Linux下如何使用C++获取硬件信息

《Linux下如何使用C++获取硬件信息》这篇文章主要为大家详细介绍了如何使用C++实现获取CPU,主板,磁盘,BIOS信息等硬件信息,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录方法获取CPU信息:读取"/proc/cpuinfo"文件获取磁盘信息:读取"/proc/diskstats"文

Linux内核参数配置与验证详细指南

《Linux内核参数配置与验证详细指南》在Linux系统运维和性能优化中,内核参数(sysctl)的配置至关重要,本文主要来聊聊如何配置与验证这些Linux内核参数,希望对大家有一定的帮助... 目录1. 引言2. 内核参数的作用3. 如何设置内核参数3.1 临时设置(重启失效)3.2 永久设置(重启仍生效

kali linux 无法登录root的问题及解决方法

《kalilinux无法登录root的问题及解决方法》:本文主要介绍kalilinux无法登录root的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录kali linux 无法登录root1、问题描述1.1、本地登录root1.2、ssh远程登录root2、

Linux ls命令操作详解

《Linuxls命令操作详解》通过ls命令,我们可以查看指定目录下的文件和子目录,并结合不同的选项获取详细的文件信息,如权限、大小、修改时间等,:本文主要介绍Linuxls命令详解,需要的朋友可... 目录1. 命令简介2. 命令的基本语法和用法2.1 语法格式2.2 使用示例2.2.1 列出当前目录下的文

Linux中的计划任务(crontab)使用方式

《Linux中的计划任务(crontab)使用方式》:本文主要介绍Linux中的计划任务(crontab)使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言1、linux的起源与发展2、什么是计划任务(crontab)二、crontab基础1、cro

Linux换行符的使用方法详解

《Linux换行符的使用方法详解》本文介绍了Linux中常用的换行符LF及其在文件中的表示,展示了如何使用sed命令替换换行符,并列举了与换行符处理相关的Linux命令,通过代码讲解的非常详细,需要的... 目录简介检测文件中的换行符使用 cat -A 查看换行符使用 od -c 检查字符换行符格式转换将

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1