0

0

Linux 进程优先级与调度策略

冰川箭仙

冰川箭仙

发布时间:2026-01-26 08:54:09

|

274人浏览过

|

来源于php中文网

原创

最可靠方法是用 ps -eo pid,comm,cls,pri,nice,pcpu 查看:cls 显示调度策略(ts/SCHED_OTHER、ff/SCHED_FIFO、rr/SCHED_RR),pri 为内核最终优先级(0–139),nice 仅对 SCHED_OTHER 有效。

linux 进程优先级与调度策略

如何查看进程的实时优先级和调度策略

Linux 中每个进程都有一个调度策略(如 SCHED_FIFOSCHED_OTHER)和两个相关数值:静态优先级(static_prio)、动态优先级(priority,即用户可见的 ni 值)。直接看 pstop 最可靠:

  • ps -eo pid,comm,cls,pri,nice,pcpu --sort=-pcpu | head -10 —— cls 显示策略(ts=SCHED_OTHERff=SCHED_FIFOrr=SCHED_RR),pri 是内核计算出的最终优先级值(范围 0–139),nice 仅对 SCHED_OTHER 有效
  • top -p $PID 进入后按 f 添加 PR(实际调度优先级)、NI(nice 值)、ST(调度类型缩写)列
  • 更底层可读 /proc/$PID/status 中的 policy: 行和 /proc/$PID/stat 第 39/40 字段(rt_prioritypolicy

chrt 修改实时调度策略和优先级

chrt 是修改调度策略最直接的工具,但注意:只有 root 或具备 CAP_SYS_NICE 能力的进程才能提升策略或设高实时优先级。

  • 启动新进程并设为 SCHED_FIFO 优先级 50:chrt -f 50 ./myapp
  • 修改已有进程:chrt -f 50 $PID(若原策略非实时,会失败;需先确认进程未被锁定)
  • 切回默认策略:chrt -o 0 $PID-o 等价于 --other,即 SCHED_OTHER
  • 错误提示 Operation not permitted 通常因权限不足或 /proc/sys/kernel/sched_rt_runtime_us 限制已耗尽

renice 只影响 SCHED_OTHER 进程的 CPU 时间份额

renice 不改变调度策略,也不影响实时进程。它只调整 niceness 值(-20 到 +19),该值参与 CFS 调度器中虚拟运行时间(vruntime)的计算,从而间接决定分配给该进程的 CPU 时间比例。

微信 WeLM
微信 WeLM

WeLM不是一个直接的对话机器人,而是一个补全用户输入信息的生成模型。

下载
  • renice -n -5 $PID 让普通进程“抢”更多 CPU(但不会抢占实时进程)
  • renice -n 10 $PID 降低其调度权重,适合后台批处理任务
  • 对已用 chrt -f 启动的进程执行 renice 无效 —— nice 值仍显示,但内核完全忽略它
  • 注意:普通用户只能调高 nice(让进程更“谦让”),调低必须有 root 权限

实时调度策略的危险点与调试线索

误用 SCHED_FIFO 或过高的 rt_priority 可导致系统无响应 —— 因为实时进程不主动让出 CPU,且不遵守 CFS 的时间片限制。

  • 典型症状:ssh 登录卡住、鼠标不动、sysrq 仍可用(Alt+SysRq+R 解锁键盘,Alt+SysRq+T 查看堆
  • 检查是否启用了实时带宽限制:cat /proc/sys/kernel/sched_rt_runtime_us(默认 950000,即 95%)和 /proc/sys/kernel/sched_rt_period_us(默认 1000000);设为 -1 表示禁用限制(不推荐)
  • 避免在容器中随意启用 SCHED_FIFO —— 宿主机上所有实时进程共享同一全局带宽池,容器间无隔离
  • 调试时优先用 chrt -p $PID 确认当前策略,再结合 psclspri 列交叉验证

真实场景里,多数服务不需要实时调度;renice 配合 CFS 已足够调控资源倾向。一旦涉及 SCHED_FIFO,务必确认有配套的监控和熔断机制——比如用 systemdCPUQuota= 限制整体占用,否则一个死循环就能拖垮整机。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

390

2023.09.04

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

395

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

575

2023.08.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

395

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

575

2023.08.10

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1373

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

705

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

295

2023.06.30

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

31

2026.01.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.8万人学习

Git 教程
Git 教程

共21课时 | 3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号