uptime

uptime命令显示了load avg,它其实是读取的/proc/uptime文件:

/proc/uptime 文件

cat /proc/uptime

9592411.58 9566042.33

第一个是系统启动了多久(单位s),第二个意思是系统启动以来,cpu idle花费的时间(单位s)。多核机器上,第二个可能大于第一个,因为他是每个核心idle的总和。

怎么才能知道uptime 真的是读取这个文件呢?想办法查看一下,这里可以用strace :

[root@localhost ~]# strace uptime 2>&1 | grep open

open("/proc/uptime", O_RDONLY) = 3

open("/var/run/utmp", O_RDONLY|O_CLOEXEC) = 4

open("/proc/loadavg", O_RDONLY) = 4

strace 命令在stderr上打印了uptime的系统调用情况,在stdout上打印命令的原始输出。strace -e open uptime 可以起到和grep open相同的作用。uptime只是格式化输出了/proc的内容。如果是脚本里想要uptime值,自己读取/proc/uptime或许更方便一些。

Load average

[root@localhost ~]# cat /proc/loadavg

0.00 0.01 0.05 2/374 40656

前三列没什么好说的,第四列是当前有多少个进程,和多少个进程处于running或者runable,最后一列是最新的被分配的pid。running的意思是,当前进程正在物理cpu上运行;runable的意思是,它在等系统给他分配cpu时间片。

[root@localhost ~]# sleep 10 &

[1] 40674

[root@localhost ~]# sleep 10 &

[2] 40675

[root@localhost ~]# sleep 10 &

[3] 40676

[root@localhost ~]# cat /proc/loadavg

0.00 0.01 0.05 2/375 40677

可以看到,每运行一次,pid就+1,cat /proc/loadavg最后一列值可以证明。

证明第四列是当前正在运行的进程数:

[root@localhost ~]# cat /proc/loadavg

0.05 0.04 0.05 2/374 40717

当前有两个进程在运行(其中一个是当前的cat,另一个是vmware的vm-tool进程)

[root@localhost ~]# cat /dev/urandom > /dev/null &

[1] 40718

[root@localhost ~]# cat /proc/loadavg

0.09 0.04 0.05 3/375 40719

创建一个无意义,但不断运行的进程(随机生产些数据,然后写入/dev/null),第四列 正在运行的进程数+1(另外两个运行中的进程和上面同理)。

load数量指进程状态处在 :正在运行、等待运行、和不可中断(后面对这个状态做解释)的进程数。load avg就是过去1min,5min,15min load数量的平均数,但这个解析是简化版本,其实并不太对。直接引用维基百科上的解释:

Mathematically speaking, all three values always average all the system load since the system started up. They all decay exponentially, but they decay at different speed. Hence, the 1-minute load average will add up 63% of the load from last minute, plus 37% of the load since start up excluding the last minute. Therefore, it's not technically accurate that the 1-minute load average only includes the last 60 seconds activity (since it still includes 37% activity from the past), but that includes mostly the last minute.

关于不可中断状态:

进程 struct task_struct

的 state 字段为TASK_UNINTERRUPTIBLE,进程陷入了不能被中断的阻塞操作,无视信号。 What is an uninterruptable process?

http://stackoverflow.com/questions/223644/what-is-an-uninterruptable-process

内核的某些处理流程是不能被打断的。如果响应异步信号,程序的执行流程中就会被插入一段用于处理异步信号的流程(这个插入的流程可能只存在于内核态,也可能延伸到用户态),于是原有的流程就被中断了

如果是单核cpu的话,loadavg是1(同一时间运行一个进程),就说明cpu利用率是100%。如果是双核cpu,loadavg为2(同一时间运行两个进程)说明cpu利用率是100%。htop左上角和nproc命令可以看系是几核cpu。

load数量包括了不可中断的进程数,但是处于这个状态的进程并不怎么影响cpu运行(可以认为不使用cpu时间)。所以从loadavg推断cpu使用率不太准,这也能解释一些为什么load很高,但是实际cpu使用率不高。

mpstat可以查看瞬时cpu使用情况,要安装sysstat(这是个牛逼的工具)。

[root@localhost ~]# yum install sysstat -y

[root@localhost ~]# mpstat 1

Linux 3.10.0-327.el7.x86_64 (localhost.virthost) 02/26/17 _x86_64_ (1 CPU)

17:38:41 CPU %usr %nice %sys %iowait %irq %soft %steal %guest %gnice %idle

17:38:42 all 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 100.00

17:38:43 all 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 100.00

^C

Average: all 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 100.00

进程

htop默认显示用户进程和用户线程。

shift+H打开关闭用户线程

shift+K打开关闭内核线程

F5显示进程继承关系(类似ps -f)

/proc//{pwd,exe,cmdline} 里包含了进程当前工作目录的链接,可执行程序的链接和命令行。可以通过读取procfs里的内容,从内核获取信息。

/proc//status 包含当前进程的许多信息(内存分配情况,父进程id等),uid指明了当前进程所属用户:

[root@localhost htop]# cat /proc/47937/status | grep Uid

Uid: 0 0 0 0

id 命令可以找到这个用户的相关信息。其实id也是读取/etc/passwd和/etc/group文件获取用户信息:

[root@localhost]# strace -e open id 0

...

open("/etc/nsswitch.conf", O_RDONLY|O_CLOEXEC) = 3

open("/lib64/libnss_files.so.2", O_RDONLY|O_CLOEXEC) = 3

open("/etc/passwd", O_RDONLY|O_CLOEXEC) = 3

open("/etc/group", O_RDONLY|O_CLOEXEC) = 3

uid=0(root) gid=0(root) groups=0(root)

+++ exited with 0 +++

为什么会去找/etc/passwd 呢?这个是读取了/etc/nsswitch.conf 配置。

[root@localhost htop]# cat /etc/nsswitch.conf

...

passwd: files sss

shadow: files sss

group: files sss

...

关于这个配置文件,可以参考这里:,总之就是/lib64/libnss_files.so 加载了这个文件,其他的一系列的name service和这个文件有关(比如dns),还可以配置成从ldap中获取用户名密码。

unix用户的密码保存在/etc/shadow:

[root@localhost]# cat /etc/shadow

root:$6$eS1H0Kk/$MPOOjZyuhc14tzBl.2O2VoLoXxkirzIdKKw41tP/cEjfEPe58VcQB3LLlGoJzuHRrE.WIjii9nalKWl/GJMoR/:17153:0:99999:7:::

第二列开头的$6$表示加密算法是sha512,后面紧接着是盐和盐+密码的hash。

用户运行可执行文件时,进程所属用户一般是当前用户自己,而不是可执行文件本身的属主(这点应该很好理解)。

使用sudo -u 运行程序可以切换进程属主。sudo权限在 /etc/sudoers配置,最好使用visudo编辑配置文件,它会对文件格式做验证。

/etc/passwd是非常敏感的文件,passwd在普通用户权限下运行,也能更改密码,说明passwd肯定是以root身份运行的,否则它没发修改passwd文件。当二进制程序有x权限后,可以设置setuid权限:

sudo chmod u+s /usr/bin/passwd

[root@localhost]# ls -l /usr/bin/passwd

-rwsr-xr-x. 1 root root 27832 Jun 10 2014 /usr/bin/passwd

这样,二进制文件运行时,进程属主就是二进制文件的属主。

其他的特殊权限还有sticky bit和setgid。下面的命令可以找到权限类似passwd这样的命令:

[root@localhost]# find /usr/bin -user root -perm -u+s

/usr/bin/chage

/usr/bin/gpasswd

/usr/bin/newgrp

/usr/bin/chfn

/usr/bin/chsh

/usr/bin/su

/usr/bin/sudo

/usr/bin/mount

/usr/bin/umount

/usr/bin/staprun

/usr/bin/crontab

/usr/bin/pkexec

/usr/bin/passwd

进程状态

R 在运行队列里

S 可中断的休眠(等待事件发生)

D 不可中断的休眠,发生页面错误时,发生的IO不可以被中断,进程此时不能处理信号,处理信号可能会造成另外一个页面错误。如果有太多进程处于这个状态,意味着有可能大量进程发生页面错误,也许应该看下swap。

Z 僵尸状态,子进程退出后,相关的资源已经释放,父进程应该在收到SIGCHL信号后D收尸,不应该把子进程随便乱扔。

T 被任务控制信号停止,ctrl+z终止后台进程可以看到这种状态。

t 被debugger停止(调试),gdb -p attach的进程,可以看到这个状态。

X 应该永远看不见

F9 htop 发送信号快捷键

可以制造一个处于uninterruptible状态的进程。使用NFS挂在远程目录的时候,如果远程目录不存在,进程就会被挂起。我们使用google的DNS 8.8.8.8 试试,因为它没有打开NFS:

[root@localhost ~]# mount 8.8.8.8:/tmp /tmp &

[1] 48642

[root@localhost ~]# ps aux | grep mount

root 48642 0.0 0.0 125628 924 pts/1 S 22:03 0:00 mount 8.8.8.8:/tmp /tmp

root 48643 0.0 0.1 42468 1608 pts/1 D 22:03 0:00 /sbin/mount.nfs 8.8.8.8:/tmp /tmp -o rw

root 48645 0.0 0.0 112616 700 pts/1 R+ 22:03 0:00 grep --color=auto mount

使用strace看看它到底在哪个调用上挂起了:

[root@localhost ~]# sudo strace /sbin/mount.nfs 8.8.8.8:/tmp /tmp -o rw

...

mount("8.8.8.8:/tmp", "/tmp", "nfs", 0, "vers=4,addr=8.8.8.8,clientaddr=1"...

进程运行的时间

linux的时间片大约在几毫秒(搞清楚linux上时间片到底多长也挺有意思的)。loadavg在单核机器上小于1,意味这cpu在过去一段时间什么事情都没做。

进程优先级

NI 用户空间优先级,最低-20到最高19。经验是升一级优先级通常可以获得10%的更多cpu时间。

PRI 内核空间优先级,0-139。0-99是实时优先级,100-139才是给用户进程用的,这映射到用户优先级的-20到19。

内存

编写用户空间的程序员或者程序,会感觉自己的程序拥有全部内存,这是幻觉。

用户态程序不会直接访问物理内存,只能访问虚拟内存空间,内核会把虚拟地址映射到物理内存或者磁盘上。

htop/top内存的含义:

VIRT/VSZ 虚拟内存,包括二进制的代码,数据,共享库,换出的页,映射了但是还没使用的页。

RES/RSS 进程实际在物理内存中的空间,不包括换出的内存,但是包括和其他进程共享的。

SHR 共享的内存

htop/top内存使用率是指RES/RSS内存占总物理内存的百分比。

nproc是什么意思_top/htop内容的含义相关推荐

  1. Cookie文件内容的含义

    以下是一个cookie文件中的一段内容 ------------------------------------------------------------------ logonTicket S ...

  2. MIT-BIN 心律失常数据库记录的头文件内容和含义

    用写字板 打开文件 100.hea,会显示下面的内容: 100 2 360 650000 100.dat 212 200 11 1024 995 -22131 0 MLII 100.dat 212 2 ...

  3. 西门子变频器操作面板所显示内容的含义分析

    西门子变频器主要是由整流.滤波.逆变.制动单元.驱动单元.检测单元微处理单元等组成.它是应用变频技术与微电子技术,通过改变电机工作电源频率方式来控制交流电动机的电力控制设备. 西门子变频器故障结果表明 ...

  4. 提升用户体验的根本是内容

    经常听到很多站长讲自己的网站外链有多少多少,收录有多高.快照当天更新等等,然后回头客,以及浏览深度却少得可伶.现在有很多学习SEO的网站,然后当你真正进入网站一看,马上就想出来.通过堆叠关键字的方式来 ...

  5. CSS核心内容整理 - (中)

    2019独角兽企业重金招聘Python工程师标准>>> 本文是CSS核心内容整理的第二篇,承接上一篇的内容继续对CSS的一些重要内容进行整理,推荐先看完这个系列的上一篇. 四.  页 ...

  6. 增值税发票二维码内容字段解析

    最近在做一个小程序项目读取增值税发票二维码信息并落库,网上搜罗了一下发票二维码中包含的信息,结合如下具体实例,简单阐述下发票二维码中的字段意义. 现在又出来了一种区块链电子发票: 点这里 通过微信小程 ...

  7. 编写autorun.inf autorun.inf完整内容

    autorun.inf 是我们电脑使用中比较常见的文件之一 ,其作用是允许在双击磁盘时自动运行指定的某个文件.但是近几年出现了用autorun.inf文件传播木马或病毒,它通过使用者的误操作让目标程序 ...

  8. linux命令行前面内容修改

    首先我们来认识一下linux命令行前面内容的含义,比如: root@ubuntu6:~# 符号 含义 root 表示当前登录的用户 @ 是一个分隔符号 ubuntu6 表示你的主机名 ~ 表示你当前所 ...

  9. 数据分析与可视化内容整理

    数据分析是基于商业目的,有目的的进行收集.整理.加工和分析数据,提炼有价信息的一个过程.其过程概括起来主要包括:明确分析目的与框架.数据收集.数据处理.数据分析.数据展现和撰写报告等6个阶段. 1.明 ...

最新文章

  1. mysql触发器学习的一个小错误
  2. 蓄电池单格电压多少伏_蓄电池充电规范手册
  3. OpenAL跨平台音效API的安装与移植
  4. MySQL内核调试_内核调试技巧
  5. JavaScript 中的 this
  6. 使用tmpfs的好处
  7. 前端实现序列帧_最简单的序列帧动画canvas插件
  8. 关于利用DEM生成水系图
  9. CSDN-Markdown语法集锦
  10. Nuvoton M031-时钟树
  11. testerhome学习笔记1_互联网测试技术
  12. Linux【问题记录 05】阿里云+腾讯云服务器挖矿木马 kthreaddk 处理记录+云服务器使用建议
  13. SX1278性能评估
  14. 什么是值传递,什么是引用传递
  15. 这三种人不适合“裸辞”!
  16. 通过TMG发布ActiveSync
  17. 博弈论第一章 完全信息静态博弈
  18. 【案例6】NC安装部署常见问题
  19. 北京超声刀治疗痘印有效吗
  20. 兔耳冲天闹元宵 非遗传承在韦桑 ——二七街道韦桑社区举办欢庆元宵节活动

热门文章

  1. java堆内与堆外数据交互_Java:汇总堆外数据
  2. zip unzip_zip和unzip上的Java要点
  3. pcl_openmap_OpenMap教程3 –使用MapHandler构建基本的地图应用程序–第2部分
  4. jooq_jOOQ与Hibernate:何时选择哪个
  5. camel java_与Java EE和Camel的轻量级集成
  6. 硒测试可实现有效的测试自动化
  7. 使用React Native和Spring Boot构建一个移动应用
  8. Java 8日期和时间
  9. epyc rome_使用Encog,ROME,JSoup和Google Guava进行博客分类
  10. Oracle JDBC中的PreparedStatement占位符过多