0x00前言:

继上次的windows计划任务后,拓展研究下linux下的计划任务,能够执行计划任务有3个命令at,batch,crontab

所谓的计划任务就是定时启动某个程序,可以是一组shell脚本,也可以是单一的输出

0x01计划任务at命令:

at在ubuntu,kali里面都是没有预先装好的

首先用安装at

apt-get install at

查看使用帮助

at --help

#回显
at: invalid option -- '-'
Usage: at [-V] [-q x] [-f file] [-mMlbv] timespec ...
at [-V] [-q x] [-f file] [-mMlbv] -t time
at -c job ...
atq [-V] [-q x]
at [ -rd ] job ...
atrm [-V] job ...
batch

看到batch也安装了,也说明了其实他们是一类的工具,之后再讲batch

首先at的参数含义

-V       参看版本
-q x      使用x队列,可以理解为它有几组任务,每组相互独立,x就是组号。一般以abcd....英文来区别不同队列
-f file    使用文件
-m       给用户发送邮件
-M       不给用户发送邮件
-l       显示设置任务列表 
-d x      删除编号为x的任

首先来设置个输出hello的shell命令

这里的<EOT>是按ctrl+D来提交任务,使用的相对时间后移5min,在桌面创建个1.txt并写入hello linux

root@ubuntu:~/Desktop# at now + min
warning: commands will be executed using /bin/sh
at> echo "hello linux" > .txt
at> <EOT>
job at Wed Mar ::

可以查看任务

root@ubuntu:~/Desktop# at -l
Wed Mar :: a root
root@ubuntu:~/Desktop#

使用不同队列查看任务,就会发现运行的时候是默认a队列,所以b队列看不到这个任务

root@ubuntu:~/Desktop# at -q a -l
Wed Mar :: a root
root@ubuntu:~/Desktop# at -q b -l
root@ubuntu:~/Desktop#

时间到了,文本自动生成

除了能够使用相对时间以外,还可以使用绝对时间来进行定时操作

root@ubuntu:~/Desktop# at :
warning: commands will be executed using /bin/sh
at> echo "hello sijidou"
at> <EOT>
job at Wed Mar ::
root@ubuntu:~/Desktop#

使用-d来进行任务的删除,删除-d带的参数是最前面那个编号,这里是7,上面那个例子的编号是6

root@ubuntu:~/Desktop# at -l
Wed Mar :: a root
root@ubuntu:~/Desktop# at -d
root@ubuntu:~/Desktop# at -l
root@ubuntu:~/Desktop#

任务无论是删除,还是到时间正常运行,它都是累加的

使用file来进行命令设置,首先创建个2.txt,写入命令

然后使用-f 2.txt参数来设置任务

root@ubuntu:~/Desktop# at -f .txt now + min
warning: commands will be executed using /bin/sh
job at Wed Mar ::
root@ubuntu:~/Desktop#

时间到了之后,产生了3.txt文件

因为linux下的文件,其实后缀用处不大,都是看用什么指令来解释文件的内容的,看warning都知道这里at使用的/bin/sh,所以就把2.txt的内容当做shell来解释的

最后说明下两个和at有稍微区别的atq和atrm不一的

atq  列出当前的计划任务效果同 "at -l" 一样

atrm  删除计划任务

root@ubuntu:~/Desktop# at -f 2.txt now +1 min 
warning: commands will be executed using /bin/sh
job 10 at Wed Mar 6 05:36:00
root@ubuntu:~/Desktop# at -f .txt now + min
warning: commands will be executed using /bin/sh
job at Wed Mar ::
root@ubuntu:~/Desktop# atq
Wed Mar :: a root
Wed Mar :: a root
root@ubuntu:~/Desktop# atrm
root@ubuntu:~/Desktop# atq
Wed Mar :: a root
root@ubuntu:~/Desktop#

最后是关于使用at权限问题,因为at可以使用/bin/sh啊,这个权限还是不错的

能够限制权限的地方在安装at后,在/etc/目录下存在

at.deny  #一开始存在的,它默认是空,它会限制里面的用户不能使用at
at.allow  #刚安装好,并没有这个文件,但是如果创建它,它只会允许里面的用户使用at
在at.allow和at.deny都存在的情况下,看at.allow
在at.allow和at.deny都不存在的情况下,只能root使用a

但是我测试了下,at.allow中,如果没有root,但是root还是能用at

0x02计划任务batch命令:

batch同at一样都是没有默认安装的,但是安装at的时候就带了batch

但是batch不需要设置时间,那么不需要设置时间,它的任务是怎么执行的呢

在系统平均负载量降到 0.8 以下时执行某项一次性的任务

我这里直接输入了,就直接蹦出来了,说明此时平均负载量很低,也就是系统很清闲,没有大量运算

batch支持些命令

-f file    使用文件里面的shell脚本
-q x    将计划任务加入某个队列
-m    发送邮件给用户

还可以看到上面截图是job 14,说明它这个任务表和at是一起的,batch相当于at命令的一部分

0x03计划任务crontab命令:

在渗透测试中,如果linux下的计划任务设置最常使用的就是crontab命令了吧

因为相比较at命令,它首先是默认安装的(我的kali和新装的ubuntu都有),其次它与at不同在于,at只能定时某次的时间然后运行一次,而crontab能够设置每天多久自启动的计划任务,可以一次设置多次触发

然后crontab的用户使用权限问题和at一样

cron.deny 不允许使用crontab的用户
cron.allow 允许使用crontab的用户
cron.allow优先度高于cron.deny
#注意唯一不同在于
cron.allow,cron.deny都不存在时候,都可以用crontab

而默认配置中cron.allow和cron.deny都是不存在的,因此意味着所有用户默认都能用crontab

首先看crontab的语法

sijidou@ubuntu:~$ crontab --help
crontab: invalid option -- '-'
crontab: usage error: unrecognized option
usage: crontab [-u user] file
crontab [ -u user ] [ -i ] { -e | -l | -r }
(default operation is replace, per 1003.2)
-e (edit user's crontab)
-l (list user's crontab)
-r (delete user's crontab)
-i (prompt before deleting user's crontab)
sijidou@ubuntu:~$

这里各个参数说明一下

-e    进入编写
-l    列出任务
-r    删除任务
-i    删除前给提示
-u    指定某用户运行任务

每条计划任务的格式书写如下

min   hour   day   month   week   [user]   command
0-59  0-23   1-31  1-12   0-7          echo "sijidou" > /home/sijidou/Desktop/1.tx

前面5个参数可以是这些形式

每个参数间用空格隔开
* 表示任意
, 表示1,2号都可以(这里假设是day的值)
- 表示1号到20号都可以(这里假设是day的值)
/ 表示每隔10天就执行一次(这里假设是day的值)

举几个例子

每月每周每日每小时51分的在桌面上生成有着"hello world"的1.txt文件

 * * * * echo "hello world" > /home/sijidou/Desktop/.tx

每过10天,在那天的每小时21分钟生成文件

 * / * * echo "hello world" > /home/sijidou/Desktop/.txt

每天的凌晨1点和2点的31分生成文件

 1,2 * * * echo "hello world" > /home/sijidou/Desktop/.txt

每周三到周五的每小时41分生成文件

 * * * 3-5 echo "hello world" > /home/sijidou/Desktop/.txt

接下来是如何把命令写进去

带参数e会进入设置的文本文件(第一次会让你选是nano还是vim,它会看你系统装了什么编译器)进行编写,之后是直接跳进去

它的原理是在/tmp/下生产一个随机后缀的文件,然后文件里面按每行算一条计划任务

写好了后,查看任务,任务已经写进去了,但是这是sijidou用户,想要向root目录下写东西有点痴心妄想了2333

再用crontab -e 打开还可以看还可以看原来的命令,但是文件名有变化

删除文件直接使用crontab -r不需要带参数,它会把/tmp/目录下的临时文件直接删除,意味着你设置的所有计划任务都没了

而-u参数只有root才能设置,这里用sijidou账号带-u参数,回显不能使用

那么切换成root用户给sijidou设置任务

再切换回sijidou来,发现写进去了,如果要继续编译直接输入crontab -e

用root账号查看,删除sijidou账户的计划任务

也可以不用依赖crontab生成的零时文件,用自己编译的文件设置计划任务

0x04结语:

参考链接

at命令参考:https://www.cnblogs.com/diantong/p/9366449.html

batch命令参考:https://blog.csdn.net/PecoVio/article/details/82428890

crontal命令参考:https://www.jianshu.com/p/9619076b1172

总参考:https://blog.csdn.net/kx_nullpointer/article/details/21299873

最新文章

  1. Btree 索引
  2. 【JAVA】Quartz 任务调度和异步执行器
  3. eclipse如何修改dynamic web module version
  4. Java多线程中的进程,线程,并行,并发
  5. jquery 操作select 语句大全
  6. webpack的配置及使用
  7. Uva 1103 Ancient Messages
  8. java多线程系列(六)---线程池原理及其使用
  9. Android01-布局篇
  10. iOS知识点、面试题 之三
  11. 函数式编程--lambda表达式对比匿名内部类
  12. newSoft
  13. 要想学好Java编程,构造器、方法重载、this关键字、垃圾回收机制,这4关一定要过!
  14. JAVA的下载与安装和环境变量配置等详细教程
  15. Minimal string CodeForces – 797C
  16. 【vue】中 provide 和 inject 的使用方法
  17. 在eclipse 导入简单的Android studio 简单项目
  18. 异常信息ASM ClassReader failed to parse class file的问题解决
  19. servlet,listener,filter,interceptor的关系
  20. FineReport和泛微OA(Ecology)的单点登录集成方案

热门文章

  1. LeetCode(70): 爬楼梯
  2. LeetCode(69):x 的平方根
  3. cf1107d 映射关系
  4. java使用POI解析2007以上的Excel表格
  5. python接收邮件
  6. axios简单使用
  7. JavaScript 匿名函数
  8. JDK 自带压缩解压流
  9. .net core vs2015 vs2017打开后errpr
  10. 关于sizeof与#pragma pack 以及网络上关于字节对齐的一点感想