Linux运维基础进程管理实时监控控制
程序员文章站
2022-06-28 23:25:12
目录1.后台运行作业2.使用信号控制进程基本进程管理信号3.监控进程活动io负载4.实时进程监控top用于实现全屏动态显示系统信息1.后台运行作业1.sleep 999 & (运行作业)[ro...
1.后台运行作业
1.sleep 999 & (运行作业) [root@localhost ~]# sleep 999 & [1] 3670 2.ps -ef|grep sleep(查看进程) [root@localhost ~]# ps -ef|grep sleep root 3670 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3671 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3672 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3673 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3674 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3675 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3676 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3677 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3678 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3686 950 0 10:54 ? 00:00:00 sleep 60 3.fg(调最后一个) [root@localhost ~]# fg sleep 999 4.jobs(查看任务) [root@localhost ~]# jobs [1] sleep 999 & [3] sleep 999 & [4] sleep 999 & [6]- sleep 999 & [7]+ sleep 999 ctr1+z(done)完成 5.说明 fg %n (调指定的任务) stopped(停滞状态) bg %3 (运行状态) +(默认操作的) -(第二个操作的)
2.使用信号控制进程
基本进程管理信号
信号编号id | 短名称 | 定义名 | 用途 |
---|---|---|---|
1 | hup | 挂起 | 让一个进程不用重启就可以重读配置文件,并让新的配置信息生效 |
2 | int | 键盘中断 | 中断一个前台进程。ctrl+c就是用的sigint信号 |
9 | kill | 中断,无法拦截 | 导致立即终止程序。无法被拦截、忽略或处理 |
15默认值 | term | 终止 | 导致程序终止。和sigkill不同,可以被拦截、忽略或处理。要求程序终止的友好方式,允许自我清理 |
kill命令根据id向进程发送信号。虽其名称为kill,但该命令可用于发送任何信号,而不仅仅是终止程序的信号
1.查看进程 [root@localhost ~]# ps -ef|grep sleep root 3670 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3672 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3673 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3675 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3676 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3901 950 0 10:59 ? 00:00:00 sleep 60 root 3904 3642 0 10:59 pts/1 00:00:00 grep --color=auto sleep 2.删除指定任务 [root@localhost ~]# kill %1 [root@localhost ~]# ps -ef|grep sleep root 3672 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3673 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3675 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3676 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3901 950 0 10:59 ? 00:00:00 sleep 60 root 3906 3642 0 11:00 pts/1 00:00:00 grep --color=auto sleep [1] sleep 999 3.kill -l(列出所有可以支持的程序) [root@localhost ~]# kill -l 1) sighup 2) sigint 3) sigquit 4) sigill 5) sigtrap 6) sigabrt 7) sigbus 8) sigfpe 9) sigkill 10) sigusr1 11) sigsegv 12) sigusr2 13) sigpipe 14) sigalrm 15) sigterm 16) sigstkflt 17) sigchld 18) sigcont 19) sigstop 20) sigtstp 21) sigttin 22) sigttou 23) sigurg 24) sigxcpu 25) sigxfsz 26) sigvtalrm 27) sigprof 28) sigwinch 29) sigio 30) sigpwr 31) sigsys 34) sigrtmin 35) sigrtmin+1 36) sigrtmin+2 37) sigrtmin+3 38) sigrtmin+4 39) sigrtmin+5 40) sigrtmin+6 41) sigrtmin+7 42) sigrtmin+8 43) sigrtmin+9 44) sigrtmin+10 45) sigrtmin+11 46) sigrtmin+12 47) sigrtmin+13 48) sigrtmin+14 49) sigrtmin+15 50) sigrtmax-14 51) sigrtmax-13 52) sigrtmax-12 53) sigrtmax-11 54) sigrtmax-10 55) sigrtmax-9 56) sigrtmax-8 57) sigrtmax-7 58) sigrtmax-6 59) sigrtmax-5 60) sigrtmax-4 61) sigrtmax-3 62) sigrtmax-2 63) sigrtmax-1 64) sigrtmax [root@localhost ~]# 4. kill 3672(删除进程) 查看进程 [root@localhost ~]# ps -ef|grep sleep root 3672 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3673 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3675 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3676 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3925 950 0 11:00 ? 00:00:00 sleep 60 root 4039 3642 0 11:00 pts/1 00:00:00 grep --color=auto sleep [root@localhost ~]# kill 3672 [root@localhost ~]# ps -ef|grep sleep root 3673 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3675 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3676 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3925 950 0 11:00 ? 00:00:00 sleep 60 root 4054 3642 0 11:01 pts/1 00:00:00 grep --color=auto sleep [3] sleep 99 5.killall sleep(删除所有sleep) 查看进程:[root@localhost ~]# ps -ef|grep sleep root 3673 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3675 3642 0 10:54 pts/1 00:00:00 sleep 999 root 3676 3642 0 10:54 pts/1 00:00:00 sleep 999 root 4164 950 0 11:01 ? 00:00:00 sleep 60 root 4174 3642 0 11:01 pts/1 00:00:00 grep --color=auto sleep 成功删除[root@localhost ~]# ps -ef|grep sleep root 4185 3642 0 11:02 pts/1 00:00:00 grep --color=auto sleep
3.监控进程活动
io负载
负载数属于全局计数器计算,是所有cpu的总和数。
由于从睡眠返回的任务可能会重新调度到不同的cpu,难以精确的每cpu计数,但累计数的准确度可以保障。
显示的平均负载代表所有的cpu。
显示负载值,实施监控
[root@localhost ~]# top
1.查看负载 [root@localhost ~]# uptime 11:12:36 up 45 min, 2 users, load average: 0.06, 0.01, 0.20 2.显示负载值,实施监控 [root@localhost ~]# top top - 11:15:03 up 47 min, 2 users, load average: 0.00, 0.00, 0.16 tasks: 328 total, 1 running, 327 sleeping, 0 stopped, 0 zombie %cpu(s): 0.0 us, 0.7 sy, 0.0 ni, 99.0 id, 0.0 wa, 0.3 hi, 0.0 si, 0.0 st mib mem : 804.8 total, 67.5 free, 474.7 used, 262.5 buff/cache mib swap: 2048.0 total, 1427.5 free, 620.5 used. 196.8 avail mem pid user pr ni virt res shr s %cpu %mem time+ command 3884 root 20 0 0 0 0 i 0.3 0.0 0:00.57 kworker+ 4404 root 20 0 64856 4880 4008 r 0.3 0.6 0:00.17 top 1 root 20 0 245372 7252 4356 s 0.0 0.9 0:03.43 systemd 2 root 20 0 0 0 0 s 0.0 0.0 0:00.00 kthreadd 3 root 0 -20 0 0 0 i 0.0 0.0 0:00.00 rcu_gp 4 root 0 -20 0 0 0 i 0.0 0.0 0:00.00 rcu_par+ 6 root 0 -20 0 0 0 i 0.0 0.0 0:00.00 kworker+ 8 root 0 -20 0 0 0 i 0.0 0.0 0:00.00 mm_perc+ 9 root 20 0 0 0 0 s 0.0 0.0 0:00.24 ksoftir+ 10 root 20 0 0 0 0 i 0.0 0.0 0:00.35 rcu_sch+ 11 root rt 0 0 0 0 s 0.0 0.0 0:00.00 migrati+ 12 root rt 0 0 0 0 s 0.0 0.0 0:00.00 watchdo+ 13 root 20 0 0 0 0 s 0.0 0.0 0:00.00 cpuhp/0 15 root 20 0 0 0 0 s 0.0 0.0 0:00.00 kdevtmp+ 16 root 0 -20 0 0 0 i 0.0 0.0 0:00.00 netns 17 root 20 0 0 0 0 s 0.0 0.0 0:00.00 kauditd 18 root 20 0 0 0 0 s 0.0 0.0 0:00.00 khungta+ 说明按m t l [root@localhost ~]# top 不显示 按1 显示cpu信息
4.实时进程监控
top用于实现全屏动态显示系统信息
//top命令交互式子命令: m //根据驻留内存大小进行排序,默认根据cpu百分比排序 p //根据cpu使用百分比进行排序 t //根据累计时间(占据cpu时长)进行排序 l //是否显示平均负载和启动时间 t //是否显示进程和cpu状态相关信息 m //是否显示内存相关信息 c //是否显示完整的命令行信息 q //退出top命令 k //终止某个进程 1 //显示所有cpu的信息 s //修改刷新时间间隔 us //表示用户空间; sy //表示内核空间; ni //表示调整nice值,cpu占用的比率; id //表示空闲百分比; wa //表示等待io完成所占据的时间百分比; hi //表示hard interrupt,硬件中断占据的时间百分比; si //表示软中断占据的时间百分比; st //表示steal,被虚拟化技术偷走的时间(比如运行虚拟机) pr //优先级 ni //nice值 virt //虚拟内存集 res //常驻内存集 shr //共享内存大小 s //进程状态
以上就是linux运维基础进程管理实时监控控制的详细内容,更多关于linux运维进程的资料请关注其它相关文章!