【Linux系列-1】top命令详解,一文带你搞懂Linux运维多线程Handler

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Linux运维全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上运维知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注运维)
img

正文

  • 50.3 us — 用户空间占用CPU的百分比。

  • 12.4 sy — 内核空间占用CPU的百分比。

  • 0.0 ni — 改变过优先级的进程占用CPU的百分比

  • 32.8 id — 空闲CPU百分比

  • 0.0% wa — IO等待占用CPU的百分比

  • 0.0 hi — 硬中断(Hardware IRQ)占用CPU的百分比

  • 4.5 si — 软中断(Software Interrupts)占用CPU的百分比

  • 0.0 st —(Steal Time)当 hypervisor 服务另一个虚拟处理器的时候,虚拟 CPU 等待实际 CPU 的时间的百分比

1.4 第四行



KiB Mem : 16267784 total,  5136976 free,  9050312 used,  2080496 buff/cache



第四行描述的是系统的内存使用情况(以kb为单位):

  • 16267784 total — 物理内存总量

  • 5136976 used — 使用中的内存总量

  • 9050312 free — 空闲内存总量

  • 2080496 buff/cache — 缓存的内存量

1.5 第五行



KiB Swap:  6160380 total,  6005320 free,   155060 used.  5676356 avail Mem 



第五行描述的是交换分区情况:

  • 6160380 total — 交换区总量

  • 155060 used — 使用的交换区总量

  • 6005320 free — 空闲交换区总量

  • 5676356 avail Mem — 可用的交换区总量

2 输出项目说明

===================================================================

在默认情况下,仅显示比较重要的 PIO、USERPR、NI、VIRT、RES、SHR、S、%CPU、%MEMTIME+、COMMAND列。

要想展示隐藏项,按 f 键进入选择界面,左侧有 * 号的表示该项是展示状态,通过方向键上下移动到某项,按 d 键可以改变该项的展示状态,然后按【ESC】或【q】键退出返回top界面。


* PID     = Process Id          

* USER    = Effective User Name 

* PR      = Priority            

* NI      = Nice Value          

* VIRT    = Virtual Image (KiB) 

* RES     = Resident Size (KiB) 

* SHR     = Shared Memory (KiB) 

* S       = Process Status      

* %CPU    = CPU Usage           

* %MEM    = Memory Usage (RES)  

* TIME+   = CPU Time, hundredths

* COMMAND = Command Name/Line   

  PPID    = Parent Process pid  

  UID     = Effective User Id   

  RUID    = Real User Id        

  RUSER   = Real User Name      

  SUID    = Saved User Id       

  SUSER   = Saved User Name     

  GID     = Group Id            

  GROUP   = Group Name          

  PGRP    = Process Group Id    

  TTY     = Controlling Tty     

  TPGID   = Tty Process Grp Id  

  SID     = Session Id          

  nTH     = Number of Threads   

  P       = Last Used Cpu (SMP) 

  TIME    = CPU Time            

  SWAP    = Swapped Size (KiB)  

  CODE    = Code Size (KiB)     

  DATA    = Data+Stack (KiB)    

  nMaj    = Major Page Faults   

  nMin    = Minor Page Faults   

  nDRT    = Dirty Pages Count   

  WCHAN   = Sleeping in Function

  Flags   = Task Flags <sched.h>

  CGROUPS = Control Groups      

  SUPGIDS = Supp Groups IDs     

  SUPGRPS = Supp Groups Names   

  TGID    = Thread Group Id     

  ENVIRON = Environment vars    

  vMj     = Major Faults delta  

  vMn     = Minor Faults delta  

  USED    = Res+Swap Size (KiB) 

  nsIPC   = IPC namespace Inode 

  nsMNT   = MNT namespace Inode 

  nsNET   = NET namespace Inode 

  nsPID   = PID namespace Inode 

  nsUSER  = USER namespace Inode

  nsUTS   = UTS namespace Inode 



各列的含义:

| 序号 | 列名 | 含义 |

| — | — | — |

| a | PID | 进程ID |

| b | PPID | 父进程ID |

| c | RUSER | 真实用户名 |

| d | UID | 进程所有者的用户id |

| e | USER | 进程所有者的用户名 |

| f | GROUP | 进程所有者的组名 |

| g | TTY | 启动进程的终端名。不是从终端启动的进程则显示为 ? |

| h | PR | 优先级 |

| i | NI | nice值。负值表示高优先级,正值表示低优先级 |

| j | P | 最后使用的CPU,仅在多CPU环境下有意义 |

| k | %CPU | 上次更新到现在的CPU时间占用百分比 |

| l | TIME | 进程使用的CPU时间总计,单位秒 |

| m | TIME+ | 进程使用的CPU时间总计,单位1/100秒 |

| n | %MEM | 进程使用的物理内存百分比 |

| o | VIRT | 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES |

| p | SWAP | 进程使用的虚拟内存中,被换出的大小,单位kb。 |

| q | RES | 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA |

| r | CODE | 可执行代码占用的物理内存大小,单位kb |

| s | DATA | 可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb |

| t | SHR | 共享内存大小,单位kb |

| u | nFLT | 页面错误次数 |

| v | nDRT | 最后一次写入到现在,被修改过的页面数。 |

| w | S | 进程状态:D=不可中断的睡眠状态,R=运行,S=睡眠,T=跟踪/停止,Z=僵尸进程 |

| x | COMMAND | 命令名/命令行 |

| y | WCHAN | 若该进程在睡眠,则显示睡眠中的系统函数名 |

| z | Flags | 任务标志,参考 sched.h |

3 命令参数

=================================================================

top命令可以后缀不同的参数,从而实现特定目的。

3.1 参数详解


  1. -b 批次模式运行,通常用来将top的输出结果传送给其他程式或储存成文件。

  2. -d 指定每两次屏幕信息刷新之间的时间间隔。可以使用s交互命令来改变之。

  3. -p 监控指定进程。监控多个进程时,进程ID之间以逗号分隔,只能在命令行下使用。

  4. -q 该选项将使top没有任何延迟的进行刷新。如果调用程序有超级用户权限,那么top将以尽可能高的优先级运行。

  5. -S 指定累计模式

  6. -s 使top命令在安全模式中运行。这将去除交互命令所带来的潜在危险。

  7. -i 使top不显示任何闲置或者僵死进程。

  8. -c 显示整个命令行而不只是显示命令名

  9. -n top命令运行n次,一般与-b搭配使用

  10. -H 显示线程,当这个设定开启时, 将显示所有进程产生的线程。

  11. -I 显示空闲的进程。

为了做好运维面试路上的助攻手,特整理了上百道 【运维技术栈面试题集锦】 ,让你面试不慌心不跳,高薪offer怀里抱!

这次整理的面试题,小到shell、MySQL,大到K8s等云原生技术栈,不仅适合运维新人入行面试需要,还适用于想提升进阶跳槽加薪的运维朋友。

本份面试集锦涵盖了

  • 174 道运维工程师面试题
  • 128道k8s面试题
  • 108道shell脚本面试题
  • 200道Linux面试题
  • 51道docker面试题
  • 35道Jenkis面试题
  • 78道MongoDB面试题
  • 17道ansible面试题
  • 60道dubbo面试题
  • 53道kafka面试
  • 18道mysql面试题
  • 40道nginx面试题
  • 77道redis面试题
  • 28道zookeeper

总计 1000+ 道面试题, 内容 又全含金量又高

  • 174道运维工程师面试题

1、什么是运维?

2、在工作中,运维人员经常需要跟运营人员打交道,请问运营人员是做什么工作的?

3、现在给你三百台服务器,你怎么对他们进行管理?

4、简述raid0 raid1raid5二种工作模式的工作原理及特点

5、LVS、Nginx、HAproxy有什么区别?工作中你怎么选择?

6、Squid、Varinsh和Nginx有什么区别,工作中你怎么选择?

7、Tomcat和Resin有什么区别,工作中你怎么选择?

8、什么是中间件?什么是jdk?

9、讲述一下Tomcat8005、8009、8080三个端口的含义?

10、什么叫CDN?

11、什么叫网站灰度发布?

12、简述DNS进行域名解析的过程?

13、RabbitMQ是什么东西?

14、讲一下Keepalived的工作原理?

15、讲述一下LVS三种模式的工作过程?

16、mysql的innodb如何定位锁问题,mysql如何减少主从复制延迟?

17、如何重置mysql root密码?

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注运维)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
Q是什么东西?

14、讲一下Keepalived的工作原理?

15、讲述一下LVS三种模式的工作过程?

16、mysql的innodb如何定位锁问题,mysql如何减少主从复制延迟?

17、如何重置mysql root密码?

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注运维)
[外链图片转存中…(img-CXNcb2zV-1713198240763)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 23
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux中,可以使用多线程来实现定时器功能。一种常见的方法是使用`timer_create`函数创建一个定时器对象,然后使用`timer_settime`函数来设置定时器的触发时间和间隔。在定时器触发时,系统会发送一个信号给指定的线程,该线程可以在信号处理函数中执行相应的操作。 以下是一个简单的示例代码,演示了如何在多线程中使用定时器: ```c #include <stdio.h> #include <stdlib.h> #include <signal.h> #include <unistd.h> #include <pthread.h> #include <time.h> #define TIMER_INTERVAL_SEC 1 void timer_handler(int sig) { // 定时器触发时执行的操作 printf("Timer expired\n"); } void* thread_func(void* arg) { // 创建定时器 timer_t timer; struct sigevent sev; struct itimerspec its; sev.sigev_notify = SIGEV_SIGNAL; sev.sigev_signo = SIGALRM; sev.sigev_value.sival_ptr = &timer; timer_create(CLOCK_REALTIME, &sev, &timer); // 设置定时器的触发时间和间隔 its.it_value.tv_sec = TIMER_INTERVAL_SEC; its.it_value.tv_nsec = 0; its.it_interval.tv_sec = TIMER_INTERVAL_SEC; its.it_interval.tv_nsec = 0; timer_settime(timer, 0, &its, NULL); // 等待定时器触发 while (1) { sleep(1); } return NULL; } int main() { pthread_t thread; // 创建线程 pthread_create(&thread, NULL, thread_func, NULL); // 等待线程结束 pthread_join(thread, NULL); return 0; } ``` 在上面的代码中,主线程创建了一个子线程,并在子线程中创建了一个定时器。定时器的触发时间被设置为1秒,当定时器触发时,会执行`timer_handler`函数中的操作。主线程使用`pthread_join`函数等待子线程结束。 请注意,上述示例中的代码仅供参考,并未处理一些潜在的错误情况。在实际应用中,您可能需要添加适当的错误处理和线程同步机制以确保程序的正确性和可靠性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值