进程管理-Linux每日一练(6)
题目一:进程有哪几种状态(生命周期)?
平时学的是这五种状态新建、就绪、运行、阻塞、终止,但是在Linux里面可以查看到的要更加详细,如下命令的 STAT
列就是展示了状态
$ ps -aux
USER PID %CPU %MEM VSZ RSS TT STAT STARTED TIME COMMAND
root 981 7.3 0.0 4724748 2764 ?? S 五02下午 73:31.27 hexo
root 79519 0.0 0.0 4277540 728 s007 S+ 9:18下午 0:00.00 xxx
有很多状态,就看首字母,其他不用在意太多
R 运行 S 可中断睡眠 Sleep D 不可中断睡眠 (usually IO) T 停止的进程 Z 僵尸进程 X 死掉的进程
题目二:通过 ps
命令我们可以获取哪些关键信息?
ps
命令一般是用来查 pid
的,我们就可以通过 kill
的方式干掉进程,或者通过 pid
去读取 /proc
目录获取进程监控信息。
和 top
命令一样,使用 ps -aux
参数,可以看到进程的各种指标
USER: 运行进程的用户 PID: 进程 ID %CPU: CPU 占用率 %MEM: 内存占用率 VSZ: 占用虚拟内存 RSS: 占用实际内存 驻留内存 TTY: 进程运行的终端 STAT: 进程状态 man ps (/STATE) STARTED: 启动日期 TIME: 运行时间 COMMAND: 启动命令
当然,如果只是想查看下pid,可以直接 pgrep 进程名
$ pgrep sshd
10180
题目三:top
命令怎么根据 cpu
、 mem
排序?通过此命令我们还能获取哪些关键信息?
使用 uptime
可以查看机器负载情况
$ uptime
21:31 up 4 days, 6:54, 3 users, load averages: 3.54 3.27 3.02
使用 top
可以临时查看进程的实时使用情况
# 指定刷新时间间隔
$ top -d 1
# 查看指定进程的动态信息
$ top -p 10126
$ top -p 10126,1
# 查看指定用户的进程
$ top -u apache
# 将两次刷新写入文件中
$ top -d 1 -b -n 2 > top.txt
在使用命令的时候, 直接在终端输入下面字符有奇效,临时发现占用问题很管用
h|? 帮助
M 按内存的使用排序
P 按 CPU 使用排序
N 以 PID 的大小排序
R 对排序进行反转
f 自定义显示字段
1 显示所有 CPU 的负载
< 向前
> 向后
z 彩色
W 保存 top 环境设置 ~/.toprc
当然,这个命令临时查看某台机器的某个进程是Ok的,但是无法查看趋势,也没办法批量查看多台服务器,我推荐使用今天发文的10个开源监控组件把服务器监控起来。
题目四:怎么让进程在后台运行?怎么让后台运行的进程切换到前台?
这一题讲的是作业控制 job
,我们可以通过他灵活的让进程在前后台切换、暂停.
我在此处用 sleep
命令来举例, sleep
的作用就是运行一个进程,然后等到一段时间,在这里用来测试进程前后台切换再合适不过。
要了解作业控制之前,先要知道前后台是什么概念,前台运行一个进程,会等待交互,会卡住命令行终端,除非你使用 ctrl+c
终止,或者 ctrl+z
暂停
$ sleep 5
# 鼠标在此闪烁,5秒之内啥也干不了
# 用ctrl+c 以后会终止进程,打印一个^C
$ sleep 5
^C
# 用ctrl+z以后会暂停进程
$ sleep 5
^Z
[1]+ Stopped sleep 5
暂停的进程上第一题的命令查看状态,状态是 T
,如果忘了是啥意思滑上去看看。
$ ps -aux |grep sleep
root 29196 0.0 0.0 107952 356 pts/0 T 21:45 0:00 sleep 5
用 jobs
命令也可以看到后台进程情况,暂停也算是切换到后台运行了,下面的输出是一个
$ jobs
[1]+ Stopped sleep 5
可以看到 [1]
,代表他的标号是1, 尝试把他调度到前台运行,会卡那直到运行完
$ fg %1
sleep 5
怎么创建一个进程让他直接在后台运行?只需要在结尾用一个 &
符号
$ sleep 100 &
[1] 29932
$ jobs
[1]+ Running sleep 100 &
要暂停后台运行的进程得先调到前台,再用 ctrl+z
$ fg %1
sleep 100
^Z
[1]+ Stopped sleep 100
$ jobs
[1]+ Stopped sleep 100
让暂停的进程直接切换到后台运行
$ bg %1
[1]+ sleep 100 &
$ jobs
[1]+ Running sleep 100 &
注意: 我以前在用 curl
命令的时候会忘记给 url
加引号,如果是一个GET请求,有参数的话,一般是下面这种形式,参数分隔符会被误认为是后台进程执行符号!
http://127.0.0.1/query?name=coding3min&passwd=abc
最后进程管理中,怎么干掉一个进程就不必说了吧~,可以发送信号,也可以直接干掉,最好是通过守护进程干掉他。
拓展知识点:守护进程
最不想遇到的事就是进程挂掉,一个告警电话打过来,半夜两三点爬起来就为了手动启动一个进程。所以进程自动拉起是很重要的。
一般用用 systemctl
、 supervisorctl
或者自己写个 crontab
定时任务、上 k8s
也可以,简单点的 docker-compose
也可以。
k8s
不仅支持进程自动拉起,还可以维护多副本,配置好一定数量的副本,挂掉一个会自动恢复,甚至里面的 HPA
支持负载均衡,可以根据你的进程占用情况自动增减副本数量。
进行守护如果想耍流氓,怎么杀也杀不掉,那就做成进程互相拉起,写到代码里,比如 360-A
进程挂了, 360-B
进程拉起来, 360-B
挂了 360-A
拉起来(对,我就是在黑360)
下次主题:管道与重定向
题目一:>
和 >>
有什么区别?题目二:重定向怎么把错误输出和正确输出分离开?题目三:怎么快速把一个非常大的文本文件清理掉?题目四:使用管道完成,组合 ps
、 grep
、 awk
、 xargs
、 kill
命令为一行命令,干掉名为 apache
的进程
下次的问题非常的简单,有时间就做做,如果我发现下次分析的时候内容太少了,我就把下下次的多写一点。