目录
一、程序和进程的关系
程序
进程
二、查看进程信息ps(静态)
方法一:ps aux
方法二:ps -elf
三、查看进程信息top(动态)
每行对应的信息
四、进程信息区各列解释
五、查看进程信息pgrep
六、查看进程树pstree
七、进程的启动方式
手工启动
调度启动
进程的前后台调度
八、终止进程的运行
pkill
九、计划任务管理at
十、计划任务管理crontab(重点)
1、管理crontab计划任务
2、crontab任务配置的格式
3、时间数值的特殊表示方法
ps命令——查看静态的进程统计信息
注: ps aux | wc -l #查看当前进程的运行数量
各列的解释:
(1)USER:进程的用户。
(2)PID:进程的ID。
(3)%CPU:进程占用的CPU百分比。
(4)%MEM:占用内存的百分比。
(5)VSZ:该进程使用的虚拟内存量(KB)。
(6)RSS:该进程占用的物理内存量(KB)。
(7)TTY:启动进程的终端名。不是从终端启动的进程则显示为 ?
(8)STAT:该行程的状态:
D:不可中断的休眠状态;R:正在运行状态;S:处于休眠状态,可被唤醒;T:停止状态,可能是在后台暂停或进程处于跟踪 调试状态;Z:僵尸进程,进程已经中止,但是部分程序还在内存当中
(9)START:该进程被触发启动时间。
(10)TIME:该进程实际使用CPU运行的时间。
(11)COMMAND:进程的启动命令。
各列的解释:
(1)F:内核分配给进程的系统标记。
(2)S:进程的状态。
(3)UID:启动这些进程的用户。
(4)PID:进程的进程ID。
(5)PPID:父进程的进程号(如果该进程是由另一个进程启动的)。
(6)C:进程生命周期中的CPU利用率。
(7)PRI:进程的优先级(越大的数字代表越低的优先级)。
(8)NI:谦让度值用来参与决定优先级。
(9)ADDR:进程的内存地址。
(10)SZ:假如进程被换出,所需交换空间的大致大小。
(11)WCHAN:若该进程在睡眠,则显示睡眠中的系统函数名。
(12)STIME:进程启动时的系统时间。
(13)TTY:进程启动时的终端设备。
(14)TIME:运行进程需要的累计CPU时间。
(15)CMD:进程的启动命令。
僵尸进程:
一个进程结束了,但是如果该进程的父进程已经结束了,那么该进程就不会变成僵尸进程,因为每个进程结束的时候,系统都会扫描当前的系统中所运行的所有进程,看有没有哪个进程是刚刚结束的这个进程的子进程,如果是的话,就有Init来接管它,成为它的父进程,子进程退出后init会回收其占用的相关资源。
(但是子进程比父进程先结束,而父进程又没有回收子进程,释放子进程占用的资源,此时子进程将成为一个僵尸进程。)
第一行为任务队列信息
第二行为进程信息
第三行为CPU的信息
第四行为内存的信息
第五行为交换空间的信息
进程信息区各列解释:
top常用命令
补充: w、uptime 都是用来查看CPU的负载情况
pgrep命令
根据特定条件查询进程PID信息
pgrep -l "进程关键字" #指定查看进程名
例:pgrep -l “进程关键字”
1、在1centos7-1中输入vim /etc/fstab
2、再复制一个会话,来查看当前centos7-1虚拟机的进程信息
3、进入复制会话2centos7-1中,使用pgrep -l "vim"查询关键字vim的进程
pgrep可用选项
pgrep -l "进程关键字" -U #指定特定用户 pgrep -l "进程关键字" -t #指定终端 使用较少
例:grep -l -U
1、在1centos7-1中创建一个新用户admin,并给与他密码,让他能够使用,再切换至用户admin,输入vim /etc/fstab
2、我们再进入复制会话中查询这台虚拟机现在的进程,但是这次指定用户,指定admin
pstree命令
以树形结构列出进程信息
pstree -aup 用户名 #以树形结构完整列出对应用户名及进程号
-a:显示完整信息
-u:列出对应用户名
-p:列出对应PID号
例:
1、先在1centos7-1中使用admin用户创建一个文件,并进入编辑
2、再进入复制会话中去以树形结构完整列出用户admin的进程号,进程名称
例:多用于让后台自己去运行,我们无需跟踪它的状态,好了之后进行查询确认无误后使用即可
1、进行一个实验,使用本地磁盘cdrom内部的文件,要使用磁盘,首先挂载,然后我们人性化统计一下/mnt目录内部空间占用情况,发现4.3G,已经很大了,然后我们,复制/mnt目录包括目录下所有文件到/opt目录中,可以看到因为非常大,需要等待,我们已经无法继续操作了
2、遇到这种情况,有两个解决方法,一是复制会话,再继续操作,二就是让它在后台自己慢慢运行
3、使用静态查询进程状态配合管道符号筛选进程号,来看该进程状态
1.Ctrl+z组合键
将当前程序挂起,即调入后台并停止执行
2.jobs命令
jobs 【-l】
查看处于后台的任务列表
3.fg命令
将后台进程恢复到前台运行,可指定任务序号
ctrl c、kill、killall
ctrl+c组合键 (中断正在执行的命令)
kill、killall命令
kill -9 2010和kill -9 2028在下图中就不示范了,很简单,kill -9 + 进程号
根据特定条件终止相应的进程
常用命令选项
-U:根据进程所属的用户名终止相应进程
-t:根据进程所在的终端终止相应程序
1、首先在1centos7-1上切换到用户lisi
2、再在复制会话中将lisi用户的进程杀掉,导致bash进程被杀掉,shell解释器也没有了
at命令
一次性计划任务
at 【HH:MM】【yyyy-mm-dd】
命令格式
[root@localhost~]#at 21:30 #不跟年月日,表示使用当前日期 at> shutdown -h now ctrl d #提交一次性计划任务 at> <EOT> job 2 at Sun May 7 21:30:00 2017 [root@localhost~]# atq #查看未执行的任务列表 [root@localhost~]# atrm 1 #删除第一条任务
全局配置文件,位于文件:/etc/crontab
系统默认的设置,位于目录:/etc/cron.*/
用户定义的设置,位于文件:/var/spool/cron/用户名
●编辑计划任务
crontab -e 【-u 用户名】 -u缺省时默认当前用户
●查看计划任务
crontab -l 【-u 用户名】
●删除计划任务
crontab -r 【-u 用户名】
代表意义 | 分钟 | 小时 | 日期 | 月份 | 周 | 命令 |
数字范围 | 0~59 | 0~23 | 1~31 | 1~12 | 0~7 | 需要执行的命令 |
周的数字为 0 或 7 时,都代表“星期天”的意思。
*表示该范围内的任意时间
,表示间隔的多个不连续时间点
-表示一个连续的时间范围
/表示间隔的时间频率
示例:
0 17 * * 1-5 周一到周五每天17点 30 8 * * 1,3,5 周一,周三,周五8.30 0 8-18/2 * * * 8点到18点每两小时 0 * */3 * * 每三天
crontab -e [-u root] 编辑一个计划任务
1.每分钟定时执行一次规则:
每1分钟执行: */1 * * * *或者* * * * * 每5分钟执行: */5 * * * *
2.每小时定时执行一次规则:
每小时执行: 0 * * * *或者0 */1 * * * 每天上午7点执行:0 7 * * * 每天上午7点10分执行:10 7 * * *
3.每天定时执行一次规则:
每天执行 0 0 * * *
4.每周定时执行一次规则:
每周执行 0 0 * * 0
5.每月定时执行一次规则:
每月执行 0 0 1 * *
6.每年定时执行一次规则:
每年执行 0 0 1 1 *
示例:
5 * * * * ls 指定每小时的第5分钟执行一次ls命令 30 5 * * * ls 指定每天的 5:30 执行ls命令 30 7 8 * * ls 指定每月8号的7:30分执行ls命令 30 5 8 6 * ls 指定每年的6月8日5:30执行ls命令 30 6 * * 0 ls 指定每星期日的6:30执行ls命令[注:0表示星期天,1表示星期1,以此类推,也可以用英文来表示,sun表示星期天,mon表示星期一等。] 30 3 10,20 * * ls 每月10号及20号的3:30执行ls命令[注:“,”用来连接多个不连续的时段] 25 8-11 * * * ls 每天8-11点的第25分钟执行ls命令[注:“-”用来连接连续的时段] */15 * * * * ls 每15分钟执行一次ls命令 [即每个小时的第0 15 30 45 60分钟执行ls命令 ] 30 6 */10 * * ls 每个月中,每隔10天6:30执行一次ls命令[即每月的1、11、21、31日是的6:30执行一次ls命令。 ]