网站首页 > 技术文章 正文
1.什么是进程优先级?
Linux进程的优先级是用来确定在多个进程同时运行时,哪个进程会获得更多的CPU时间片。
Linux进程的优先级分为实时优先级和普通优先级。
实时优先级用于实时应用程序,如硬实时任务和实时控制系统,而普通优先级用于非实时应用程序。
2.进程优先级原理
实时进程:动态优先级为0-99的进程,采用实时调度算法调度。
普通进程:动态优先级为100-139的进程,采用完全公平调度算法调度。
nice值:是用于调整普通进程优先级的参数。范围:-20-19。
2.1 task_struct优先级
task_struct {
......
int prio;
int static_prio;
int normal_prio;
unsigned int rt_priority;
};
prio(动态优先级)
动态优先级,有效优先级,调度器最终使用的优先级数值,范围0-139,值越小,优先级越高。
static_prio(静态优先级)
静态优先级,采用SCHED_NORMAL和SCHED_BATCH调度策略的进程(即普通进程)用于计算动态优先级的,范围100-139。
prio = static_prio = nice + DEFAULT_PRIO = nice + 120。
normal_prio(归一化优先级)
用于计算prio的中间变量,不需要太关心。
rt_priority(实时优先级)
实时优先级,采用SCHED_FIFO和SCHED_RR调度策略进程(即实时进程)用于计算动态优先级,范围0-99。
prio = MAX_RT_PRIO - 1 - rt_prio = 100 - 1 - rt_priority;
实时优先级数值越大,得到的动态优先级数值越小,优先级越高。
3.查看进程优先级
3.1 执行ps -elf 命令查看进程优先级
PRI:进程优先级,数值越小,优先级越高。(并非动态优先级)
NI:nice值。
3.2cat /proc/PID/sched查看进程调度信息
policy:调度策略
prio:动态优先级
4.修改进程优先级
4.1 setpriority函数原型
int setpriority(int which, id_t who, int prio);
功能:setpriority函数用于设置进程nice值。
参数:
which:指定要修改nice值的对象,可以是以下值之一:
PRIO_PROCESS:用于修改指定进程的优先级。
PRIO_PGRP:用于修改指定进程组的优先级。
PRIO_USER:用于修改指定用户的所有进程的优先级。
who:指定被修改优先级的对象的标识符。
如果which为PRIO_PROCESS,则who为目标进程的进程ID(PID)。
如果which为PRIO_PGRP,则who为目标进程组的进程组ID(PGID)。
如果which为PRIO_USER,则who为目标用户的用户ID(UID)。
prio:新的nice值,范围通常为-20到19之间。
返回值:
成功:返回0。
失败:返回-1,并设置errno。
4.2 getpriority函数原型
int getpriority(int which, id_t who);
功能:getpriority函数用于获取进程nice值。
参数:
which:指定要获取nice值的对象,可以是以下值之一:
PRIO_PROCESS:用于修改指定进程的优先级。
PRIO_PGRP:用于修改指定进程组的优先级。
PRIO_USER:用于修改指定用户的所有进程的优先级。
who:指定获取nice值的对象的标识符。
如果which为PRIO_PROCESS,则who为目标进程的进程ID(PID)。
如果which为PRIO_PGRP,则who为目标进程组的进程组ID(PGID)。
如果which为PRIO_USER,则who为目标用户的用户ID(UID)。
返回值:
成功:返回nice值。
失败:返回-1,并设置errno。
4.3 sched_setscheduler函数原型
int sched_setscheduler(pid_t pid, int policy, const struct sched_param *param);
功能:sched_setscheduler函数是Linux系统中用于设置进程调度策略和优先级的系统调用。
参数:
pid:进程ID,0表示当前进程。
policy:表示要设置的调度策略,常用的调度策略有以下几种选项:
SCHED_OTHER:普通进程调度策略。
SCHED_FIFO:先进先出调度策略。
SCHED_RR:轮转调度策略。
param:是一个指向sched_param结构的指针,用于指定优先级参数。
struct sched_param {
...
int sched_priority;
...
};
返回值:
成功:返回0。
失败:返回-1,并设置errno。
sched_setscheduler使用注意事项:
调度策略在内核中的定义:
4.4 sched_getscheduler函数原型
int sched_getscheduler(pid_t pid);
功能:sched_getscheduler函数是Linux系统中的一个于获取指定进程的调度策略。
参数:
pid:进程id,0表示当前进程。
返回值:
成功:返回调度策略:
SCHED_OTHER
SCHED_FIFO
SCHED_RR
SCHED_BATCH
SCHED_IDLE
失败:返回-1,并设置errno。
4.5 sched_setparam函数原型
int sched_setparam(pid_t pid, const struct sched_param *param);
功能:sched_setparam用于设置进程实时优先级,该函数不能设置调度策略。
参数:
pid:进程id,0表示当前进程。
param:参数sched_setscheduler函数。
返回值:
成功:返回0。
失败:返回-1,并设置errno。
4.6 sched_getparam函数原型
int sched_getparam(pid_t pid, struct sched_param *param);
功能:sched_getparam用于获取指定进程的实时优先级。
参数:
pid:进程id,0表示当前进程。
param:参数sched_setscheduler函数。
返回值:
成功:返回0。
失败:返回-1,并设置errno。
猜你喜欢
- 2024-10-20 操作系统概论:第四章 内存管理 操作系统内存管理笔记
- 2024-10-20 推荐一款nginx+redis+ehcache高并发与高可用缓存架构
- 2024-10-20 真正的缓存之王,Google Guava 只是弟弟
- 2024-10-20 操作系统-存储管理与文件管理-笔记
- 2024-10-20 高性能缓存 Caffeine(一) 高效缓存cache的作用
- 2024-10-20 一文读懂进程调度算法 进程调度常用算法及其思想
- 2024-10-20 缓存最关心指标有哪些,这篇文章告诉你?
- 2024-10-20 缓存算法:LRU、LFU、随机替换等常见算法简介
- 2024-10-20 Caffine Cache 在 SpringBoot 中的使用
- 2024-10-20 力扣算法题-如何使用两个栈来实现一个FIFO的队列?
你 发表评论:
欢迎- 最近发表
-
- 在 Spring Boot 项目中使用 activiti
- 开箱即用-activiti流程引擎(active 流程引擎)
- 在springBoot项目中整合使用activiti
- activiti中的网关是干什么的?(activiti包含网关)
- SpringBoot集成工作流Activiti(完整源码和配套文档)
- Activiti工作流介绍及使用(activiti工作流会签)
- SpringBoot集成工作流Activiti(实际项目演示)
- activiti工作流引擎(activiti工作流引擎怎么用)
- 工作流Activiti初体验及在数据库中生成的表
- Activiti工作流浅析(activiti6.0工作流引擎深度解析)
- 标签列表
-
- oraclesql优化 (66)
- 类的加载机制 (75)
- feignclient (62)
- 一致性hash算法 (71)
- dockfile (66)
- 锁机制 (57)
- javaresponse (60)
- 查看hive版本 (59)
- phpworkerman (57)
- spark算子 (58)
- vue双向绑定的原理 (68)
- springbootget请求 (58)
- docker网络三种模式 (67)
- spring控制反转 (71)
- data:image/jpeg (69)
- base64 (69)
- java分页 (64)
- kibanadocker (60)
- qabstracttablemodel (62)
- java生成pdf文件 (69)
- deletelater (62)
- com.aspose.words (58)
- android.mk (62)
- qopengl (73)
- epoch_millis (61)
本文暂时没有评论,来添加一个吧(●'◡'●)