Linux一次性计划任务at命令使用详解

目录
  • 前言
  • 1.一次性计划任务的介绍
  • 2.命令
  • 3.创建一次性计划任务
  • 4.一次性计划任务管理
    • 4.1 查看一次性计划任务
    • 4.2 删除一次性计划任务
    • 4.3查看一次性计划任务的详细信息
  • 5.一次性计划任务使用控制

前言

计划任务,就是有计划的任务,就是我们想按照我们的计划自动的执行任务。

关键点有 2 个:

第一个是计划,第二个是自动。

1.一次性计划任务的介绍

所谓一次性计划任务,就是按照 计划 只 执行一次 的任务。

2.命令

Linux中的 at 命令就是用来创建一次性计划任务的,at 命令有一个服务 atd 会以后台模式运行,检查当前的时间来决定是否运行“计划”。

默认情况下,atd 服务每 60 秒检查一次目录,有“计划”时,会检查“计划”运行时间,如果“计划运行”的时间与当前时间匹配,则运行此“计划”。

3.创建一次性计划任务

首先,at 服务必须要开:

systemctl start atd

查看 atd 的状态(是否为active):

systemctl status atd

查看是否开启:

systemctl is-active atd

停掉atd服务(将不能再执行一次性计划任务):

systemctl stop atd

[root@localhost ~]# vim /root/backup-yum-repo.sh
[root@localhost ~]# cat /root/backup-yum-repo.sh
#!/bin/bash
mkdir /opt/yum-repo-backup-dir -p
cp -r /etc/yum.repos.d /opt/yum-repo-backup-dir/yum.repos.d-`date +"%Y-%m-%d-%H:%M:%S"`.bak
[root@localhost ~]# chmod +x backup-yum-repo.sh

使用 at 命令来执行一次性备份 yum 仓库文件,为了顺利的查看 at 的执行结果,使用下面命令来关闭 ntp 同步,并设置当前时间

#timedatectl set-ntp 0 命令关闭了 ntp 同步
[root@localhost ~]# timedatectl set-ntp 0
#date -s "2021-12-1 16:58:30" 命令设置日期和时间
[root@localhost ~]# date -s "2021-12-1 16:58:30"

示例一:具体时间的一次性计划任务

下午的5点执行,即17:00执行(如果此时的时间已经过了当天下午,那么,顺延到第二天)

# 下面命令中的 <EOT> 是提交 at 的计划任务,使用ctrl+d即可出现
[root@localhost ~]# at 5:00PM
warning: commands will be executed using /bin/sh
at> /root/backup-yum-repo.sh
at> <EOT>
job 5 at Wed Dec  1 17:00:00 2021
# atq 查看一次性计划任务
[root@localhost ~]# atq
5	Wed Dec  1 17:00:00 2021 a root
[root@localhost ~]# date;atq;ls /opt/yum-repo-backup-dir/
Wed Dec  1 16:59:50 CST 2021
5	Wed Dec  1 17:00:00 2021 a root
[root@localhost ~]# date;atq;ls /opt/yum-repo-backup-dir/
Wed Dec  1 17:00:02 CST 2021
yum.repos.d-2021-12-01-17:00:00.bak

示例二:具体日期的一次性计划任务

2021年12月12号的此刻执行某脚本。

如果没有指定time,那么就是定制计划任务的time作为执行天的time。(若指定的日期为当天日期,则会在下一分钟执行计划任务)

[root@localhost ~]# at 2021-12-12
warning: commands will be executed using /bin/sh
at> /root/backup-yum-repo.sh
at> <EOT>
job 6 at Sun Dec 12 17:07:00 2021
[root@localhost ~]# atq
6	Sun Dec 12 17:07:00 2021 a root

示例三:具体日期和时间的一次性计划任务

在2021年12月13号的12点12分执行

[root@localhost ~]# at 12:12 2021-12-13
warning: commands will be executed using /bin/sh
at> /root/backup-yum-repo.sh
at> <EOT>
job 7 at Mon Dec 13 12:12:00 2021
[root@localhost ~]# atq
6	Sun Dec 12 17:07:00 2021 a root
7	Mon Dec 13 12:12:00 2021 a root

示例四:在5天后的9点15分执行

[root@localhost ~]# atq
6	Sun Dec 12 17:07:00 2021 a root
7	Mon Dec 13 12:12:00 2021 a root
[root@localhost ~]# at 9:15 + 5 days
warning: commands will be executed using /bin/sh
at> /root/backup-yum-repo.sh
at> <EOT>
job 8 at Mon Dec  6 09:15:00 2021
[root@localhost ~]# atq
6	Sun Dec 12 17:07:00 2021 a root
7	Mon Dec 13 12:12:00 2021 a root
8	Mon Dec  6 09:15:00 2021 a root

示例五:在周一执行

[root@localhost ~]# atq
6	Sun Dec 12 17:07:00 2021 a root
7	Mon Dec 13 12:12:00 2021 a root
8	Mon Dec  6 09:15:00 2021 a root
[root@localhost ~]# at monday
warning: commands will be executed using /bin/sh
at> /root/backup-yum-repo.sh
at> <EOT>
job 9 at Mon Dec  6 17:18:00 2021
[root@localhost ~]# atq
6	Sun Dec 12 17:07:00 2021 a root
7	Mon Dec 13 12:12:00 2021 a root
8	Mon Dec  6 09:15:00 2021 a root
9	Mon Dec  6 17:18:00 2021 a root

注:不能用过去的时间使用 at ,没有后悔药的

4.一次性计划任务管理

4.1 查看一次性计划任务

atq

[root@localhost ~]# atq
6	Sun Dec 12 17:07:00 2021 a root
7	Mon Dec 13 12:12:00 2021 a root
8	Mon Dec  6 09:15:00 2021 a root
9	Mon Dec  6 17:18:00 2021 a root

4.2 删除一次性计划任务

atrm

[root@localhost ~]# atq
6	Sun Dec 12 17:07:00 2021 a root
7	Mon Dec 13 12:12:00 2021 a root
8	Mon Dec  6 09:15:00 2021 a root
9	Mon Dec  6 17:18:00 2021 a root
[root@localhost ~]# atrm 8
[root@localhost ~]# atq
6	Sun Dec 12 17:07:00 2021 a root
7	Mon Dec 13 12:12:00 2021 a root
9	Mon Dec  6 17:18:00 2021 a root

4.3查看一次性计划任务的详细信息

at -c job_id

[root@localhost ~]# atq
6	Sun Dec 12 17:07:00 2021 a root
7	Mon Dec 13 12:12:00 2021 a root
9	Mon Dec  6 17:18:00 2021 a root
[root@localhost ~]# at -c 7

5.一次性计划任务使用控制

at.allow (/etc/at.allow)

at.deny (/etc/at.deny)

用户可以使用 at 命令设置一次性计划任务,那么 也可以控制哪些用户可以使用计划任务(在白名单中),哪些用户不可以使用计划任务

at 一次性计划任务的白名单是 at.allow ,黑名单是 at.deny 。不建议既使用白名单,又使用黑名单。

建议使用白名单,at.allow 的优先级高于 at.deny。即:wang 既在白名单,又在黑名单,则 wang 可以执行at

默认在rhel8.0系统中没有 at.allow 文件,可以自己创建。

# 将用户 wang 添加到黑名单
[root@localhost ~]# cat /etc/at.deny
wang
[root@localhost ~]# su - wang
[wang@localhost ~]$ at
You do not have permission to use at.
# 将用户 wang 既添加到黑名单,又添加到白名单
[root@localhost ~]# cat /etc/at.allow
wang
[root@localhost ~]# cat /etc/at.deny
wang
[root@localhost ~]# su - wang
[wang@localhost ~]$ at
Garbled time

到此这篇关于Linux一次性计划任务at命令使用详解的文章就介绍到这了,更多相关Linux一次性计划任务内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Linux用户自定义at、cron计划任务执行的方法

    Linux系统中有两种计划任务,一种是只会执行一次 at 计划任务,一种是可以周期性地执行的 cron 计划任务 at 一次性计划任务 描述 在指定的时间执行特定命令(单次),也称为延时动作任务. 用法 at 时间 [回车] 参数 at -l #列出单次计划任务 at -r 任务id ##删除此id的任务 at -d 任务id ##删除此id的任务 at -m #让无输出的命令产生邮件 at -M #让有输出的命令产生邮件 at -c 任务id ##产看此id任务的动作 at -f 文件 ##用

  • Linux一次性计划任务at命令使用详解

    目录 前言 1.一次性计划任务的介绍 2.命令 3.创建一次性计划任务 4.一次性计划任务管理 4.1 查看一次性计划任务 4.2 删除一次性计划任务 4.3查看一次性计划任务的详细信息 5.一次性计划任务使用控制 前言 计划任务,就是有计划的任务,就是我们想按照我们的计划自动的执行任务. 关键点有 2 个: 第一个是计划,第二个是自动. 1.一次性计划任务的介绍 所谓一次性计划任务,就是按照 计划 只 执行一次 的任务. 2.命令 Linux中的 at 命令就是用来创建一次性计划任务的,at

  • Linux上的文件搜索命令实例详解

    locate 基础了解 在centos7上默认没有locate命令,需要先手动安装.安装步骤:http://www.cnblogs.com/feanmy/p/7676717.html locate命令搜索的后台数据库路径:/var/lib/mlocate/mlocate.db ls -hl /var/lib/mlocate total 1.2M -rw-r----- 1 root slocate 1.2M Oct 16 14:36 mlocate.db 更新数据库使用updatedb,配置文件为

  • Linux 中常用的Rpm命令实例详解

    rpm命令是RPM软件包的管理工具.rpm原本是Red Hat Linux发行版专门用来管理Linux各项套件的程序,由于它遵循GPL规则且功能强大方便,因而广受欢迎.逐渐受到其他发行版的采用.RPM套件管理方式的出现,让Linux易于安装,升级,间接提升了Linux的适用度. 语法 rpm(选项)(参数) 选项 -a:查询所有套件: -b<完成阶段><套件档>+或-t <完成阶段><套件档>+:设置包装套件的完成阶段,并指定套件档的文件名称: -c:只列出

  • linux下scp和sftp命令使用详解

    目录 前言 1. scp 使用 2. sftp 使用 3. scp 和 sftp 有啥区别?用哪个好? 总结 前言 scp 和 sftp 是一种远程文件加密传输协议,讲通俗点就是用来操控本地/远程文件,不知道你注意到了没有,它们开头都带了 s,是的,它们嵌套了一层 ssh 加密协议. 像 sftp 它的传统版本就是 ftp,但这种协议不安全,传输数据是都是明文的,很容易受到攻击窃取,所以才有了后来的 sftp,其实就跟 http / https 同个道理. 如果你还没了解过 ssh 可以参考我之

  • linux shell脚本学习xargs命令使用详解

    xargs是给命令传递参数的一个过滤器,也是组合多个命令的一个工具.它把一个数据流分割为一些足够小的块,以方便过滤器和命令进行处理.通常情况下,xargs从管道或者stdin中读取数据,但是它也能够从文件的输出中读取数据.xargs的默认命令是echo,这意味着通过管道传递给xargs的输入将会包含换行和空白,不过通过xargs的处理,换行和空白将被空格取代. xargs 是一个强有力的命令,它能够捕获一个命令的输出,然后传递给另外一个命令,下面是一些如何有效使用xargs 的实用例子. 1.

  • Linux ftp 命令行中下载文件get与上传文件put的命令应用详解

    介绍:从本地以用户anok登录的机器192.168.0.16上通过ftp远程登录到192.168.0.6的ftp服务器上,登录用户名是peo.以下为使用该连接做的实验. 查看远程ftp服务器上用户peo相应目录下的文件所使用的命令为:ls,登录到ftp后在ftp命令提示符下查看本地机器用户anok相应目录下文件的命令是:!ls.查询ftp命令可在提示符下输入:?,然后回车. 1.从远程ftp服务器下载文件的命令格式: get  远程ftp服务器上当前目录下要下载的文件名  [下载到本地机器上当前

  • linux 查看端口占用命令实例详解

     linux 查看端口占用命令实例详解 端口是系统非常重要的一个东东,我们经常需要查看哪个进程占用了哪个端口,或者哪个端口被哪个进程占用.废话不多说,直接上干货,教大家怎样查看系统端口占用情况. 方法一: 1.先用ps -ef | grep xxx(某个进程),可以查看某个进程的pid. 2.再用netstat -anp | grep pid号,可以查看到该进程占用的端口号! 方法二: 直接用lsof命令可以查看端口使用情况! 以上就是对linux 查看端口占用命令的讲解,如有疑问请留言,或者到

  • linux下防火墙开启某个端口号及防火墙常用命令使用(详解)

    1.永久性生效,重启后不会复原 开启:chkconfigiptables on 关闭:chkconfigiptables off 2.即时生效,重启后复原 重启防火墙 方式一:/etc/init.d/iptables restart 方式二:service iptables restart 关闭防火墙: 方式一:/etc/init.d/iptables stop 方式二:service iptables stop 启动防火墙 方式一:/etc/init.d/iptables start 方式二:

  • Linux中mysqldump命令实例详解

    mysqldump是mysql数据库中备份工具,用于将MYSQL服务器中的数据库以标准的sql语言的方式导出,并保存到文件中. 语法: mysqldump (选项) 选项: --add-drop-table :在每个创建数据表语句前添加删除数据库的语句  --add-locks:备份数据库表时锁定数据库表  --all-databases:备份mysql服务器上的所有数据库  --comments:添加注释信息  --compact:压缩模式,产生更少的输出  --complete-insert

  • linux 中的ls命令参数详解及ls命令的使用实例

    一.ls命令参数详解 可以通过阅读 ls 的说明书页(man ls)来获得选项的完整列表. -a – 全部(all).列举目录中的全部文件,包括隐藏文件(.filename).位于这个列表的起首处的 .. 和 . 依次是指父目录和你的当前目录. -l – 长(long).列举目录内容的细节,包括权限(模式).所有者.组群.大小.创建日期.文件是否是到系统其它地方的链接,以及链接的指向. -F – 文件类型(File type).在每一个列举项目之后添加一个符号.这些符号包括:/ 表明是一个目录:

随机推荐