IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> Linux中进程和计划任务管理 -> 正文阅读

[系统运维]Linux中进程和计划任务管理


前言

如何去查看进程、调用进程,生产环境中经常需要查看进程的使用率,来调优;进程又分为前台和后台,那么如何启动进程,怎么去调用前后台改变的一个运营方式;如果进程挂了,怎么终止进程


一、程序和进程的关系

1.程序

  • 保存在硬盘、光盘等介质中的可执行代码和数据
  • 静态保存的代码

2.进程

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

二、查看进程信息

1. ps命令

1.1 查看静态的进程统计信息

[root@localhost ~]# ps aux
将以简单列表的形式显示出进程信息

参数:

-a:显示当前终端下的所有进程信息,包括其他用户的进程。与“x”选项结合时将显示系统中所有的进程信息。
-u:使用以用户为主的格式输出进程信息。
-x:显示当前用户在所有终端下的进程信息

USER        PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root          1  4.2  0.3  46236  6784 ?        Ss   15:26   0:01 /usr/lib/systemd/systemd --swi
root          2  0.0  0.0      0     0 ?        S    15:26   0:00 [kthreadd]
root          3  0.0  0.0      0     0 ?        S    15:26   0:00 [ksoftirqd/0]
root          4  0.0  0.0      0     0 ?        S    15:26   0:00 [kworker/0:0]
root          5  0.0  0.0      0     0 ?        S<   15:26   0:00 [kworker/0:0H]
root          6  0.0  0.0      0     0 ?        S    15:26   0:00 [kworker/u256:0]
root          7  0.0  0.0      0     0 ?        S    15:26   0:00 [migration/0]
root          8  0.0  0.0      0     0 ?        S    15:26   0:00 [rcu_bh]
root          9  0.0  0.0      0     0 ?        S    15:26   0:00 [rcu_sched]
root         10  0.0  0.0      0     0 ?        S    15:26   0:00 [watchdog/0]
root         11  0.0  0.0      0     0 ?        S    15:26   0:00 [watchdog/1]
root         12  0.0  0.0      0     0 ?        S    15:26   0:00 [migration/1]
root         13  0.0  0.0      0     0 ?        S    15:26   0:00 [ksoftirqd/1]
root         14  0.0  0.0      0     0 ?        S    15:26   0:00 [kworker/1:0]
root         15  0.0  0.0      0     0 ?        S<   15:26   0:00 [kworker/1:0H]
root         16  0.0  0.0      0     0 ?        S    15:26   0:00 [watchdog/2]
root         17  0.0  0.0      0     0 ?        S    15:26   0:00 [migration/2]
root         18  0.0  0.0      0     0 ?        S    15:26   0:00 [ksoftirqd/2]

# 上述输出信息中,第一行为列表标题,其中各字段的含义描述如下。
# USER:启动该进程的用户账号的名称。
# PID:该进程在系统中的数字 ID 号,在当前系统中是唯一的。
# %CPU:CPU 占用的百分比。
# %MEM:内存占用的百分比。
# VSZ:该进程使用的虚拟内存量(KB)。
# RSS:该进程占用的物理内存量(KB)。
# TTY:表明该进程在哪个终端上运行。不是从终端启动的进程则显示为?。
# STAT:该进程的状态
# START:启动该进程的时间。
# TIME:该进程占用的 CPU 时间。
# COMMAND:启动该进程的命令的名称  


1.1.1 STAT常见状态的含义

-D:不可被唤醒的睡眠状态,通常用于 I/O 情况。
-R:该进程正在运行。
-S:该进程处于睡眠状态,可被唤醒。
-T:停止状态,可能是在后台暂停或进程处于除错状态。
-W:内存交互状态(从 2.6 内核开始无效)。
-X:死掉的进程(应该不会出现)。
-Z:僵尸进程。进程已经中止,但是部分程序还在内存当中。
-<:高优先级(以下状态在 BSD 格式中出现)。
-N:低优先级。
-L:被锁入内存。
-s:包含子进程。
-l:多线程(小写 L)。
-+:位于后台。
-C:进程占用CPU的百分比


#### 1.1.2 查看进程状态例子
[root@localhost ~]# vim 1.txt    

在另一个终端执行:
[root@localhost ~]# ps aux | grep 1.txt  
root       1921  0.0  0.2 151764  5312 pts/1    S+   16:14   0:00 vim 1.txt
root       1975  0.0  0.0 112676   996 pts/0    S+   16:16   0:00 grep --color=auto 1.txt
#查看1.txt的状态;S表示睡眠状态,+表示前台

再回到执行vim 1.txt 的终端上,按ctrl+z :
[root@localhost ~]# vim 1.txt

[2]+  已停止               vim 1.txt

再在另一个终端执行:
[root@localhost ~]# ps aux |grep 1.txt
root       1921  0.0  0.2 151764  5312 pts/1    T    16:14   0:00 vim 1.txt
root       2030  0.0  0.0 112676   992 pts/1    S+   16:21   0:00 grep --color=auto 1.txt
#查看状态T表示停止状态

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

1.2 查看静态的进程统计信息

[root@localhost ~]# ps -elf
将以长格式显示系统中的进程信息

参数:

- e:显示系统内的所有进程信息。
- 1:使用长格式显示进程信息。
- f:使用完整的格式显示进程信息。.

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 15:53 ?        00:00:01 /usr/lib/systemd/sy
1 S root          2      0  0  80   0 -     0 kthrea 15:53 ?        00:00:00 [kthreadd]
1 S root          3      2  0  80   0 -     0 smpboo 15:53 ?        00:00:00 [ksoftirqd/0]
1 S root          5      2  0  60 -20 -     0 worker 15:53 ?        00:00:00 [kworker/0:0H]
1 S root          7      2  0 -40   - -     0 smpboo 15:53 ?        00:00:00 [migration/0]
1 S root          8      2  0  80   0 -     0 rcu_gp 15:53 ?        00:00:00 [rcu_bh]
1 S root          9      2  0  80   0 -     0 rcu_gp 15:53 ?        00:00:00 [rcu_sched]
5 S root         10      2  0 -40   - -     0 smpboo 15:53 ?        00:00:00 [watchdog/0]
5 S root         11      2  0 -40   - -     0 smpboo 15:53 ?        00:00:00 [watchdog/1]
1 S root         12      2  0 -40   - -     0 smpboo 15:53 ?        00:00:00 [migration/1]
1 S root         13      2  0  80   0 -     0 smpboo 15:53 ?        00:00:00 [ksoftirqd/1]
1 S root         15      2  0  60 -20 -     0 worker 15:53 ?        00:00:00 [kworker/1:0H]
5 S root         16      2  0 -40   - -     0 smpboo 15:53 ?        00:00:00 [watchdog/2]
1 S root         17      2  0 -40   - -     0 smpboo 15:53 ?        00:00:00 [migration/2]
1 S root         18      2  0  80   0 -     0 smpboo 15:53 ?        00:00:00 [ksoftirqd/2]
1 S root         20      2  0  60 -20 -     0 worker 15:53 ?        00:00:00 [kworker/2:0H]
5 S root         21      2  0 -40   - -     0 smpboo 15:53 ?        00:00:00 [watchdog/3]
1 S root         22      2  0 -40   - -     0 smpboo 15:53 ?        00:00:00 [migration/3]
1 S root         23      2  0  80   0 -     0 smpboo 15:53 ?        00:00:00 [ksoftirqd/3]
1 S root         25      2  0  60 -20 -     0 worker 15:53 ?        00:00:00 [kworker/3:0H]
5 S root         27      2  0  80   0 -     0 devtmp 15:53 ?        00:00:00 [kdevtmpfs]
1 S root         28      2  0  60 -20 -     0 rescue 15:53 ?        00:00:00 [netns]
1 S root         29      2  0  80   0 -     0 watchd 15:53 ?        00:00:00 [khungtaskd]
1 S root         30      2  0  60 -20 -     0 rescue 15:53 ?        

# 上述输出信息中,第一行为列表标题,其中各字段的含义描述如下。
# F:内核分配给进程的系统标记。
# S:进程的状态。
# UID:启动这些进程的用户。
# PID: 进程的进程ID.
# PPID:父进程的进程号(如果该进程是由另一“个进程启动的)
# C:进程生命周期中的CPU利用率。
# PRI:进程的优先级(越大的数字代表越低的优先级)。
# NI: 谦让度值用来参与决定优先级。
# ADDR:进程的内存地址。
# SZ:假如进程被换出,所需交换空间的大致大小。
# WCHAN:若该进程在睡眠,则显示睡眠中的系统函数名。
# STIME:进程启动时的系统时间。
# TTY:进程启动时的终端设备。   pts/0255代表虚拟终端,一般是远程连接的终端;tty1 tty7 代表本地控制台终端
# TIME:运行进程需要的累计CPU时间。
# CMD:进程的启动命令。


2.top命令

2.1 查看动态的进程排名信息

[root@localhost ~]# top

top - 16:29:25 up 35 min,  2 users,  load average: 0.01, 0.02, 0.04
Tasks: 160 total,   1 running, 157 sleeping,   2 stopped,   0 zombie
%Cpu(s):  0.0 us,  0.1 sy,  0.0 ni, 99.8 id,  0.1 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem :  1867048 total,  1010360 free,   311472 used,   545216 buff/cache
KiB Swap:  4194300 total,  4194300 free,        0 used.  1332024 avail Mem 

   PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND                   
   116 root      20   0       0      0      0 S   0.3  0.0   0:01.02 kworker/0:2               
   602 root      20   0  231564   6284   4916 S   0.3  0.3   0:01.87 vmtoolsd                  
     1 root      20   0  128164   6836   4076 S   0.0  0.4   0:01.12 systemd                   
     2 root      20   0       0      0      0 S   0.0  0.0   0:00.00 kthreadd                  
     3 root      20   0       0      0      0 S   0.0  0.0   0:00.00 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.00 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.22 rcu_sched                 
    10 root      rt   0       0      0      0 S   0.0  0.0   0:00.01 watchdog/0                
    11 root      rt   0       0      0      0 S   0.0  0.0   0:00.00 watchdog/1                
    12 root      rt   0       0      0      0 S   0.0  0.0   0:00.00 migration/1               
    13 root      20   0       0      0      0 S   0.0  0.0   0:00.00 ksoftirqd/1               
    15 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 kworker/1:0H              
    16 root      rt   0       0      0      0 S   0.0  0.0   0:00.00 watchdog/2                
    17 root      rt   0       0      0      0 S   0.0  0.0   0:00.00 migration/2               
    18 root      20   0       0      0      0 S   0.0  0.0   0:00.05 ksoftirqd/2               
    20 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 kworker/2:0H              
    21 root      rt   0       0      0      0 S   0.0  0.0   0:00.00 watchdog/3                
    22 root      rt   0       0      0      0 S   0.0  0.0   0:00.01 migration/3               
    23 root      20   0       0      0      0 S   0.0  0.0   0:00.00 ksoftirqd/3               
    25 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 kworker/3:0H              
    27 root      20   0       0      0      0 S   0.0  0.0   0:00.00 kdevtmpfs                 
    28 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 netns    


# 上述输出信息中,开头的部分显示了系统任务(Tasks)、CPU占用、内存占用(Mem)、交换空间(Swap)等汇总信息,汇总信息下方依次显示当前进程的排名情况。相关信息的含义表述如下。

#uptime信息:
        # 16:29:25	当前时间
        # up 35 min	系统运行时间 ,说明此服务器连续运行 35分钟
		# 2 user	当前登录用户数
 	    # load average: 0.01, 0.02, 0.04	系统负载,即任务队列的平均长度。 三个数值分别为 1 分钟、5 分钟、15 分钟前到现在的平均值。   

# 系统任务(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,可用物理空间。

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

  • 按 s 修改刷新时间,默认 3s 刷新一次;按空格 立即刷新。
  • 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 键确认即可终止对应的进程。


3.pgrep命令

  • 根据特定条件查询进程PID信息

例:

[root@localhost ~]# pgrep -l ‘log’
[root@localhost ~]# pgrep -l -U teacher -t tty1

参数:

-l: 选项可同时输出对应的进程名以及PID
-U:选项查询特定用户的进程
-t :选项查询在特定终端运行的进程


4.pstree命令

  • 以树形结构列出进程信息
    pstree 命令默认情况下只显示各进程的名称

例:

[root@localhost ~]# pstree -aup
[root@localhost ~]# pstree -ap root

参数:

-p:选项使用时可以同时列出对应的PID号
-u:选项可以列出对应的用户名
-a:选项可以列出完整的命令信息

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


三、进程的启动方式

1.手工启动

  • 前台启动:用户输入命令,直接执行程序
  • 后台启动:在命令行尾加入“&”符号

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

进程在前台运行(如执行“ls-l”命令)时,用户必须等到该进程执行结束并退出以后才能继续输入其他命令,大多数命令操作在前台启动运行。进程在后台运行时,用户可以继续在当前终端中输入其他命令,而无须等待该进程结束,适用于运行耗时较长的操作。

启动后台进程需要使用“&”操作符,将“&”操作符放在要执行命令的最后面,进程启动后会直接放入后台运行,而不占用前台的命令操作界面,方便用户进行其他操作。例如,当使 用 cp 命令从光盘中制作镜像文件时,由于需要复制的数据较多,耗时较长,因此可结合“&” 符号将复制操作放到后台运行,以便用户可以继续执行其他命令操作

例:

[root@localhost ~]# cp /dev/cdrom mycd.iso &
[3] 4355


2.调度启动

  • 使用at命令,设置一次性计划任务
  • 使用crontab命令,设置周期性计划任务

在服务器维护工作中,经常需要执行一些比较费时而且较占用资源的任务(如数据备份),这些任务更适合在相对空闲的时候(如夜间)进行。这时就需要用户事先进行调度安排,指 定任务运行的时间,当系统到达设定时间时会自动启动并完成指定的任务。调度启动的计划 任务进程均在后台运行,不会占用用户的命令终端。
进程的调度启动可以通过 at、crontab 命令进行设置,其中 at 命令用于设置一次性(如12:15 时重启网络服务)计划任务,crontab 命令用于设置周期性运行(如每周五 17:30 备份数据库)的计划任务。


3.进程的前后台调度

3.1 Ctrl+z 组合键

  • 将当前进程挂起,即调入后台并停止运行

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

3.2 jobs命令

  • 查看处于后台的任务列表

参数

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

3.3 fg和bg命令

  • 使用 bg(BackGround,后台)命令,可以将后台中暂停执行(如按 Ctrl+Z 组合键挂起)的任务恢复运行,继续在后台执行操作
  • 使用 fg 命令(ForeGround,前台),可以将后台任务重新恢复到前台运行。
    除非后台中的任务只有一个,否则 bg 和 fg 命令都需要指定后台进程的任务编号作为参数。

例,执行如下的“fg 1”命令可以将之前挂起至后台的 wget 进程重新调入前台执行
[root@localhost ~]# jobs
[1]- Stopped cp /dev/cdrom mycd.iso
[2]+ Stopped
top [root@localhost ~]# fg 1


四、终止进程的运行

1. Ctrl+c组合键

  • 中断正在执行的命令

当用户在前台执行某个进程时,可以按Ctrl+C组合键强制进行中断(如命令长时间没有响应的情况下)。
中断前台进程的运行后,系统将返回命令行提示符状态等待用户输入新的命令。


2. kill、killall命令

  • kill用于终止指定PID号的进程
  • killall用于终止指定名称的所有进程
  • “-9”选项用于强制终止

当按 Ctrl+C 组合键无法终止程序或者需要结束在其他终端或后台运行的进程时, 可以使用专用的进程终止工具 kill、killall 和 pkill。

2.1 使用kill命令终止进程

通过 kill 命令终止进程时,需要使用进程的 PID 号作为参数。无特定选项时,kill 命令将给该进程发送终止信号并正常退出运行,若该进程已经无法响应终止信号,则可以结合“-9” 选项强行终止进程。强制终止进程时可能会导致程序运行的部分数据丢失,因此不到不得已时不要轻易使用“-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 testfile  &	//打开vim 程序并挂起作为测试
[1]+   Stopped	vim testfile
[root@localhost ~]# jobs –l	//查询目标进程的PID 号
[1]+   7095 Stopped	vim testfile

[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

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.pkill命令

  • 根据特定条件终止相应的进程

常用参数:

-U:根据进程所属的用户名终止相应进程
-t:根据进程所在的终端终止相应进程

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

例如,若要终止由用户 hmj 启动的进程(包括登录 Shell),可以执行以下操作。
su - lz
vim tst.txt &
[root@localhost ~]# pgrep –l -U "lz"
3773 bash	                            //确认目标进程相关信息3773 bash
[root@localhost ~]# pkill -9 -U "lz"	//强行终止用户hackli 的进程
[root@localhost ~]# pgrep -l -U "lz"	//确认目标进程已被终止


五、计划任务管理at

1.at命令

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

at [hh:mm] [yyy-mm-dd]
任务设置完毕后按Ctrl+D组合键提交

[root@kgc /]# date
20210816日 星期一 16:20:58 +00
[root@kgc /]# at 16:23 2021-08-16
at> pgrep -U root | wc -l > /tmp/ps.root //任务设置完毕后按Ctrl+D 组合键提交
at> <EOT><EOT>
job 1 at Mon Aug 16 16:23:00 2021

[root@localhost ~]# cat /tmp/ps.root	//等过了计划时间后验证命令结果202

例2:

以下操作将设置一条计划任务,在当天的 21:30 自动关闭当前系统。
[root@localhost ~]# at 21:30
at> shutdown -h now 
at> <EOT>                //Ctrl+D组合键提交
  • 对于已经设置但还未执行(未到时间点)的计划任务,可以通过 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 条任务已被删除

2.crontab命令

  • 按照预先设置的时间周期(分钟、小时、天…)重复执行用户指定的命令操作
  • 属于周期性计划任务
  • 主要设置文件
    - 全局配置文件,位于文件了 /etc/crontab
    - 系统默认的设置,位于目录: /etc/cron */
    - 用户定义的设置,位于文件: /varlspoollcron/用户名

参数:

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服务

2.1 管理crontab计划任务

  • 编辑计划任务
crontab -e [-u 用户名]
  • 查看计划任务
crontab -l [-u 用户名]
  • 删除计划任务
crontab -r [-u 用户名]

2.2 crontab任务配置的格式

  • 分钟 取值为 0~59 的任意整数
  • 小时 取值为 0~23 的任意整数
  • 日期 取值为 1~31 的任意整数(日期在该月份中必须有效)
  • 月份 取值为 1~12 的任意整数
  • 星期 取值为 0~7 的任意整数,0 或 7 代表星期日

2.2.1 时间数值的特殊表示方法

*表示该范围内的任意时间

减号“-”:可以表示一个连续的时间范围,如“1-4”表示整数 1、2、3、4。
逗号“,”:可以表示一个间隔的不连续范围,如“3, 4, 6, 8”。
斜杠符号“/”:可以用来指定间隔频率,如在日期字段中的“*/3”表示每隔 3 天。


2.3 例:

2.3.1若要按固定的周期重复完成一些系统管理任务,任务内容如下:

  • ①每天早上 7:50自动开启 sshd 服务,22:50 关闭 sshd 服务;
  • ②每隔五天清空一次cron FTP 服务器公共目录/var/ftp/pub 中的数据;
  • ③每周六的 7:30 重新启动系统中的 httpd 服务;
  • ④每周一、周三、周五的下午 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/
*/2 * * * * ls -lh /home/*

2.3.2 用户 jerry 设置一条计划任务:在每周日晚上的 23:55 将/etc/passwd 文件的内容复制到宿主目录中,保存为 pwd.txt 文件

普通用户执行“crontab -e”命令时,可以设置自己的计划任务(需要注意命令的执行权限)。

[jerry @localhost ~]# crontab -e
55 23 * * 7 /usr/bin/cp /etc/passwd /home/jerry/pwd.txt

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

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

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

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

[jerry@localhost ~]$ crontab -r	 //用户jerry 清空自己设置的计划任务

[jerry@localhost ~]$ crontab -l
[jerry@localhost ~]$ crontab -l
no crontab for jerry

总结

  • 查看进程的命令(ps、top、pgrep.pstree)
  • 进程控制:
    • 启动进程、调度进程、终止进程
  • at命令设置计划任务
  • crontab计划任务的配置字段
  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2021-08-18 13:05:48  更:2021-08-18 13:06:10 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/28 20:00:03-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计