Linux系统中的进程和计划任务管理

目录

引言

一、查看进程

1、程序和进程的关系

2、查看静态的进程统计信息—ps命令

3、查看动态的进程排名信息—top命令

4、根据特定条件查询进程PID信息—pgrep命令

5、以树形结构列出进程信息—pstree命令

二、控制进程

1、手动启动

2、调度启动

3、进程的前后台调度

4、终止进程的运行

三、计划任务管理

1、一次性计划任务—at命令

2、周期性任务设置—crontab命令

总结


引言

每当运行Linux操作系统时,程序会被加载到内存当中运行,程序可以多个进程,如何去控制系统服务以及优化系统服务,操作系统上的数据都是以进程的形态存在,怎么去管理好进程,以及优化好执行的计划任务,是必不可少的,下面就是进程和计划任务管理的相关技术。

一、查看进程

1、程序和进程的关系

①程序:保存在硬盘、光盘等介质中的可执行代码和数据;静态保存的代码

②执行进程:在CPU及内存中运行的程序代码;动态执行的代码;父、子进程;每个程序可以创建一个或多个进程。

2、查看静态的进程统计信息—ps命令

①常用的参数

参数

含义

-a

显示当前终端下的所有进程信息,包括其他用户的进程。与"x"选项结合时将显示系统中所有的进程信息。

-u

使用以用户为主的格式输出进程信息。

-x

显示当前用户在所有终端下的进程信息。

-e

示系统内的所有进程信息。

-l

使用长格式显示进程信息。

-f

使用完整的格式显示进程信息。

②ps -aux(将以简单列表的形式显示出进程信)

[root@localhost ~]# ps aux
USER        PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root          1  1.6  0.1 191408  4424 ?        Ss   14:47   0:01 /usr/lib/systemd/system
root          2  0.0  0.0      0     0 ?        S    14:47   0:00 [kthreadd]
root          3  0.0  0.0      0     0 ?        S    14:47   0:00 [ksoftirqd/0]
root          4  0.0  0.0      0     0 ?        S    14:47   0:00 [kworker/0:0]
root          5  0.0  0.0      0     0 ?        S<   14:47   0:00 [kworker/0:0H]
root          6  0.0  0.0      0     0 ?        S    14:47   0:00 [kworker/u256:0]
root          7  0.0  0.0      0     0 ?        S    14:47   0:00 [migration/0]
root          8  0.0  0.0      0     0 ?        S    14:47   0:00 [rcu_bh]
root          9  0.1  0.0      0     0 ?        S    14:47   0:00 [rcu_sched]
root         10  0.0  0.0      0     0 ?        S<   14:47   0:00 [lru-add-drain]

上述输出信息中,第一行为列表标题,其中各字段的含义描述如下:

字段

含义

字段

含义

USER

启动该进程的用户账号的名称。

PID

该进程在系统中的数字ID号,在当前系统中是唯一的。

%CPU

CPU占用的百分比。

%MEM

内存占用的百分比。

VSZ

该进程使用的虚拟内存量(KB)。

RSS

该进程占用的物理内存量(KB)。

TTY

表明该进程在哪个终端上运行。不是从终端启动的进程则显示为?。

STAT

该进程的状态(D:不可中断的休眠状态:R:正在运行状态;s:处于休眠状态,可被唤醒;r:停止状态,可能是在后台暂停或进程处于跟踪调试状态:z:僵尸进程,进程已经中止,但是部分程序还在内存当中;+:前台运行)。

START

启动该进程的时间。

TIME

该进程占用的 CPU 时间。

COMMAND

启动该进程的命令的名称

僵尸进程
俗话:父进程退出子进程没有退出  那么这些子进程就没有父进程来管理了,就变成了僵尸进程。
专业话:一个进程结束了,但是如果该进程的父进程已经先结束了,那么该进程就不会变成僵尸进程,因为每个进程结束的时候,系统都会扫描当前系统中所运行的所有进程,看有没有哪个进程是刚刚结束的这个进程的子进程,如果是的话,就由Init来接管它,成为它的父进程,子进程退出后init会回收其占用的相关资源。但是当子进程比父进程先结束,而父进程又没有回收子进程,释放子进程占用的资源,此时子进程将成为一个僵尸进程。

进程状态,常见的状态有以下几种:

状态

含义

状态

含义

-D

不可被唤醒的睡眠状态,通常用于I/O情况。

-R

该进程正在运行。

-S

该进程处于睡眠状态,可被唤醒。

-T

停止状态,可能是在后台暂停或进程处于除错状态。

-W

内存交互状态(从2.6内核开始无效)。

-X

死掉的进程(应该不会出现)。

-Z

僵尸进程。进程已经中止,但是部分程序还在内存当中。

-<

高优先级(以下状态在 BSD 格式中出现)。

-N

低优先级。

-L

被锁入内存。

-s

包含子进程。

-l

多线程.

-+

位于后台。

-C

程占用CPU的百分比

③查看进程状态详细步骤

需要在一个终端上执行:

[root@benet ~]# vim 1.conf

在另一个终端执行:

[root@localhost ~]# ps -aux |grep 1.conf
root      10599  0.1  0.1 151800  5340 pts/0    S+   15:06   0:00 vim 1.conf
root      10603  0.0  0.0 112724  1000 pts/1    S+   15:07   0:00 grep --color=auto 1.conf

 #查看状态S表示睡眠状态,+表示前台

再在 vim 1.conf这个终端上按下: ctrl+z

[root@localhost ~]# vim 1.conf

[1]+  已停止               vim 1.conf

在另一个终端执行:

[root@localhost ~]# ps -aux |grep 1.conf
root      10599  0.0  0.1 151800  5340 pts/0    T    15:06   0:00 vim 1.conf
root      10605  0.0  0.0 112724   996 pts/1    S+   15:07   0:00 grep --color=auto 1.conf

 #查看状态T表示停止状态

注意点:

ctrl-c:是发送 SIGINT 信号,终止一个进程。
ctrl-z:是发送 SIGSTOP 信号,挂起一个进程,将作业放置到后台(暂停)。
ctrl-d:不是发送信号,而是表示一个特殊的二进制值,表示 EOF,代表输入完成或者注销。

④在不可中断状态查看进程状态详细步骤

需要在一个终端上执行:

[root@localhost ~]# tar -zcvf usr.tar.gz /usr/

在另一个终端执行:由S+,R+变为D+

[root@localhost ~]# ps -aux
USER        PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root      11152 19.7  0.0 124004  1764 pts/0    R+   15:54   0:09 tar -zcvf usr.tar.gz 

[root@localhost ~]# ps -aux
USER        PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root      11152 17.6  0.0 124204  1972 pts/0    S+   15:54   0:16 tar -zcvf usr.tar.gz 

[root@localhost ~]# ps -aux
USER        PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root      11152 17.9  0.0 124204  1972 pts/0    D+   15:54   0:20 tar -zcvf usr.tar.gz 

⑤常用的选项(e、l、f)组合

ps -elf(将以长格式显示系统中的进程信息)

[root@localhost ~]# ps -elf
F S UID         PID   PPID  C PRI  NI ADDR SZ WCHAN  STIME TTY          TIME CMD
4 S root          1      0  0  80   0 - 47852 ep_pol 14:47 ?        00:00:01 /usr/lib/s
1 S root          2      0  0  80   0 -     0 kthrea 14:47 ?        00:00:00 [kthreadd]
1 S root          3      2  0  80   0 -     0 smpboo 14:47 ?        00:00:00 [ksoftirqd
1 S root          5      2  0  60 -20 -     0 worker 14:47 ?        00:00:00 [kworker/0
1 S root          7      2  0 -40   - -     0 smpboo 14:47 ?        00:00:00 [migration
1 S root          8      2  0  80   0 -     0 rcu_gp 14:47 ?        00:00:00 [rcu_bh]
1 S root          9      2  0  80   0 -     0 rcu_gp 14:47 ?        00:00:00 [rcu_sched
1 S root         10      2  0  60 -20 -     0 rescue 14:47 ?        00:00:00 [lru-add-d

上述输出信息中,第一行为列表标题,其中各字段的含义描述如下:

字段

含义

字段

含义

F

内核分配给进程的系统标记。

S

进程的状态。

UID

启动这些进程的用户

PID

进程的进程ID。

PPID

父进程的进程号(如果该进程是由另一个进程启动的)

C

进程生命周期中的CPU利用率。

PRI

进程的优先级(越大的数字代表越低的优先级)。

NI

谦让度值用来参与决定优先级。

ADDR

进程的内存地址。

SZ

假如进程被换出,所需交换空间的大致大小。

WCHAN

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

STIME

进程启动时的系统时间。

TTY

进程启动时的终端设备。pts/0255代表虚拟终端,一般是远程连接的终端;tty1 tty7代表本地控制台终端。

TIME

运行进程需要的累计CPU时间

CMD

进程的启动命令

3、查看动态的进程排名信息—top命令

①top命令中的含义

[root@localhost ~]# top
top - 16:19:30 up  1:31,  2 users,  load average: 0.00, 0.01, 0.05
Tasks: 215 total,   1 running, 213 sleeping,   1 stopped,   0 zombie
%Cpu(s):  0.0 us,  0.0 sy,  0.0 ni, 99.9 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem :  3861508 total,   112116 free,   447612 used,  3301780 buff/cache
KiB Swap:  4194300 total,  4194300 free,        0 used.  3075428 avail Mem 

   PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND        
  8679 root      20   0  320216   6712   5216 S   0.3  0.2   0:04.21 vmtoolsd       
     1 root      20   0  191408   4424   2604 S   0.0  0.1   0:01.60 systemd        
     2 root      20   0       0      0      0 S   0.0  0.0   0:00.02 kthreadd       
     3 root      20   0       0      0      0 S   0.0  0.0   0:00.03 ksoftirqd/0    
     5 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 kworker/0:0H   
     7 root      rt   0       0      0      0 S   0.0  0.0   0:00.02 migration/0    
     8 root      20   0       0      0      0 S   0.0  0.0   0:00.00 rcu_bh         
     9 root      20   0       0      0      0 S   0.0  0.0   0:00.57 rcu_sched      
    10 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 lru-add-drain  
    11 root      rt   0       0      0      0 S   0.0  0.0   0:00.02 watchdog/0     
    12 root      rt   0       0      0      0 S   0.0  0.0   0:00.01 watchdog/1     
    13 root      rt   0       0      0      0 S   0.0  0.0   0:00.02 migration/1    
    14 root      20   0       0      0      0 S   0.0  0.0   0:00.02 ksoftirqd/1   

上述输出信息中,其中各字段的含义描述如下:

排数top里面中的含义
第1排top - 16:19:30(当前时间) up  1:31系统运行时间 ,  2 users(当前登录用户数),  load average: 0.00, 0.01, 0.05(系统负载,即任务队列的平均长度。 三个数值分别为 1 分钟、5 分钟、15 分钟前到现在的平均值)。
第2排系统任务(Tasks)信息:total总进程数,running:正在运行的进程数,sleeping:休眠的进程数,stopped:中止的进程数,zombie:僵死无响应的进程数。
第3排%Cpu(s)占用信息:us 用户占用,sy 内核占用,ni 优先级调度占用,id 空闲CPU,wa I/O 等待占用,hi 硬件中断占用,si 软件中断占用,st 虚拟化占用。了解空闲的CPU百分比,主要看%id 部分。
第4排内存占用(KiB Mem)信息:total 总内存空间,free 空闲内存,used 已用内存,buff/cache 物理内存和交换内存的缓冲区总和。
第5排交换空间(KiB Swap)占用:total 总交换空间,free 空闲交换空间,used 已用交换空间,avail Mem 可用物理空间。
第6排PID:进程 id;USER:进程所有者的用户名;PR:优先级(由内核动态调整),用户不能;NI:进程优先级(nice 值,负值表示高优先级,正值表示低优先级,用户可以自己调整);VIRT(virtual memory usage):虚拟内存,是进程正在使用的所有内存(ps 中标为 VSZ);RES(resident memory usage):是进程所使用的物理内存,实际实用内存(ps 中标为 RSS);SHR:共享内存大小,单位(kb);S:进程状态;%CPU:上次更新到现在的 CPU 时间占用百分比;%MEM:进程使用的物理内存百分比;TIME+:进程使用的 CPU 时间总计,单位 1/100 秒;COMMAND:命令名/命令行。

②top命令全屏操作界面快捷键

默认3s刷新一次,按s修改刷新时间按空格 :立即刷新。

P键:按 CPU排序。

M键:按内存排序。

T键:按时间排序。

p键:进程 IP,查看某个进程状态。

N键:根据启动时间进行排序。

数字键1:显示每个内核的CPU 使用率u/U:指定显示的用户。

h键:可以获得 top 程序的在线帮助信息。

q键:可以正常地退出 top 程序。

注意点:

若通过top排名工具发现某个进程CPU占用率非常高,需要终止该进程的运行,可以在top操作界面中按k键,然后在列表上方将会出现“PID to signal/kill [default pid = 3180]:” 的提示信息,根据提示输入指定进程的PID号并按Enter键, 出现“Send pid 5597 signal [15/sigterm]”的二次确认的提示信息,然后按Enter键确认即可终止对应的进程。

4、根据特定条件查询进程PID信息—pgrep命令

常用的参数

参数含义
-l选项可同时输出对应的进程名以及PID
-U选项查询特定用户的进程
-t选项查询在特定终端运行的进程
[root@localhost ~]# pgrep -l "conf"
85 ipv6_addrconf
10095 ibus-dconf


[root@localhost ~]# pgrep -l -U root -t tty1
9909 X

5、以树形结构列出进程信息—pstree命令

①常用参数

参数

含义

-p

选项使用时可以同时列出对应的PID号

-u

选项可以列出对应的用户名

-a

选项可以列出完整的命令信息

②执行:pstree -aup命令可以查看当前系统的进程树,包括各进程对应的PID 号、用户名、完整命令等信息。从输出结果中可以看出,systemd 进程确实是 Linux 操作系统中所有进程的“始祖”。

[root@localhost ~]# pstree -aup | wc -l
265

二、控制进程

1、手动启动

由用户手工输入命令或者可执行程序的路径,可以至少启动一个进程。根据该进程是否  需要占用当前的命令终端,手工启动又可以分为前台启动和后台启动。

①前台启动:用户输入命令,直接执行程序。

进程在前台运行(如执行“ls -l”命令)时,用户必须等到该进程执行结束并退出以后才能继续输入其他命令,大多数命令操作在前台启动运行。

②后台启动:在命令行尾加入“&”符号。

进程在后台运行时,用户可以继续在当前终端中输入其他命令,而无须等待该进程结束,适用于运行耗时较长的操作。启动后台进程需要使用“&”操作符,将“&”操作符放在要执行命令的最后面,进程启动后会直接放入后台运行,而不占用前台的命令操作界面,方便用户进行其他操作。

当使用cp命令从光盘中制作镜像文件时,由于需要复制的数据较多,耗时较长,
因此可结合“&”符号将复制操作放到后台运行,以便用户可以继续执行其他命令操作:
[root@localhost ~]# cp /dev/cdrom /home/cetos7.iso &
[2] 13537

2、调度启动

在服务器维护工作中,经常需要执行一些比较费时而且较占用资源的任务(如数据备份),这些任务更适合在相对空闲的时候(如夜间)进行。这时就需要用户事先进行调度安排,指 定任务运行的时间,当系统到达设定时间时会自动启动并完成指定的任务。调度启动的计划 任务进程均在后台运行,不会占用用户的命令终端。

①使用at命令,设置一次性计划任务

②使用crontab命令,设置周期性计划任务

进程的调度启动可以通过 at、crontab 命令进行设置,其中 at 命令用于设置一次性(如12:15 时重启网络服务)计划任务,crontab 命令用于设置周期性运行(如每周五 17:30 备份数据库)的计划任务。

3、进程的前后台调度

①Ctrl+Z组合键:将当前进程挂起,即调入后台并停止执行。

当Linux操作系统中的命令正在前台执行时(运行尚未结束),按Ctrl+Z组合键可以将当前进程挂起(调入后台并停止执行),这种操作在需要暂停当前进程并进行其他操作时特别有用。

[root@localhost ~]# tar -zcvf usr.tar.ga /usr/
tar: 从成员名中删除开头的“/”
/usr/
/usr/bin/
/usr/bin/cp
^Z
[1]+  已停止               tar -zcvf usr.tar.ga /usr/

②jobs命令:查看处于后台的任务列表。

常用参数

-l:选项可以同时显示该进程对应的PID号

[root@localhost ~]# vim 1.conf &
[1] 13774
[root@localhost ~]# jobs -l
[1]+ 13774 停止 (tty 输出)     vim 1.conf

③fg命令:将后台进程恢复到前台运行,可指定任务序号。

[root@localhost ~]# vim 1.conf &
[1] 13774
[root@localhost ~]# fg 1
vim 1.conf

④bg命令:可以将后台中暂停执行(如按 Ctrl+Z 组合键挂起)的任务恢复运行,继续在后台执行操作

[root@localhost ~]# tar -zcvf usr.tar.ga /usr/
tar: 从成员名中删除开头的“/”
/usr/
/usr/bin/
/usr/bin/cp
^Z
[1]+  已停止               tar -zcvf usr.tar.ga /usr/
[root@localhost ~]# bg

注意点:

除非后台中的任务只有一个,否则 bg 和 fg 命令都需要指定后台进程的任务编号作为参数。

4、终止进程的运行

①Ctrl+C组合键:当用户在前台执行某个进程时,可以按Ctrl+C组合键强制进行中断(如命令长时间没有响应的情况下)。中断前台进程的运行后,系统将返回命令行提示符状态等待用户输入新的命令。当按 Ctrl+C 组合键无法终止程序或者需要结束在其他终端或后台运行的进程时。

[root@localhost ~]# tar -zcvf usr.tar.ga /usr/
tar: 从成员名中删除开头的“/”
/usr/
/usr/bin/
/usr/bin/cp
^C

②kill命令:通过 kill 命令终止进程时,需要使用进程的PID号作为参数。无特定选项时,kill 命令将给该进程发送终止信号并正常退出运行,若该进程已经无法响应终止信号,则可以结合“-9”选项强行终止进程。强制终止进程时可能会导致程序运行的部分数据丢失,因此不到不得已时不要轻易使用“-9”选项。

若SSH服务的sshd进程的PID号为10026,则执行“kill 5822”命令后可以将进程 sshd终止
[root@localhost ~]# pgrep -l "sshd"
9276 sshd
10026 sshd
10518 sshd
[root@localhost ~]# kill 10026
[root@localhost ~]# pgrep -l "sshd"
9276 sshd
10518 sshd
对于无法正常终止的系统进程,在必要时可以结合“-9”选项强制终止。
以下操作展示了强制终止 vim 进程的过程
[root@localhost ~]# vim 1.test &
[1] 14324
[root@localhost ~]# jobs -l
[1]+ 14324 停止 (tty 输出)     vim 1.test
[root@localhost ~]# kill 14324
[root@localhost ~]# jobs -l
[1]+ 14324 停止 (tty 输出)     vim 1.test
[root@localhost ~]# kill -9 14324
[root@localhost ~]# jobs -l
[1]+ 14324 已杀死               vim 1.test

③killall命令:使用 killall 命令可以通过进程名称来终止进程,当需要结束系统中多个相同名称的进程时,使用 killall 命令将更加方便,效率更高。killall 命令同样也有“-9”选项。

执行如下的“killall -9 vim”命令可将所有名为 vim 的进程都强行终止
[root@localhost ~]# vim 1.test &
[1] 14342
[root@localhost ~]# vim 2.test &
[2] 14343
[root@localhost ~]# jobs -l
[1]- 14342 停止 (tty 输出)     vim 1.test
[2]+ 14343 停止 (tty 输出)     vim 2.test
[root@localhost ~]# killall -9 vim
[root@localhost ~]# jobs -l
[1]- 14342 已杀死               vim 1.test
[2]+ 14343 已杀死               vim 2.test

④pkill命令:可以根据进程的名称、运行该进程的用户、进程所在的终端等多种属性终止特定的进程,大部分选项与 pgrep 命令基本类似,如“-U”(指定用户)、“-t”(指定终端)等选项,使用起来非常方便。

若要终止由用户 hmj 启动的进程(包括登录 Shell),可以执行以下操作。
[root@localhost ~]# su - lisi
上一次登录:二 8月 17 17:42:29 CST 2021pts/1 上
[lisi@localhost ~]$ vim test.txt &
[1] 14526
[lisi@localhost ~]$ pgrep -l -U "lisi"
14481 bash
14526 vim

[1]+  已停止               vim test.txt
[lisi@localhost ~]$ pkill -9 -U "lisi"
已杀死
[root@localhost ~]# pgrep -l -U "lisi"

三、计划任务管理

在 Linux 操作系统中,除了用户即时执行的命令操作以外,还可以配置在指定的时间、指定的日期执行预先计划的系统管理任务(如定期备份、定期采集监测数据)。CentOS 系统中默认已安装了 at、cronie 软件包,通过 atd 和 crond 这两个系统服务实现一次性、周期性计划任务的功能,并分别通过 at、crontab 命令进行计划任务设置。

1、一次性计划任务—at命令

使用at命令设置的计划任务只在指定的时间点执行一次,前提是对应的系统服务atd必须已经运行。需要注意的是,计划执行任务的时间、日期必须安排在当前系统的时刻之后,否则将无法正确设置计划任务。设置一次性计划任务时,在 at 命令行中依次指定计划执行任务的时间、日期作为参数(若只指定时间则表示当天的该时间,若只指定日期则表示该日期的当前时间),确认后将进入带“at>”提示符的任务编辑界面,每行设置一条执行命令,可以依次设置多条语句,最后按 Ctrl+D组合键提交任务。所设置的命令操作将在计划的时间点被依次执行。

以下操作先通过date命令确认当前的系统时间,并设置在2021年8月17日的21:53自动执行以下任务:
统计该时间点系统中由root用户运行的进程的数量,并将该数值保存到/tmp/ps.root文件中。
[root@localhost ~]# date
2021年 08月 17日 星期二 21:51:14 CST
[root@localhost ~]# at 21:53 2021-08-17
at> pgrep -U root | wc -l > /tmp/ps.root
at> <EOT>
job 2 at Tue Aug 17 21:53:00 2021
[root@localhost ~]# cat /tmp/ps.root
174
以下操作将设置一条计划任务,在当天的22:00自动关闭当前系统。
[root@localhost ~]# at 22:00
at> shutdown -h now
at> <EOT>
job 3 at Tue Aug 17 22:00:00 2021
对于已经设置但还未执行(未到时间点)的计划任务,可以通过 atq 命令进行查询。
但已执行过的 at 任务将不会再出现在列表中。
[root@localhost ~]# atq
3	Tue Aug 17 22:00:00 2021 a root
若要删除指定编号的 at 任务,可以使用 atrm 命令。删除后的 at 任务将不会被执行, 
并且不会显示在 atq 命令的显示结果中,但已经执行过的任务无法删除。
[root@localhost ~]# atq
3	Tue Aug 17 22:00:00 2021 a root
[root@localhost ~]# atrm 3
[root@localhost ~]# atq

2、周期性任务设置—crontab命令

crond 通过多个目录和文件设置计划任务,不同类型的任务由不同的配置文件来设置

①/etc/crontab——系统任务配置文件

/etc/crontab文件中设置的是维护Linux操作系统所需的任务,Linux操作系统及相关程序在安装时可自动设置,不建议用户手动修改此文件。

该文件中包括设置Shell环境、可执行路径等变量的操作,以及每小时、每天、每周、每月需要执行的任务目录。执行如下的“cat /etc/crontab”命令可以查看/etc/crontab文件的具体内容。
[root@localhost ~]# 
[root@localhost ~]# cat /etc/crontab 
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root

# For details see man 4 crontabs

# Example of job definition:
# .---------------- minute (0 - 59)
# |  .------------- hour (0 - 23)
# |  |  .---------- day of month (1 - 31)
# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri
,sat# |  |  |  |  |
# *  *  *  *  * user-name  command to be executed

根据/etc/crontab 配置文件中的设定,crond 将按照不同的周期重复执行相应目录中的任务脚本文件。

②/var/spool/cron/——用户cron任务的配置文件存放目录

由用户自行设置(使用crontab 命令)的cron计划任务将被保存到目录/var/spool/cron/ 中,文件名与用户名相同。

先设置一条计划任务:在每周日晚上的 23:55 将/etc/passwd 文件的内容复制到宿主目录中,
保存为 pwd.txt 文件,然后通过如下操作可以得知,root用户的cron计划任务保存在配置文
件/var/spool/cron/root中。
[root@localhost ~]# crontab -e
55 23 * * 7 /usr/bin/cp /etc/passwd /home/jerry/pwd.txt
[root@localhost ~]# ls -l /var/spool/cron/root
-rw------- 1 root root 56 8月  17 22:25 /var/spool/cron/root

crond守护进程会自动检查/etc/crontab文件、/etc/cron.d/目录及/var/spool/cron/目录中的改变,如果发现有配置更改,它们就会被载入内存,所以当某个crontab 文件改变后并不需要重新启动crond守护进程就可以使设置生效。

③使用 crontab 命令管理用户的计划任务

设置用户的周期性计划任务列表主要通过 crontab 命令进行,结合不同的选项可以完成不同的计划任务管理操作。

常用的选项

参数

含义

-e

编辑计划任务列表

-u

指定所管理的计划任务属于哪个用户,默认是针对当前用户(自己),一般只有 root 用户有权限使用此选项(用于编辑、删除其他用户的计划任务)

-l

列表显示计划任务

-r

删除计划任务列表

管理计划任务命令

编辑计划任务:crontab  -e  [-u  用户名]

查看计划任务:crontab  -l  [-u  用户名]

删除计划任务:crontab  -r  [-u  用户名]

crontab -u 用户名:指定XX用户的cron服务

crontab -l:列出当前用户下的cron的详细内容

crontab -u zx -l:列出zx用户下的cron的详细内容

crontab -r:删除所有用户的cron内容,普通用户执行,只删除自己的cron内容

crontab -r -u zx:删除zx用户的cron内容

crontab -e:编辑cron服务

字段

说明

分钟

取值为从0到59之间的任意整数

小时

取值为从0到23之间的任意整数

日期

取值为从1到31之间的任意整数

月份

取值为从1到12之间的任意整数

星期

取值为从0到7之间的任意整数,0或7代表星期日

命令

要执行的命令或程序脚本

时间数值的特殊表示方法

符号

含义

*

表示该范围内的任意时间

,

表示间隔的多个不连续时间点

-

表示一个连续的时间范围

/

指定间隔的时间频率

若要按固定的周期重复完成一些系统管理任务,任务内容如下:
①每天早上7:30自动开启sshd服务,22:30关闭sshd服务;
②每隔7天清空一次FTP服务器公共目录/var/ftp/pub中的数据;
③每周六的7:30重新启动系统中的httpd服务;
④每周一、周三、周五的下午18:30,使用tar命令自动备份/etc/httpd目录,
则可由root用户通过crontab设置以下计划任务。
[root@localhost ~]# crontab -e
30 7 * * * /usr/bin/systemctl start sshd.service
30 22 * * * /usr/bin/systemctl stop sshd.servic
0 0 */7 * * /usr/bin/rm -rf /var/ftp/pub/*
30 7 * * 6 /usr/bin/systemctl httpd restart
30 18 * * 1,3,5 /usr/bin/tar jcf httpdconf.tar.bz2 /etc/httpd/

④查看用户的计划任务列表

crontab命令结合“-l”选项可以查看当前用户的计划任务列表,对于root用户来说,还可以结合“-u”选项查看其他用户的计划任务。

[root@localhost ~]# crontab -l
30 7 * * * /usr/bin/systemctl start sshd.service 
30 22 * * * /usr/bin/systemctl stop sshd.servic 
0 0 */7 * * /usr/bin/rm -rf /var/ftp/pub/*
30 7 * * 6 /usr/bin/systemctl httpd restart
30 18 * * 1,3,5 /usr/bin/tar jcf httpdconf.tar.bz2 /etc/httpd/

⑤删除用户的计划任务列表

当只需要删除某一条计划任务时,可以通过“crontab -e”命令进行编辑;而若要清空某个用户的所有计划任务,可以执行“crontab -r”命令。

[root@localhost ~]# crontab -l
30 7 * * * /usr/bin/systemctl start sshd.service 
30 22 * * * /usr/bin/systemctl stop sshd.servic 
0 0 */7 * * /usr/bin/rm -rf /var/ftp/pub/*
30 7 * * 6 /usr/bin/systemctl httpd restart
30 18 * * 1,3,5 /usr/bin/tar jcf httpdconf.tar.bz2 /etc/httpd/
[root@localhost ~]# crontab -r
[root@localhost ~]# crontab -l
no crontab for root

总结

1、查看进程可以使用ps命令(静态的进程统计信息)、top命令(动态的进程排名信息)、pgrep命令(特定条件查询进程PID信息)、ptree命令(以树形结构列出进程信息)。

2、调度进程的执行可以使用Ctrl+Z组合键(将当前进程挂起,即调入后台并停止执行)、&符号(适用于运行耗时较长的操作,操作符放在要执行命令的最后面)、jobs命令(处于后台的任务列表)、fg命令(将后台进程恢复到前台运行,可指定任务序号)和bg命令(将后台中暂停执行的任务恢复运行,继续在后台执行操作)。

3、终止进程可以使用Ctrl+C组合键(强制进行中断)、kill命令(使用进程的PID号作为参数)、killall命令(多个相同名称)和 pkill命令(进程的名称、运行该进程的用户、进程所在的终端等多种属性)。

4、使用at命令可以设置一次性执行的计划任务,最后按 Ctrl+D组合键提交任务。

5、使用crontab命令可以设置周期性执行的计划任务。

6、Crontab计划任务的配置格式中,六个字段依次为分钟、小时、日期、月份、星期、命令。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值