Linux的定期、延时任务与临时文件管理

一.定期任务

1、计划定期任务

命令 功能
at mm:ss/now+?min 设定时间
at 命令 设定该时间执行的命令
Ctrl + D 设定完毕开始执行
at -l 查看现有定期任务及编号
at -c 编号 查看该编号定期任务详细信息
at -r 编号 取消该编号定期任务,该任务将不再执行

Linux的定期、延时任务与临时文件管理

2、如何限制用户是否拥有计划定期任务权限

(1)限制设定:

命令 功能
/etc/at.allow at命令的用户白名单,多个用户添加时分行写即可,系统中默认不存在此文件,需建立
/etc/at.deny at命令的用户黑名单,多个用户添加时分行写即可,系统中默认存在此文件,白名单文件被建立后,黑名单文件将不被系统检测(即使白名单中没有内容)
vim /etc/at.deny 用vim修改用户黑名单,黑名单内的用户不可使用at指令,root用户不受黑名单限制
vim /etc/at.allow 用vim修改用户白名单,只有白名单内的用户可以使用at指令,名单上没有的用户均不可使用,root用户不受白名单限制

(2)测试:

命令 功能
useradd 123 添加新用户123
useradd westos 添加新用户westos
passwd 123 设置123用户密码
passwd westos 设置westos用户密码
su - username 进入想要测试的用户
at mm:ss/now+?min 输入命令测试能否按设定执行或不执行

Linux的定期、延时任务与临时文件管理

二.延迟任务

1、用户延迟任务

命令 功能
crontab -e 建立延迟任务文件
crontab -l -u username 查看该用户下的延迟任务文件
crontab -l 查看当前用户的延迟任务文件
crontab -r 删除当前用户的延迟任务文件
crontab -r -i 删除时询问是否删除
cron语法 何时运行
06 * * * * 每个小时整点过6分运行
08 05 * * * 每天的05:08运行(24小时制)
08 14 06 * * 每月第6天的14:08运行
15 18 14 2 * 每个2月14日的18:15运行
14 20 * * 3 每个星期三的20:14运行
*/3 * * * * 每3分钟运行一次(0,以及3的倍数)
*/5 1-5 2,18 * * 每月第2和18天的1-5点每5分钟运行,不包括5点整

Linux的定期、延时任务与临时文件管理

2、系统延迟任务

(1)如何建立系统延迟任务

命令 功能
cd /etc/crontab 进入该目录
cd /etc/crontab/cron.d 选择该目录自定义建立
vim 123 建立文件输入命令保存即可

Linux的定期、延时任务与临时文件管理

(2)如何设置用户延迟任务权限

命令 功能
vim /etc/cron.deny 修改用户黑名单
vim /etc/cron.allow 修改用户白名单,白名单被建立后黑名单将不再被检测

Linux的定期、延时任务与临时文件管理

三.系统中的临时文件管理

系统中/usr/lib/tmpfiles.d/标示了服务的临时文件的存放位置

命令 功能
vim /usr/lib/tmpfiles.d/dir.conf 在该目录中建立dir.conf文件,编辑该文件,设置临时文件的策略
d dir.conf 1777(权限) root root 6s 编写策略,目录名和位置,权限,所有人,所有组,生命周期
systemd-tmpfiles --creat /usr/lib/tmpfiles.d/dir.conf 以此策略为原则建立目录(名称和地址由策略决定)
touch /xx/xx/dir/file1 在由此策略建立的目录中建立文件,等待6s后
systemd-tmpfiles --clean /usr/lib/tmpfiles.d/dir.conf 清除以此策略为原则的目录下到达生命周期的文件,file1被清除
touch /xx/xx/dir/file2 建立file2
systemd-tmpfiles --clean /usr/lib/tmpfiles.d/dir.conf 在6s内清除,file2未到达生命周期,则file2不能被清除

Linux的定期、延时任务与临时文件管理