Linux系统中的进程就相当于Windows的任务管理器,只是区别于任务管理器的是进程需要用命令来管理的。
程序
进程
进程是动态的,程序是静态的
程序是二进制文件,进程是程序运行的过程
有生命周期和运行状态
进程下面还有多个线程
ps -aux #以简单列表的形式显示出进程信息
-a:显示当前终端下的所有进程信息,包括其他用户的进程。与"x"选项结合时将显示系统中所有的进程信息
-u:使用以用户为主的格式输出进程信息
-x:显示当前用户在所有终端下的进程信息
STAT
D:系统守护进程
T: 调式、程序执行一般停止
R:该程序目前正在运作,或者是可被运作:
S:该程序目前正在睡眠当中(可说是idle状态啦!),但可被某些讯号(signal)唤醒。
T该程序目前正在侦测或者是停止了;
Z:该程序应该已经终止,但是其父程序却无法正常的终止他,造成zombie(疆尸)程序的状态D不可中断状态。
它们含意如下:
<:表示进程运行在高优先级上
N:表示进程运行在低优先级上
L:表示进程有页面锁定在内存中
s:表示进程是控制进程s:
l:表示进程是多线程的
+:表示当前进程运行在前台
D:系统守护进程
T:调式、程序执行一般停止
查看静态的进程统计信息
ps -elf #以长格式显示系统中的进程信息
常用参数
-e:显示系统内的所有进程信息
-l:使用长格式显示进程信息
-f:使用完整的格式显示进程信息
僵尸进程:
一个进程结束了,但是如果该进程的父进程已经先结束了,那么该进程就不会变成僵尸进程,因为每个进程结束的时候,系统都会扫描当前系统中所运行的所有进程,看有没有哪个进程是刚刚结束的这个进程的子进程,如果是的话,就由Init来接管它,成为它的父进程,子进程退出后init会回收其占用的相关资源。但是当子进程比父进程先结束,而父进程又没有回收子进程,释放子进程占用的资源,此时子进程将成为一个僵尸进程。
进程状态:
-D: 不可被唤醒的睡眠状态,通常用于I/o情况。
-R:该进程正在运行。
-S:该进程处于睡眠状态,可被唤醒。
-T:停止状态,可能是在后台暂停或进程处于除错状态。
-W:内存交互状态(从2.6内核开始无效)。
-X:死掉的进程(应该不会出现)。
-Z:僵尸进程。进程已经中止,但是部分程序还在内存当中。
-<:高优先级(以下状态在BSD格式中出现)。
-N:低优先级。
-L:被锁入内存。
-s:包含子进程。
-l:多线程(小写L)。
-+:位于后台。
-C:进程占用CPU的百分比
在top命令执行过程中可以使用的一些交互命令。这些命令都是单字母的,如果在命令行中使用了-s选项, 其中一些命令可能会被屏蔽。
需求:压力测试,查看CPU和内存的使用率
1、先top实时查看动态进程信息,压力测试前,查看cpu和内存使用率
2、模拟持续输入文件,测试CPU和内存的抗压能力
3、压力测试后,CPU和内存的使用率
4、找到CPU占用率较高的进程并终止(可以在top操作界面中按k键,然后在列表上方将会出现"PID to signal/kill [default pid =14195]:”的提示信息,根据提示输入指定进程的 PID 号并按 Enter 键,出现"send pid 14195signal [15/sigterm]"的二次确认的提示信息,然后按Enter键确认即可终止对应的进程。)
5、cpu和内存已占满,无法将/etc下的所有文件复制到/opt/lichen
6、查看,发现内存已占满
7、查看磁盘占用空间,寻找出问题文件夹(/opt/lichen)
8、删除问题文件
9、解决问题后,再次查看cpu和内存的使用率,恢复正常
小结:
Top动态查看系统进程使用情况,并用dd命令做压力测试,模拟内存使用率过高。查看内存使用率较高的进程的 pid号,则终止该进程,防止因内存过大造成系统崩溃。然后寻找问题原因,Top可以以动态的方式显示各进程的状态信息,当发现CPU和内存的使用率过高时,可能会对系统工作造成影响,所以我们要找出问题所在,并且解决问题。
pgrep命令
常用参数:
举例:
pstree命令
常用参数:
手工启动
调度启动
- 将当前进程挂起,即调入后台并停止执行
- 查看处于后台的任务列表
- 将后台进程恢复到前台运行,可指定任务序号
kill最常用的信号是:
1 (HUP):重新加载进程。
9 (KILL):杀死一个进程。
15 (TERM):正常停止一个进程。
kill值默认15
kill -3 杀死并退出进程
kill -9不正规,直接杀进程 kill -3是友好的杀死进程
kill -19和ctrl+z差不多 ,挂起并停止执行
举例:
1、查看sshd的进程PID,终止PID为9137的进程
2、杀死sshd的全部进程,此时要打开虚拟机,开启sshd,然后查看一下状态是active,机器就恢复正常了
at命令
使用at命令设置的计划任务只在指定的时间点执行一次,前提是对应的系统服务atd必须已经运行。需要注意的是,计划执行任务的时间、日期必须安排在当前系统的时刻之后,否则将无法正确设置计划任务。
设置一次性计划任务时,在at命令行中依次指定计划执行任务的时间、日期作为参数(若只指定时间则表示当天的该时间,若只指定日期则表示该日期的当前时间),确认后进入带"at>"提示符的任务编辑界面,每行设置一条执行命令,可以依次设置多条语句,后按Ctrl+组合键提交任务。所设置的命今操作将在计划的时间点被依次执行。例如,以下操作先通过date命令确认当前的系统时间,并设置在2017年5月7日的10:35自动执行以下任务:统计该时间点系统中由root
用户运行的进程的数量,并将该数值保存到/tmp/ps.root 文件中。
[root@localhost~]#at 21:30 #不跟年月日,表示使用当前日期
at> shutdown -h now
at> #在当天的21:30自动关闭当前系统
对于已经设置但还未执行(未到时间点)的计划任务,可以通过atq命令进行查询。但已执行过的at任务将不会再出现在列表中。
[root@localhost~]# atq #查看未执行的任务列表
[root@localhost~]# atrm 1 #删除第一条任务
举例:
1、设置2022年4月5号的10点13分,查询root用户的PID号并统计数量输出到/tmp/psroot.txt
2、设置10点16分,shutdown关机
3、设置10:18分删除/home/wangwu,用atq未执行任务列表,用atrm删除
举例:
查看全局配置文件
crontab守护进程会自动检查/etc/crontab文件、/etc/cron.d目录及/var/spool/cron/目录中的改变,如果发现配置有更改,它们会被载入内存,所以放某个crontab文件改变后并且不需要重新启动crond守护进程就可以设置生效。
编辑计划任务
crontab -e 【-u 用户名】 -u缺省时默认当前用户
查看计划任务
crontab -l 【-u 用户名】
删除计划任务
crontab -r 【-u 用户名】
时间数值的特殊表示方法
0 20 * * 1-5 周一到周五每天20点
30 8 * * 1,3,5 周一,周三,周五8.30
0 8-18/2 * * * 8点到18点每两小时
0 * */3 * * 每三天
* 8-10 * * 1,3,5 周一,周三,周五的8点到10点
1、每天晚上凌晨2点30分进行数据备份,把web源目录 /var/www/html/ 备份到/home/backup目录下,并且压缩备份
2、请每周1、3、5、7去查找/opt/spingcould目录下的所有.log文件,并且删除3天以外的文件。
首先,在创建/opt下创建spingcould目录,在spingcould里创建{1…5}.log文件。然后把时间设到4月11日,再查看
3、每天18 : 00至23 : 00之间每隔30 查看系统(messages)日志中是否有error报错,并且输出到 error.txt
首先,在/home里面创建error.txt,然后修改时间,查看error.txt
4、每月1、10、22日的4 : 45需要重启服务器系统
把时间设到2022-4-10 4:45分
我学会了四种查看进程命令的方式(ps、top、pgrep、pstree),还有进程的启动方式,包括启动进程、调度进程以及终止进程。知道如何用at命令和crontab命令来做计划任务管理,定期备份、检测、删除数据。