前言
如何去查看进程、调用进程,生产环境中经常需要查看进程的使用率,来调优;进程又分为前台和后台,那么如何启动进程,怎么去调用前后台改变的一个运营方式;如果进程挂了,怎么终止进程
一、程序和进程的关系
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命令
例:
[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"
5822 sshd
[root@localhost ~]# kill 5822
[root@localhost ~]# pgrep -l "sshd"
对于无法正常终止的系统进程,在必要时可以结合“-9”选项强制终止。例如,以下操作展示了强制终止 vim 进程的过程
[root@localhost ~]# vim testfile &
[1]+ Stopped vim testfile
[root@localhost ~]# jobs –l
[1]+ 7095 Stopped vim testfile
[root@localhost ~]# kill 7095
[root@localhost ~]# kill -9 7095
2.2 使用 killall 命令终止进程
使用 killall 命令可以通过进程名称来终止进程,当需要结束系统中多个相同名称的进程时,使用 killall 命令将更加方便,效率更高。killall 命令同样也有“-9”选项。
例如,执行如下的“killall -9 vim”命令可将所有名为 vim 的进程都强行终止
[root@localhost ~]# vim testfile1 &
[1]+ Stopped vim testfile1
[root@localhost ~]# vim testfile2 &
[2]+ Stopped vim testfile2
[root@localhost ~]# jobs -l
[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
[root@localhost ~]# pkill -9 -U "lz"
[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
2021年 08月 16日 星期一 16:20:58 +00
[root@kgc /]# at 16:23 2021-08-16
at> pgrep -U root | wc -l > /tmp/ps.root
at> <EOT><EOT>
job 1 at Mon Aug 16 16:23:00 2021
[root@localhost ~]# cat /tmp/ps.root
例2:
以下操作将设置一条计划任务,在当天的 21:30 自动关闭当前系统。
[root@localhost ~]# at 21:30
at> shutdown -h now
at> <EOT>
- 对于已经设置但还未执行(未到时间点)的计划任务,可以通过 atq 命令进行查询。但已执行过的 at 任务将不会再出现在列表中。具体操作如下:
[root@localhost ~]# atq
2 Sun May 7 21:30:00 2017 a root
- 若要删除指定编号的 at 任务,可以使用 atrm 命令。删除后的 at 任务将不会被执行, 并且不会显示在 atq 命令的显示结果中,但已经执行过的任务无法删除。具体操作如下:
[root@localhost ~]# atrm 2
[root@localhost ~]# atq
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
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
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@localhost ~]$ crontab -l
[jerry@localhost ~]$ crontab -l
no crontab for jerry
总结
- 查看进程的命令(ps、top、pgrep.pstree)
- 进程控制:
- at命令设置计划任务
- crontab计划任务的配置字段
|