五分钟明白linux中nice值表示什么

2024-02-23 20:58

本文主要是介绍五分钟明白linux中nice值表示什么,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原文链接:https://www.cpweb.top/500

nice:用户态在低优先级花费的cpu时间。可以理解为被降低优先级进程花费的cpu时间,下面实例对比演示下。

[root@cp proc]# cat /proc/stat | grep 'cpu'        //首先我们记录下当前nice值,方便后面对比,即第三列当前为0
cpu  475 0 1257 1898 2 0 2 0 0 0
cpu0 475 0 1257 1898 2 0 2 0 0 0
[root@cp proc]# stress -i 5             //使用stress命令模拟五个进程
.........
[root@cp ~]# ps aux | grep stress
root       7762  0.0  0.0   7312   640 pts/0    S+   18:45   0:00 stress -i 5
root       7763 17.7  0.0   7312   100 pts/0    D+   18:45   0:15 stress -i 5
root       7764 17.7  0.0   7312   100 pts/0    D+   18:45   0:15 stress -i 5
root       7765 17.7  0.0   7312   100 pts/0    D+   18:45   0:15 stress -i 5
root       7766 17.8  0.0   7312   100 pts/0    D+   18:45   0:15 stress -i 5
root       7767 17.7  0.0   7312   100 pts/0    D+   18:45   0:15 stress -i 5
[root@cp ~]# ps -l -p 7763             //查看7763进程的优先级
F S   UID    PID   PPID  C PRI  NI ADDR SZ WCHAN  TTY          TIME CMD
1 D     0   7763   7762 17  80   0 -  1828 sync_i pts/0    00:00:16 stress
//想要明白进程优先级,先得了解PRI和NI这两个值的含义PRI:进程的优先级,数值越小,该进程的优先级越高,就越早被 CPU 执行。NI :可以理解为进程优先级的修正量,NI值的范围从-20到+19。因为PRI=PRI(old)+NI,所以正值表示低优先级,负值表示高优先级,值为零则表示不会调整该进程的优先级。PRI这个值用户是不能修改的,所以要调整一个进程的优先级只能通过调整NI值来实现。

(1) 进程低优先级实验
[root@cp ~]# renice +19 -p 7763         //使用renice命令将此进程优先级调整为最低
7763 (process ID) old priority 0, new priority 19
[root@cp ~]# ps -l -p 7763
F S   UID    PID   PPID  C PRI  NI ADDR SZ WCHAN  TTY          TIME CMD
1 D     0   7763   7762 17  99  19 -  1828 sync_i pts/0    00:00:28 stress
[root@cp ~]# cat /proc/stat | grep cpu
cpu  942 9 17701 1898 2 0 3 0 0 0
cpu0 942 9 17701 1898 2 0 3 0 0 0
[root@cp ~]# cat /proc/stat | grep cpu
cpu  949 10 17947 1898 2 0 3 0 0 0
cpu0 949 10 17947 1898 2 0 3 0 0 0
[root@cp ~]# cat /proc/stat | grep cpu              //我们可以清楚观测到此前为0,怎么都不动的nice值随着时间不断增加。
cpu  950 11 18037 1898 2 0 3 0 0 0
cpu0 950 11 18037 1898 2 0 3 0 0 0[root@cp ~]# pidstat -C stress 2 1              //同时我们可以看到7763进程等待cpu的时间明显上升
Linux 3.10.0-957.el7.x86_64 (cp) 	07/31/2020 	_x86_64_	(1 CPU)07:04:22 PM   UID       PID    %usr %system  %guest   %wait    %CPU   CPU  Command
07:04:24 PM     0      7763    1.00   17.41    0.00   72.64   18.41     0  stress
07:04:24 PM     0      7764    0.50   16.92    0.00   47.26   17.41     0  stress
07:04:24 PM     0      7765    0.50   16.92    0.00   32.84   17.41     0  stress
07:04:24 PM     0      7766    0.50   17.41    0.00   30.35   17.91     0  stress
07:04:24 PM     0      7767    0.00   17.91    0.00   18.41   17.91     0  stressAverage:      UID       PID    %usr %system  %guest   %wait    %CPU   CPU  Command
Average:        0      7763    1.00   17.41    0.00   72.64   18.41     -  stress
Average:        0      7764    0.50   16.92    0.00   47.26   17.41     -  stress
Average:        0      7765    0.50   16.92    0.00   32.84   17.41     -  stress
Average:        0      7766    0.50   17.41    0.00   30.35   17.91     -  stress
Average:        0      7767    0.00   17.91    0.00   18.41   17.91     -  stress[root@cp ~]# mpstat -P ALL 2 1                  //使用mpstat命令可以发现nice值的变化
Linux 3.10.0-957.el7.x86_64 (cp) 	07/31/2020 	_x86_64_	(1 CPU)07:03:46 PM  CPU    %usr   %nice    %sys %iowait    %irq   %soft  %steal  %guest  %gnice   %idle
07:03:48 PM  all    1.99    1.00   97.01    0.00    0.00    0.00    0.00    0.00    0.00    0.00
07:03:48 PM    0    1.99    1.00   97.01    0.00    0.00    0.00    0.00    0.00    0.00    0.00Average:     CPU    %usr   %nice    %sys %iowait    %irq   %soft  %steal  %guest  %gnice   %idle
Average:     all    1.99    1.00   97.01    0.00    0.00    0.00    0.00    0.00    0.00    0.00
Average:       0    1.99    1.00   97.01    0.00    0.00    0.00    0.00    0.00    0.00    0.00[root@cp ~]# renice 0 -p 7763                       //将进程nice调整为0,可以观测到nice值停止变化了
7763 (process ID) old priority 19, new priority 0
[root@cp ~]# ps -l -p 7763
F S   UID    PID   PPID  C PRI  NI ADDR SZ WCHAN  TTY          TIME CMD
1 D     0   7763   7762 17  80   0 -  1828 sync_i pts/0    00:00:44 stress
[root@cp ~]# cat /proc/stat | grep cpu
cpu  1119 52 25564 1898 2 0 3 0 0 0
cpu0 1119 52 25565 1898 2 0 3 0 0 0
[root@cp ~]# cat /proc/stat | grep cpu
cpu  1120 52 25639 1898 2 0 3 0 0 0
cpu0 1120 52 25639 1898 2 0 3 0 0 0
[root@cp ~]# cat /proc/stat | grep cpu
cpu  1123 52 25708 1898 2 0 3 0 0 0
cpu0 1123 52 25708 1898 2 0 3 0 0 0

(2) 进程高优先级实验

前面说nice值表示的是被降低优先级进程花费的cpu时间,那么如果调高进程优先级nice值会发生变化么

[root@cp ~]# renice -20 -p 7763
7763 (process ID) old priority 0, new priority -20
[root@cp ~]# ps -l -p 7763
F S   UID    PID   PPID  C PRI  NI ADDR SZ WCHAN  TTY          TIME CMD
1 D     0   7763   7762 17  60 -20 -  1828 sync_i pts/0    00:02:19 stress
[root@cp ~]# cat /proc/stat | grep cpu
cpu  2602 52 77422 1899 2 0 5 0 0 0
cpu0 2602 52 77422 1899 2 0 5 0 0 0
[root@cp ~]# cat /proc/stat | grep cpu
cpu  2605 52 77520 1899 2 0 5 0 0 0
cpu0 2605 52 77520 1899 2 0 5 0 0 0
[root@cp ~]# cat /proc/stat | grep cpu              //可以清楚观测到,不会发生变化。
cpu  2607 52 77581 1899 2 0 5 0 0 0
cpu0 2607 52 77581 1899 2 0 5 0 0 0
[root@cp ~]# pidstat -C stress 2 1              //同时我们可以看到7763进程等待cpu的时间明显降低
Linux 3.10.0-957.el7.x86_64 (cp) 	07/31/2020 	_x86_64_	(1 CPU)07:01:33 PM   UID       PID    %usr %system  %guest   %wait    %CPU   CPU  Command
07:01:35 PM     0      7763    0.50   17.91    0.00    6.97   18.41     0  stress
07:01:35 PM     0      7764    0.50   16.92    0.00   36.32   17.41     0  stress
07:01:35 PM     0      7765    0.00   17.41    0.00   34.83   17.41     0  stress
07:01:35 PM     0      7766    0.50   16.92    0.00   51.24   17.41     0  stress
07:01:35 PM     0      7767    0.50   17.41    0.00   72.64   17.91     0  stressAverage:      UID       PID    %usr %system  %guest   %wait    %CPU   CPU  Command
Average:        0      7763    0.50   17.91    0.00    6.97   18.41     -  stress
Average:        0      7764    0.50   16.92    0.00   36.32   17.41     -  stress
Average:        0      7765    0.00   17.41    0.00   34.83   17.41     -  stress
Average:        0      7766    0.50   16.92    0.00   51.24   17.41     -  stress
Average:        0      7767    0.50   17.41    0.00   72.64   17.91     -  stress
[root@cp ~]# mpstat -P ALL 2 1              //使用mpstat命令也没发现nice值的变化
Linux 3.10.0-957.el7.x86_64 (cp) 	07/31/2020 	_x86_64_	(1 CPU)06:59:16 PM  CPU    %usr   %nice    %sys %iowait    %irq   %soft  %steal  %guest  %gnice   %idle
06:59:18 PM  all    3.00    0.00   97.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00
06:59:18 PM    0    3.00    0.00   97.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00Average:     CPU    %usr   %nice    %sys %iowait    %irq   %soft  %steal  %guest  %gnice   %idle
Average:     all    3.00    0.00   97.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00
Average:       0    3.00    0.00   97.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00


原文链接:https://www.cpweb.top/500

这篇关于五分钟明白linux中nice值表示什么的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

windows和Linux安装Jmeter与简单使用方式

《windows和Linux安装Jmeter与简单使用方式》:本文主要介绍windows和Linux安装Jmeter与简单使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows和linux安装Jmeter与简单使用一、下载安装包二、JDK安装1.windows设

Kali Linux安装实现教程(亲测有效)

《KaliLinux安装实现教程(亲测有效)》:本文主要介绍KaliLinux安装实现教程(亲测有效),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、下载二、安装总结一、下载1、点http://www.chinasem.cn击链接 Get Kali | Kal

linux服务之NIS账户管理服务方式

《linux服务之NIS账户管理服务方式》:本文主要介绍linux服务之NIS账户管理服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、所需要的软件二、服务器配置1、安装 NIS 服务2、设定 NIS 的域名 (NIS domain name)3、修改主

Linux实现简易版Shell的代码详解

《Linux实现简易版Shell的代码详解》本篇文章,我们将一起踏上一段有趣的旅程,仿照CentOS–Bash的工作流程,实现一个功能虽然简单,但足以让你深刻理解Shell工作原理的迷你Sh... 目录一、程序流程分析二、代码实现1. 打印命令行提示符2. 获取用户输入的命令行3. 命令行解析4. 执行命令

ubuntu16.04如何部署dify? 在Linux上安装部署Dify的技巧

《ubuntu16.04如何部署dify?在Linux上安装部署Dify的技巧》随着云计算和容器技术的快速发展,Docker已经成为现代软件开发和部署的重要工具之一,Dify作为一款优秀的云原生应用... Dify 是一个基于 docker 的工作流管理工具,旨在简化机器学习和数据科学领域的多步骤工作流。它

Linux高并发场景下的网络参数调优实战指南

《Linux高并发场景下的网络参数调优实战指南》在高并发网络服务场景中,Linux内核的默认网络参数往往无法满足需求,导致性能瓶颈、连接超时甚至服务崩溃,本文基于真实案例分析,从参数解读、问题诊断到优... 目录一、问题背景:当并发连接遇上性能瓶颈1.1 案例环境1.2 初始参数分析二、深度诊断:连接状态与

Linux系统调试之ltrace工具使用与调试过程

《Linux系统调试之ltrace工具使用与调试过程》:本文主要介绍Linux系统调试之ltrace工具使用与调试过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、ltrace 定义与作用二、ltrace 工作原理1. 劫持进程的 PLT/GOT 表2. 重定

Linux区分SSD和机械硬盘的方法总结

《Linux区分SSD和机械硬盘的方法总结》在Linux系统管理中,了解存储设备的类型和特性是至关重要的,不同的存储介质(如固态硬盘SSD和机械硬盘HDD)在性能、可靠性和适用场景上有着显著差异,本文... 目录一、lsblk 命令简介基本用法二、识别磁盘类型的关键参数:ROTA查询 ROTA 参数ROTA

嵌入式Linux之使用设备树驱动GPIO的实现方式

《嵌入式Linux之使用设备树驱动GPIO的实现方式》:本文主要介绍嵌入式Linux之使用设备树驱动GPIO的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、设备树配置1.1 添加 pinctrl 节点1.2 添加 LED 设备节点二、编写驱动程序2.1

嵌入式Linux驱动中的异步通知机制详解

《嵌入式Linux驱动中的异步通知机制详解》:本文主要介绍嵌入式Linux驱动中的异步通知机制,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、异步通知的核心概念1. 什么是异步通知2. 异步通知的关键组件二、异步通知的实现原理三、代码示例分析1. 设备结构