图解Linux进程优先级

目录

1.什么是进程优先级?

2.进程优先级原理

3.查看进程优先级

4.修改进程优先级

4.1 setpriority函数原型

4.2 getpriority函数原型

4.3 sched_setscheduler函数原型

4.4 sched_getscheduler函数原型

4.5 sched_setparam函数原型

4.6 sched_getparam函数原型


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。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/130311.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Unity Perception合成数据生成、标注与ML模型训练

在线工具推荐: Three.js AI纹理开发包 - YOLO合成数据生成器 - GLTF/GLB在线编辑 - 3D模型格式在线转换 - 3D场景编辑器 任何训练过机器学习模型的人都会告诉你,模型是从数据得到的,一般来说,更多的数据和标签会带来更好的性能。 …

限制LitstBox控件显示指定行数的最新数据(3/3)

实例需求:由于数据行数累加增加,控件加载的数据越来越多,每次用户都需要使用右侧滚动条拖动才能查看最新数据。 因此希望ListBox只加载最后10行数据(不含标题行),这样用户可以非常方便地选择数据&#xff…

JMeter组件

1.JMeter常用组件 必须组件:测试计划,线程组(包含多个线程),取样器 测试计划,JMeter默认创建且仅有一个 线程组: 添加步骤: 选择TestPlan并点击鼠标右键添加 分类以及使用&…

Spring Data Redis + RabbitMQ - 基于 string 实现缓存、计数功能(同步数据)

目录 一、Spring Data Redis 1.1、缓存功能 1.1.1、分析 1.1.2、案例实现 1.1.3、效果演示 1.2、计数功能(Redis RabbitMQ) 1.2.1、分析 1.2.2、案例实现 一、Spring Data Redis 1.1、缓存功能 1.1.1、分析 使用 redis 作为缓存, M…

curl(四)证书相关

一 证书相关 ① -k 1、客户端忽略服务端证书校验 -k | --insecure --> 单向[1]、这个选项显式地允许curl 执行不安全 的SSL连接和传输[2]、所有SSL连接都试图通过使用默认安装的CA证书捆绑包来确保安全[3]、这使得所有被认为是不安全的连接失败,除非使用-k --> 自签…

顺序表(数据结构)

顺序表是用一段 物理地址连续 的存储单元依次存储数据元素的线性结构&#xff0c;一般情况下采用数组存 储。在数组上完成数据的增删查改。 顺序表的实现 #pragma once #include<stdio.h> #include<stdlib.h> #include<assert.h> typedef int SLDataType;//…

k8s的RBAC中,clusterrole, rolebinding 是什么关系谁先谁后

在Kubernetes中&#xff0c;Role-Based Access Control&#xff08;RBAC&#xff09;用于控制集群中不同用户、服务账号或组的访问权限。ClusterRole 和 RoleBinding 是两个关键的 RBAC 组件&#xff0c;它们之间的关系是 ClusterRole 定义了一组权限规则&#xff0c;而 RoleBi…

一座 “数智桥梁”,华为助力“天堑变通途”

《水调歌头游泳》中的一句话&#xff0c;“一桥飞架南北&#xff0c;天堑变通途”&#xff0c;广为人们所熟知&#xff0c;其中展现出的&#xff0c;是中国人对美好出行的无限向往。 天堑变通途从来不易。 中国是当今世界上交通运输最繁忙、最快捷的国家之一&#xff0c;交通行…

2023-在mac下安装Homebrew的国内镜像

mac安装Homebrew的国内镜像 尝试使用其他下载源&#xff1a;GitHub 可能会受到访问限制&#xff0c;尝试使用其他镜像或下载源。您可以使用清华大学、中科大或阿里云的 Homebrew 镜像&#xff0c;以提高下载速度和可靠性。例如&#xff0c;可以使用阿里云的镜像来安装 Homebre…

冒泡排序(Java)

基本思想 比较前后相邻的二个数据&#xff0c;如果前面数据大于后面的数据&#xff0c;就将这二个数据交换。这样对数组的第 0 个数据到 N-1 个数据进行一次遍历后&#xff0c;最大的一个数据就“沉”到数组第N-1 个位置。如此循环 (N-1)次&#xff0c;每次循环需要比较的个数…

任务1 部署ChatGLM3-6B大模型并进行对话测试

部署ChatGLM3-6B大模型并进行对话测试 0 介绍&#xff1a;1 趋动云项目创建与环境配置1.1 创建项目&#xff1a;1.2 配置环境1.2.1 进入终端1.2.2 设置镜像源1.2.3 克隆项目,并安装依赖 2 修改代码&#xff0c;改路径以及启动代码3 运行代码3.1 运行gradio界面&#xff1a;3.2 …

雷池WAF社区版的使用教程

最近听说了一款免费又好用的WAF软件&#xff0c;雷池社区版&#xff0c;体验了一下虽然还有很多改进的空间 但是总体来说很适合小站长使用&#xff0c;和学习使用 也建议所有想学防火墙和红队&#xff08;攻击队&#xff09;练习使用&#xff0c;听说给官网提交绕过还有额外的…

ZKP Introduction of Nova (Yu Guo) 手写笔记

ZKP学习笔记 郭宇老师Nova课程手写笔记

你知道Python、Pycharm、Anaconda 三者之间的关系吗?

哈喽~大家好呀 Python作为深度学习和人工智能学习的热门语言&#xff0c;你知道Python、Pycharm、Anaconda 三者之间的关系吗&#xff1f;学习一门语言&#xff0c;除了学会其简单的语法之外还需要对其进行运行和实现&#xff0c;才能实现和发挥其功能和作用。下面来介绍运行P…

机器学习(深度学习)轴承故障诊断分类(提供故障数据和python代码实现)

机器学习&#xff08;深度学习&#xff09;故障诊断分类&#xff08;提供故障数据和python代码实现&#xff09; 轴承故障数据集和python代码自取&#xff1a;https://mbd.pub/o/bread/ZZWTm5hw 摘要&#xff1a;机器学习广泛的应用于机械故障诊断和故障分类问题&#xff0c;本…

时间复杂度的计算技巧-算法模型中的时间复杂度如何计算,有哪些技巧呢

大家好&#xff0c;我是微学AI&#xff0c;今天给大家介绍一下时间复杂度的计算技巧-算法模型中的时间复杂度如何计算&#xff0c;有哪些技巧呢&#xff0c;算法的时间复杂度是评估算法性能和效率的一种方式&#xff0c;它表示算法需要执行多少次基本操作才能完成其任务&#x…

关于游双Linux高性能服务器编程代码清单13-4 Segmentation fault (core dumped)报错问题

我尝试了各种改编的或者官方的代码&#xff0c;居然都是错的&#xff0c;最终我发现了问题在于这一行代码 sub_process[pid] user_count; 就是这行代码把pid赋予数组&#xff0c;但是这个数组有多大呢&#xff0c;代码如下 sub_process new int[PROCESS_LIMIT ]; 会发现代…

在react中使用redux react-redux的使用demo

前言: redux是一种状态管理工具,可以存储和操作一些全局或者很多组件需要使用的公共数据。 平心而论,redux的使用对于新上手来说不太友好,多个依赖包的,多种api的结合使用,相对来说比做同样一件事的vuex用起来比较麻烦.不过,熟能生巧,用多了也就习惯了,下面是个人的一个demo,…

Linux文本编辑器vim使用和配置详解

vim介绍 ​ vim是Linux的一款文本编辑器&#xff0c;可以用来编辑代码&#xff0c;而且支持语法高亮&#xff0c;还可以进行一系列配置使vim更多样化。也可以运行于windows&#xff0c;mac os上。 ​ vim有多种模式&#xff0c;但目前我们只介绍绝大多数场景用的到的模式&…

树结构及其算法-二叉树节点的插入

目录 树结构及其算法-二叉树节点的插入 C代码 树结构及其算法-二叉树节点的插入 二叉树节点插入的情况和查找相似&#xff0c;重点是插入后仍要保持二叉查找树的特性。如果插入的节点已经在二叉树中&#xff0c;就没有插入的必要了&#xff0c;如果插入的值不在二叉树中&…