Linux——进程和计划任务管理(理论+实验)

2023-05-16

目录

  • 前言
  • 一、程序、进程线程概述
    • 1.1 程序
    • 1.2 进程
    • 1.3 线程
    • 1.4 程序、进程和线程的关系
    • 1.5 程序和进程的关系
  • 二、查看进程
    • 2.1 1.ps 命令——查看静态的进程统计信息(Processes Statistic)
      • 2.1.2 top 命令——查看进程动态信息
      • 2.1.3 pgrep 命令——查询进程信息
      • 2.1.4 pstree 命令——查看进程树
  • 三、控制进程
    • 3.1启动进程
      • 3.1.1 手工启动进程
      • 3.1.2 调度启动进程
    • 3.2 改变进程的运行方式
      • 3.2.1 挂起当前的进程
      • 3.2.2 查看后台的进程
      • 3.2.3 将后台的进程恢复运行
    • 3.3 终止进程执行
      • 3.3.1 使用 kill 命令终止进程
      • 3.2.2 使用 killall 命令终止进程
      • 3.3.3 使用 pkill 命令终止进程
  • 四、计划任务管理
    • 4.1 at 一次性任务设置
      • 4.1.1 安装顺序
  • 五、crontab 周期性任务设置
    • 5.1 crontab 的配置文件和目录
      • 5.1.1 /etc/crontab——系统任务配置文件
      • 5.1.2 /var/spool/cron/——用户 cron 任务的配置文件存放目录
    • 5.2 使用 crontab 命令管理用户的计划任务
      • 5.2.1 编辑用户的计划任务列表
      • 5.2.2 查看用户的计划任务列表
      • 5.2.3 删除用户的计划任务列表

前言

  • 程序是保存在外部存储介质(如硬盘)中的可执行机器代码和数据的静态集合,而进程是在 CPU 及内存中处于动态执行状态的计算机程序
  • 在 Linux 操作系统中,每个程序启动后可以创建一个或多个进程

一、程序、进程线程概述

1.1 程序

  • 计算机程序是一组计算机能识别和执行的指令,运行于电子计算机上,满足人们某种需求的信息化工具

1.2 进程

  • 程序是保存在外部存储介质(如硬盘)中的可执行机器代码和数据的静态集合,而进程 是在 CPU 及内存中处于动态执行状态的计算机程序。在 Linux 操作系统中,每个程序启动后可以创建一个或多个进程

1.3 线程

  • 线程(thread)是操作系统能够进行运算调度的最小单位
  • 线程被包含在进程之中,是进程中的实际运作单位
  • 一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务

1.4 程序、进程和线程的关系

名称关系
程序一个应用程序可以包含一个或者多个进程
进程一个进程包含一个或多个线程
线程线程是执行操作的最小单元

1.5 程序和进程的关系

  • 程序
    • 保存在硬盘,光盘等介质中的可执行代码和数据
    • 静态保存的代码
  • 进程
    • 在CPU及内存中运行的程序代码
    • 动态执行的代码
    • 父.子进程:每个进程可以创建一个或多个进程,是一个依赖关系

二、查看进程

  • 了解系统中进程的状态是对进程进行管理的前提,使用不同的命令工具可以从不同的角度查看进程状态

2.1 1.ps 命令——查看静态的进程统计信息(Processes Statistic)

  • ps命令是Linux系统中最为常用的进程查看工具,主要用于显示包含当前运行的各进程完整信息的静态快照
  • ps命令基本格式
ps [选项]  注意:有一些选项时不带“-”前缀的(添加“-”前缀后含义可能会有出入)
  • 常用命令选项
选项解释
a显示当前终端下的所有进程信息,包括其他用户的进程。与“x”选项结合时将显 示系统中所有的进程信息
u使用以用户为主的格式输出进程信息
x显示当前用户在所有终端下的进程信息
-e显示系统内的所有进程信息
-l使用长(Long)格式显示进程信息
-f使用完整的(Full)格式显示进程信息
  • 注意:
    • 有一部分选项是不带“-”前缀的(添加“-”前缀后含义可能会有出入,详细请参考 man 手册页)
    • 习惯上将上述选项组合在一起使用,如执行“ps aux”或“ps -elf”命令
  • 执行“ps aux”命令后,将以简单列表的形式显示出进程信息
[root@localhost ~]# ps aux
USER        PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root          1  0.2  0.3 193700  6836 ?        Ss   22:38   0:01 /usr/lib/systemd/syst
root          2  0.0  0.0      0     0 ?        S    22:38   0:00 [kthreadd]
root          3  0.0  0.0      0     0 ?        S    22:38   0:00 [ksoftirqd/0]
root          4  0.0  0.0      0     0 ?        S    22:38   0:00 [kworker/0:0]
root          5  0.0  0.0      0     0 ?        S<   22:38   0:00 [kworker/0:0H]
root          7  0.0  0.0      0     0 ?        S    22:38   0:00 [migration/0]
root          8  0.0  0.0      0     0 ?        S    22:38   0:00 [rcu_bh]
..以下省略部分内容
  • 上述输出信息中,每一列称为字段或者列或者属性
  • 上述输出信息中,第一行为列表标题,其中个字段的含义如下
    • USER:启动该进程的用户账号的名称。
    • PID:该进程在系统中的数字 ID 号,在当前系统中是唯一的。
    • %CPU:CPU 占用的百分比。
    • %MEM:内存占用的百分比。
    • VSZ:占用虚拟内存(swap 空间)的大小。
    • RSS:占用常驻内存(物理内存)的大小。
    • TTY:表明该进程在哪个终端上运行。“?”表示未知或不需要终端。
    • STAT:显示进程当前的状态,如 S(休眠)、R(运行)、Z(僵死)、<(高优先级)、N(低优先级)、s(父进程)、+(前台进程)。对处于僵死状态的进程应该予以手动终止。
    • START:启动该进程的时间。
    • TIME:该进程占用的 CPU 时间。
    • COMMAND:启动该进程的命令的名称
  • 若执行如下的“ps -elf”命令,则将以长格式显示系统中的进程信息,并且包含更丰富的内容
##输出信息中还包括 PPID 列(表示对应进程的父进程的 PID 号)
[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 - 32041 ep_pol 23:04 ?        00:00:00 /usr/l
1 S root          2      0  0  80   0 -     0 kthrea 23:04 ?        00:00:00 [kthre
1 S root          3      2  0  80   0 -     0 smpboo 23:04 ?        00:00:00 [ksoft
1 S root          4      2  0  80   0 -     0 worker 23:04 ?        00:00:00 [kwork
1 S root          5      2  0  60 -20 -     0 worker 23:04 ?        00:00:00 [kwork
1 S root          6      2  0  80   0 -     0 worker 23:04 ?        00:00:00 [kwork
1 S root          7      2  0 -40   - -     0 smpboo 23:04 ?        00:00:00 [migra
1 S root          8      2  0  80   0 -     0 rcu_gp 23:04 ?        00:00:00 [rcu_b
1 R root          9      2  0  80   0 -     0 -      23:04 ?        00:00:00 [rcu_s
..此处省略部分信息
  • 上述输出信息中每个字段的含义
    • PPID:表示对应进程的父进程的PID号
    • PRI:用户态优先级(人为)
    • NI: nice值,内核态优先级,取值范围(-20~19),值越小,优先级越高
    • ADDR:若是 - ,代表正在运行
    • SZ:在swap交换分区的容量
    • WCHAN:当前进程在内核中的名称
    • STIME:启动时间
  • 直接执行不带任何选项的 ps 命令时,将只显示当前用户会话中打开的进程
[root@localhost ~]# ps
PID TTY	TIME CMD
3728 pts/1	00:00:00 bash
4976 pts/1	00:00:00 ps
  • 由于系统中运行的进程数量较多,需要查询某一个进程的信息时可以结合管道操作和grep 命令进行过滤
##过滤出包含“bash”的进程信息
[root@localhost ~]# ps aux | grep bash
root	806    0.0   0.0 115248	936 ?	S	08:27	0:00 /bin/bash /usr/ sbin/ksmtuned
root	3115    0.0   0.0   52864	568 ?	Ss	08:28	0:00 /usr/bin/ssh-ag- ent /bin/sh -c exec -l /bin/bash -c "env GNOME_SHELL_SESSION_MODE=classic gnome- session --session gnome-classic"
root	3675 0.0 0.1 116536	3240 pts/0	Ss	08:34	0:00 bash
root	5034 0.0 0.0 112652	960 pts/0	S+	09:23	0:00 grep --color=au
to bash					

2.1.2 top 命令——查看进程动态信息

  • 使用 ps 命令查看到的是一个静态的进程信息,并不能连续地反馈出当前进程的运行状态
  • 若希望以动态刷新的方式显示各进程的状态信息,可以使用 top 命令
  • top 命令将会在当前终端以全屏交互式的界面显示进程排名,及时跟踪包括 CPU、内存等系统资源占用情况,默认情况下每三秒钟刷新一次,其作用基本类似于Windows 操作系统中的任务管理器
[root@localhost ~]# top
top - 23:17:10 up 12 min,  3 users,  load average: 0.00, 0.04, 0.06
Tasks: 185 total,   1 running, 184 sleeping,   0 stopped,   0 zombie
%Cpu(s):  0.0 us,  0.0 sy,  0.0 ni, 99.7 id,  0.3 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem :  1867024 total,   670880 free,   669584 used,   526560 buff/cache
KiB Swap:  4194300 total,  4194300 free,        0 used.   986308 avail Mem 

   PID USER      PR  NI    VIRT    RES    SHR S %CPU %MEM     TIME+ COMMAND       
  1833 root      20   0 1624108 168500  51624 S  0.0  9.0   0:02.26 gnome-shell   
  1983 root      20   0 1100816  63532  20704 S  0.0  3.4   0:00.10 evolution-cal+
  2083 root      20   0 1202856  59344  19216 S  0.0  3.2   0:00.08 evolution-cal+
  2040 root      20   0 1040248  59132  19108 S  0.0  3.2   0:00.06 evolution-cal+
  1994 root      20   0  884268  32724  14160 S  0.0  1.8   0:00.31 gnome-software
  1392 root      20   0  288368  30804  10276 S  0.0  1.6   0:00.40 X             
  1965 root      20   0 1026108  30296  18916 S  0.0  1.6   0:00.20 nautilus-desk+
  • 上述输出信息中,开头的部分显示了系统任务(Tasks)、CPU 占用、内存占用(Mem)、交换空间(Swap)等汇总信息,汇总信息下方依次显示当前进程的排名情况
    • 系统任务(Tasks)信息:total,总进程数;running,正在运行的进程数;sleeping, 休眠的进程数;stopped,中止的进程数;zombie,僵死无响应的进程数。
    • CPU 占用信息:us,用户占用;sy,内核占用;ni,优先级调度占用;id,空闲CPU;wa,I/O 等待占用;hi,硬件中断占用;si,软件中断占用;st,虚拟化占用。要了解空闲的 CPU 百分比,主要看%id 部分。
    • 内存占用(Mem)信息:total,总内存空间;free,空闲内存;used,已用内存buff/cache,物理内存和交换内存的缓冲区总和。
    • 交换空间(Swap)占用:total,总交换空间;free,空闲交换空间;used,已用交换空间;avail Mem,可用物理空间
  • top 命令选项
    • M:以内存大小排序
    • c:以CPU占用排序
    • h:top程序在线帮助信息
    • q:退出

2.1.3 pgrep 命令——查询进程信息

  • 当使用 ps 命令查询某个进程的 PID 信息时,往往需要结合 grep 命令对输出结果进行过滤,但这样使用非常不方便,而 pgrep 命令正是查询特定进程信息的专用工具
  • 使用 pgrep 命令可以根据进程的名称、运行该进程的用户、进程所在的终端等多种属性查询特定进程的PID 号
  • 通过 pgrep 命令,可以只指定进程的一部分名称进行查询,结合“-l”选项可同时输出对应的进程名(否则只输出 PID 号,不便于理解)
[root@localhost ~]# pgrep -l "log"
431 xfs-log/dm-0
636 xfs-log/sda1
637 xfs-log/sdb1
661 xfs-log/dm-2
713 abrt-watch-log
730 abrt-watch-log
799 systemd-logind
1135 rsyslogd
  • 还可结合“-U”选项查询特定用户的进程、“-t”选项查询在特定终端运行的进程
##查询由用户 teacher 在 tty2 终端上运行的进程及 PID[root@localhost ~]# pgrep -l -U teacher -t tty2
6098 bash
6144 vim

2.1.4 pstree 命令——查看进程树

  • pstree 命令可以输出 Linux 操作系统中各进程的树形结构,以更加直观地判断各进程之间的相互关系(父进程、子进程)
  • pstree 命令默认情况下只显示各进程的名称
    • 结合“-p” 选项使用时可以同时列出对应的 PID 号
    • 结合“-u”选项可以列出对应的用户名
    • 结合“-a”选项可以列出完整的命令信息
执行的“pstree -aup”命令可以查看当前系统的进程树,包括各进程对应的PID 号、用户名、完整命令等信息
[root@localhost ~]# pstree -aup
systemd,1 --switched-root --system --deserialize2
……// 省略部分信息
├─login,6029
│	└─bash,6098,teacher
│	└─vim,6144 myfile.txt
……// 省略部分信息

##从输出结果中可以看出,systemd 进程确实是 Linux 操作系统中所有进程的“始祖”
  • 使用 pstree 命令时,也可以只查看属于指定用户的进程树结构,只要指定用户名作为参数即可
##列出由用户 teacher 打开的进程及子进程的树结构
[root@localhost ~]# pstree -ap teacher
bash,6248

bash,6098
└─vim,6144 myfile.txt

三、控制进程

3.1启动进程

  • 在 Linux 操作系统中,可以由用户手工启动或者按预订计划调度启动新的进程

3.1.1 手工启动进程

  • 进程在前台运行时,用户必须等到该进程执行结束并退出后才能继续输入其他命令。运行耗时较长的操作可进入后台运行,进程在后台运行时,用户可以继续在当前终端输入其他命令,无需等待该进程结束。
  • 前台启动:用户输入命令,直接执行程序
  • 后台启动:在命令末尾加入“&”符号
[root@localhost ~]# cp /dev/cdrom mycd.iso&		'//在后台运行复制镜像文件进程'
[1] 3227		'//输出信息中心包括后台任务序号,PID号'

3.1.2 调度启动进程

  • 有些任务非常费时,适合在相对空闲的时间进行,我们便可以使用调度安排启动
  • at命令,设置一次性计划任务(如 12:30重启网络服务)
  • crontab,命令,设置周期性计划任务(如 每周六18:00 备份数据库)

3.2 改变进程的运行方式

3.2.1 挂起当前的进程

  • 将当前进程挂起,即调入后台并停止执行(对于速度缓慢,会耽误其他操作的进程使用)
  • 示例
##在使用 wget 命令下载 Firefox 软件包时,发现下载速度缓慢,为了不耽误其他操作,可以按 Ctrl+Z 组合键将该下载任务调入后台并暂停执行
[root@localhost ~]# wget ftp://173.17.17.13/firefox-3.6.13.tar.bz2
--12:55:24-- ftp://173.17.17.13/firefox-3.6.13.tar.bz2
=> 'firefox-3.6.13.tar.bz2.1' Connecting to 173.17.17.13:21… 已连接. 正在以 anonymous 登录 … 登录成功!
==> SYST … 完成.	==> PWD … 完成.
==> TYPE I … 完成. ==> 不需要 CWD.
==> SIZE firefox-3.6.13.tar.bz2 … 9437184
==> PASV … 完成.	==> RETR firefox-3.6.13.tar.bz2 … 完成. 长度:9437184 (9.0M)
0% [	]0	--.- k/s
//按Ctrl+Z 组合键
[1]+   Stopped	wget ftp://173.17.17.13/firefox-3.6.13.tar.bz2

3.2.2 查看后台的进程

  • 查看处于后台的任务列表。
  • 结合“-l”选项可以同时显示出该进程对应的PID号
  • 输出结果中,每一行记录对应一个后台进程的状态信息,行首的数字代表该进程在后台的任务编号。
  • 若当前终端没有后台进程,将不会显示任何信息
  • 示例:
执行“jobs -l”命令可以看到前面挂起的 wget 下载任务的相关信息
[root@localhost ~]# jobs -l
[1]+ 28584 停 止 wget ftp://173.17.17.13/firefox-3.6.13.tar.bz2

3.2.3 将后台的进程恢复运行

  • 将后台进程恢复到前台运行,可以指定任务序号
  • bg(BackGround)命令可以将后台中暂停执行的任务恢复运行,继续在后台执行操作
  • fg(ForeGround)命令可以将后台任务恢复到前台运行
  • 除非后台任务只有一个,否则bg和fg命令都需要指定后台进程的任务编号作为参数
  • 示例:
执行如下的“fg 1”命令可以将之前挂起至后台的 wget 进程重新调入前台执行
[root@localhost ~]# fg 1
wget ftp://173.17.17.13/firefox-3.6.13.tar.bz2
…… //省略部分信息

3.3 终止进程执行

  • 平常可以使用Ctrl + C组合键强制中断
  • Ctrl + C组合键无法中止后,可以使用专门的进程中止工具 kill,killall,pkill

3.3.1 使用 kill 命令终止进程

  • kill命令需要使用进程的PID号作为参数
  • 若进程无法响应,可结合“-9”选项强行中止进程。强行中止进程可能会到时部分数据丢失,谨慎使用
  • 示例:
##若 SSH 服务的 sshd 进程的 PID 号为 5822,则执行“kill 5822”命令后可以将进程 sshd 终止
[root@localhost ~]# pgrep -l "sshd"	//查询目标进程的PID 号
5822 sshd
[root@localhost ~]# kill 5822	//终止指定PID 的进程
[root@localhost ~]# pgrep -l "sshd"	//确认进程已终止(查询时无结果)
  • 对于无法正常终止的系统进程,在必要时可以结合“-9”选项强制终止
  • 示例:
##强制终止 vim 进程
[root@localhost ~]# vim tmpfile	//打开vim 程序并挂起作为测试
[1]+   Stopped	vim tmpfile
[root@localhost ~]# jobs –l	//查询目标进程的PID 号
[1]+   7095 Stopped	vim tmpfile
[root@localhost ~]# kill 7095		//尝试正常结束进程[root@localhost ~]# jobs -l			//但发现vim 进程并未退出[1]+   7095 Stopped	vim tmpfile
[root@localhost ~]# kill -9 7095		//强制终止目标进程[root@localhost ~]# jobs -l		//成功终止vim 进程[1]+ 2993  已 杀死	vim tmpfile

3.2.2 使用 killall 命令终止进程

  • 使用 killall 命令可以通过进程名称来终止进程,当需要结束系统中多个相同名称的进程时,使用 killall 命令将更加方便,效率更高
  • killall 命令同样也有“-9”选项
  • 示例:
##执行“killall -9 vim”命令可将所有名为 vim 的进程都强行终止
[root@localhost ~]# vim testfile1	//挂起第 1 个 vim 测试进程
[1]+   Stopped	vim testfile1
[root@localhost ~]# vim testfile2	//挂起第 2 个 vim 测试进程
[2]+   Stopped	vim testfile2
[root@localhost ~]# jobs -l		//确认待终止的进程信息[1]-   7144 Stopped	vim testfile1
[2]+   7153 Stopped	vim testfile2
[root@localhost ~]# killall -9 vim	//通过进程名终止多个进程[root@localhost ~]# jobs -l
[1]-   7144 Killed	vim testfile1
[2]+   7153 Killed	vim testfile2

3.3.3 使用 pkill 命令终止进程

  • 使用 pkill 命令可以根据进程的名称、运行该进程的用户、进程所在的终端等多种属性终止特定的进程
  • 大部分选项与 pgrep 命令基本类似,如“-U”(指定用户)、“-t”(指定终端) 等选项,使用起来非常方便
  • 示例:
##要终止由用户 hackli 启动的进程(包括登录 Shell),可以执行以下操作
[root@localhost ~]# pgrep –l -U "hackli"	//确认目标进程相关信息3773 bash
[root@localhost ~]# pkill -9 -U "hackli"	//强行终止用户hackli 的进程
[root@localhost ~]# pgrep -l -U "hackli"	//确认目标进程已被终止

四、计划任务管理

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

4.1 at 一次性任务设置

4.1.1 安装顺序

  • 使用 at 命令设置的计划任务只在指定的时间点执行一次,前提是对应的系统服务 atd 必须已经运行
  • 需要注意的是,计划执行任务的时间、日期必须安排在当前系统的时刻之后,否则将无法正确设置计划任务
  • 设置一次性计划任务时,在 at 命令行中依次指定计划执行任务的时间、日期作为参数(若只指定时间则表示当天的该时间,若只指定日期则表示该日期的当前时间),确认后将进入带“at>”提示符的任务编辑界面,每行设置一条执行命令,可以依次设置多条语句,最后按 Ctrl+D 组合键提交任务。所设置的命令操作将在计划的时间点被依次执行
##以下操作先通过 date 命令确认当前的系统时间,并设置在 201757 日的10:35 自动执行以下任务:统计该时间点系统中由 root 用户运行的进程的数量,并将该数值保存到/tmp/ps.root 文件中
[root@localhost ~]# date
Sun May 7 10:33:13 EDT 2017
[root@localhost ~]# at 10:35 2017-05-07
at> pgrep -U root | wc -l > /tmp/ps.root
at> <EOT>	//任务设置完毕后按Ctrl+D 组合键提交
job 1 at Sun May 7 10:35:00 2017
[root@localhost ~]# cat /tmp/ps.root	//等过了计划时间后验证命令结果202

##以下操作将设置一条计划任务,在当天的 21:30 自动关闭当前系统
[root@localhost ~]# at 21:30
at> shutdown -h now at> <EOT>

job 2 at Sun May 7 21:30:00 2017

##对于已经设置但还未执行(未到时间点)的计划任务,可以通过 atq 命令进行查询。但已执行过的 at 任务将不会再出现在列表中
[root@localhost ~]# atq
2 Sun May 7 21:30:00 2017 a root

##若要删除指定编号的 at 任务,可以使用 atrm 命令。删除后的 at 任务将不会被执行, 并且不会显示在 atq 命令的显示结果中,但已经执行过的任务无法删除
[root@localhost ~]# atrm 2	//删除第 2 条 at 计划任务
[root@localhost ~]# atq	//确认第 2 条任务已被删除

五、crontab 周期性任务设置

  • 使用 crontab 命令设置的计划任务可以按预设的周期重复执行,从而大大减轻设置重复性系统管理任务的操作
  • 启用周期性任务也有一个前提条件,即对应的系统服务 crond 必须已经运行

5.1 crontab 的配置文件和目录

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

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

  • /etc/crontab 文件中设置的是维护 Linux 操作系统所需的任务,Linux 操作系统及相关程序在安装时可自动设置,不建议用户手动修改此文件
  • 示例:
##该文件中包括设置 Shell 环境、可执行路径等变量的操作,以及每小时、每天、每周、每月需要执行的任务目录
##执行如下的“cat/etc/crontab”命令可以查看/etc/crontab 文件的具体内容
[root@localhost ~]# cat /etc/crontab
SHELL=/bin/bash	//设置执行计划任务的Shell 环境
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 将按照不同的周期重复执行相应目录中的任务脚本文件

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

  • 由用户自行设置(使用 crontab 命令)的 cron 计划任务将被保存到目录/var/spool/cron/ 中,文件名与用户名相同
  • 示例:
##通过如下操作可以得知,root 用户的 cron 计划任务保存在配置文件/var/spool/cron/root 中
[root@localhost ~]# ls -l /var/spool/cron/*
-rw-------. 1 root root 33 May 7 11:01 /var/spool/cron/root
  • crond 守护进程会自动检查/etc/crontab 文件、/etc/cron.d/目录及 /var/spool/cron/目录中的改变,如果发现有配置更改,它们就会被载入内存,所以当某个 crontab 文件改变后并不需要重新启动 crond 守护进程就可以使设置生效

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

  • 设置用户的周期性计划任务列表主要通过 crontab 命令进行,结合不同的选项可以完成不同的计划任务管理操作
  • 常用选项
选项解释
-e编辑计划任务列表
-u指定所管理的计划任务属于哪个用户,默认是针对当前用户(自己),一般只有 root 用户有权限使用此选项(用于编辑、删除其他用户的计划任务)
-l列表显示计划任务
-r删除计划任务列表
常用选项
crontab -e [-u 用户名]  		'//编辑计划任务  e:edit,编辑,使用方式同Vim编辑器。'
crontab -l [-u 用户名] 		'//查看计划任务  l:list,列表'
crontab -r [-u 用户名]  		'//删除计划任务  r:remove,移除'

crontab -l 		'//查看当前用户的计划列表'
crontab -l -u lisi 		 '//查看lisi用户的计划任务'

crontab -e 		'//可以操作删除一条计划任务'
crontab -r 		'//删除用户所有的计划任务'

命令格式: 时间周期设置 + 任务内容设置
命令格式

5.2.1 编辑用户的计划任务列表

  • 执行“crontab -e”命令后,将打开计划任务编辑界面(与 vi 中的操作相同)
  • 通过该界面用户可以自行添加具体的任务配置,每行代表一个记录,配置的格式与/etc/crontab 文件中的主体部分类似
01 * * * * /root/run_hourly_cmd 02 4 * * * /root/run_daily_cmd
22 4 * * 0 /root/run_weekly_cmd
42 4 1 * * /root/run_monthly_cmd
50 3 2 1 * /root/run_yearly_cmd
  • 每一行任务配置记录都包括六个数据字段,分别表示不同的含义
分钟小时日期月份星期执行的命令
01****run_hourly_cmd
024***run_daily_cmd
224**0run_weekly_cmd
4241**run_monthly_cmd
50321*run_yearly_cmd
  • 由于各字段的作用不同,其取值范围也不一样
  • 当使用“*”时表示取值范围中的任意时间
  • crontab 任务配置记录中所设置的命令操作将在“分钟”+“小时”+“日期”+ “月份”+“星期”都满足的条件下执行
项目说明
分钟取值为 0~59 的任意整数小时 取值为 0~23 的任意整数
日期取值为 1~31 的任意整数(日期在该月份中必须有效)
月份取值为 1~12 的任意整数
星期取值为 0~7 的任意整数,0 或 7 代表星期
命令可以是普通的命令,也可以是自己编写的程序脚本
  • 除了“*”以外,还可以使用“-”(减号)、“,”(逗号)、“/”(斜杠)与数字构成表达式来表示较复杂的时间关系
    • 减号“-”:可以表示一个连续的时间范围,如“1-4”表示整数 1、2、3、4。
    • 逗号“,”:可以表示一个间隔的不连续范围,如“3, 4, 6, 8”。
    • 斜杠符号“/”:可以用来指定间隔频率,如在日期字段中的“*/3”表示每隔 3 天
  • 示例:
若要按固定的周期重复完成一些系统管理任务,任务内容如下:
(1)每天早上 7:50自动开启 sshd 服务,22:50 关闭 sshd 服务
(2)每隔五天清空一次 FTP 服务器公共目录/var/ftp/pub 中的数据
(3)每周六的 7:30 重新启动系统中的 httpd 服务
(4)每周一、周三、周五的下午 17:30,使用 tar 命令自动备份/etc/httpd 目录,则可由 root 用户通过 crontab 设置以下计划任务
[root@localhost ~]# crontab -e
50 7 * * * /usr/bin/systemctl start sshd.service 
50 22 * * * /usr/bin/systemctl stop sshd.servic 
0 0 */5 * * /usr/bin/rm -rf /var/ftp/pub/*
30 7 * * 6 /usr/bin/systemctl httpd restart
30 17 * * 1,3,5 /usr/bin/tar jcf httpdconf.tar.bz2 /etc/httpd/
  • 普通用户执行“crontab -e”命令时,可以设置自己的计划任务(需要注意命令的执行权限)
##用户 jerry 设置一条计划任务:在每周日晚上的 23:55/etc/passwd 文件的内容复制到宿主目录中,保存为 pwd.txt 文件
[jerry @localhost ~]# crontab -e
55 23 * * 7 /usr/bin/cp /etc/passwd /home/jerry/pwd.txt
  • 因各条计划任务在执行时并不需要用户登录,所以任务配置记录中的命令建议使用绝对路径,以避免因缺少执行路径而无法执行命令的情况
  • 另外,在设置非每分都执行的任务时, “分钟”字段也应该填写一个具体的时间数值,而不要保留为默认的“*”,否则将会在每分钟执行一次计划任务

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

  • crontab 命令结合“-l”选项可以查看当前用户的计划任务列表,对于 root 用户来说,还可以结合“-u”选项查看其他用户的计划任务
[root@localhost ~]# crontab –l	//查看用户root 自己的计划任务
50 7 * * * /usr/bin/systemctl start sshd.service 50 22 * * * /usr/bin/systemctl stop sshd.servic 0 0 */5 * * /usr/bin/rm -rf /var/ftp/pub/*
30 7 * * 6 /usr/bin/systemctl httpd restart
30 17 * * 1,3,5 /usr/bin/tar jcf httpdconf.tar.bz2 /etc/httpd/
[root@localhost ~]# crontab -l -u jerry	//查看用户jerry 的计划任务
55 23 * * 7 /usr/bin/cp /etc/passwd /home/jerry/pwd.txt [root@localhost ~]# ls -l /var/spool/cron/jerry
-rw-------. 1 root root 57 May 7 11:10 /var/spool/cron/jerry

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

  • 当只需要删除某一条计划任务时,可以通过“crontab -e”命令进行编辑
  • 而若要清空某个用户的所有计划任务,可以执行“crontab -r”命令
[jerry@localhost ~]$ crontab -r	//用户jerry 清空自己设置的计划任务
[jerry@localhost ~]$ crontab -l
no crontab for jerry
  • 在设置用户的 crontab 计划任务的过程中,由于每一条记录只能运行一行命令,难以完成更复杂的系统管理任务操作,因此在实际工作中,当需要按照固定周期运行一些操作复杂的任务时,通常会将相关命令操作编写成脚本文件,然后在计划任务配置中加载该脚本并执行
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Linux——进程和计划任务管理(理论+实验) 的相关文章

随机推荐

  • Python if else条件语句你懂了吗?

    在 Python 中 xff0c 可以使用 if else 语句对条件进行判断 xff0c 然后根据不同的结果执行不同的代码 xff0c 这称为选择结构或者分支结构 Python 中的 if else 语句可以细分为三种形式 xff0c 分
  • 嵌入式学习系统里的ROM和RAM(转载)

    一个嵌入式项目在立项时 xff0c 其中有个重要的环节就是对系统所需的RAM和ROM用量进行评估 xff0c 在满足系统需求的前提下 xff0c 尽量降低硬件成本 xff0c 据说同等大小的RAM价格大概是ROM的6倍 大部分的资料都宣称程
  • 关于Mysql8.0.22服务无法启动问题

    关于Mysql8 0 22服务无法启动问题 1 官网下载 解压完成后 不存在data文件夹 也不要自己创建 后面会用命令生成 请往后看 2 创建my ini文件 xff08 一定要放在bin目录下 xff0c 不要放在mysql8 0 22
  • 查找Ubuntu中安装软件的位置

    查找Ubuntu中安装软件的位置 下面仅自我学习记录只做参考 xff0c 不可全信 通常使用ps e 找到软件的具体名字 xff0c 然后进行位置查找 自我记录 1 执行程序查看 对于有的程序没有效果 type 软件名 2 通过进程查看 p
  • Python爬虫:第三章 数据解析 xpath解析(12)

    第三章 数据解析 xpath 解析xpath 解析基础example1 爬取58二手房中的房源信息example2 解析下载图片数据example3 全国城市名称爬取 xpath 解析 xpath 解析基础 span class token
  • java获取项目文件绝对路径

    该方法是先根据指定目录创建文件目录后 xff0c 再获取起绝对路径 xff0c 可先在指定目录中放入指定文件 xff0c 这样就可以直接获取起绝对路径 span class token keyword public span span cl
  • 三分钟带你了解最成熟最流行的LAMP网站应用架构

    三分钟带你了解最成熟最流行的LAMP网站应用架构 一 LAMP概述1 各组件的主要作用2 各组件安装顺序 二 编译安装Apache httpd服务准备工作1 关闭防火墙 xff0c 将安装Apache所需软件包传到 opt目录下2 安装环境
  • IDEA通过maven配置Spring保姆级教程

    写在前面 xff1a 此篇文章主要是记录IDEA利用maven配置Spring的全过程 由于本人也是慢慢探索出来的 xff0c 所以有不全或者遗漏的地方 xff0c 还请大家斧正 请耐心看完文章 xff0c 前期工作做完后IDEA才可以配置
  • 策略梯度算法(Policy Gradient)逐行代码详解

    理论部分以及完整代码参看之前的博客 xff1a https blog csdn net qq 47997583 article details 124506650 本文章介绍的是策略梯度算法中的REINFORCE实现 上图为算法流程图 xf
  • python爬虫(自动下载图片)

    爬虫第一步下载第三方工具 requests包 win 43 R 输入cmd点击确定或回车 输入以下命令下载requests包 requests包是python爬虫常用的包 他的下载方式是 pip install requsts 如果觉得下载
  • python json格式转字典

    impor json req 61 json loads 转换的内容
  • mysql安装5.7出现闪退解决办法

    MySQL下载官网 下载地址 xff1a https dev mysql com downloads mysql 我之前用的是5 5的版本升级到5 7是将所有的数据生成到文件里 命令 mysqldump u root p all datab
  • 小程序设置、获取本都缓存、发送请求、渲染数据、转发当前页面、下拉刷新页面

    设置 获取缓存 xff0c 发送请求 xff0c 渲染数据 xff0c 转发当前页面 设置 获取本地缓存设置本地缓存 xff08 wx setStorage xff09 获取本地缓存 xff08 wx getStorageSync xff0
  • cnpm安装步骤

    安装nodeJS 官网下载 xff1a http nodejs cn download 选择其他版本下载地址 https nodejs org zh cn download releases 选版本点击下载 然后下载后缀名为msi 因为安装
  • likeadmin权限管理菜单报错:AxiosError

    报错图片 xff1a 这个原因是后端返回的 JSON 数据太多而导致前端报错 xff0c 可能是因为前端无法处理大量数据 下面是一些可能导致前端代码处理大量数据出现问题 返回json数据中的末尾有说到数据太多了的原因 然后我去数据库的sys
  • Vue安装

    Vue安装 一 安装二 使用步骤1 在项目中使用vue2 使用命令创建vue项目 一 安装 安装vue之前需要安装nodeJS 1 需要安装Node js 可以从官方网站进行下载并安装 2 这篇博客有详细的步骤 Node js安装详解 3
  • Thinkphp6模型关联

    文章目录 前言一 一对一关联示例 二 一对多三 多对多四 示例总结hasManybelongsTohasOne 前言 ThinkPHP 6 模型关联是指使用 PHP 对象关系映射 xff08 ORM xff09 机制 xff0c 通过模型类
  • Linux----生产者与消费者

    生产者与消费者 模型场景分析 xff1a 编程流程 xff1a 生产者同步流程消费者同步流程 代码实现主函数生产者线程函数消费者线程函数 模型场景 分析 xff1a 缓冲区buff中存放数据 生产者和消费者数目不固定 xff0c 生产者向缓
  • 一篇文章了解Like用法及常见索引失效情况

    1 简介 本文主要通过介绍Like索引及常见索引失效情况 xff0c 以MySQL为例 2 EXPLAIN关键字 一条查询语句在经过MySQL查询优化器的各种基于成本和规则的优化会后生成一个所谓的执行计划 EXPLAIN 语句 就可以看到某
  • Linux——进程和计划任务管理(理论+实验)

    目录 前言一 程序 进程线程概述1 1 程序1 2 进程1 3 线程1 4 程序 进程和线程的关系1 5 程序和进程的关系 二 查看进程2 1 1 ps 命令 查看静态的进程统计信息 xff08 Processes Statistic xf