Linux计划任务与日志的管理


Linux计划任务与日志的管理

  • 计划任务-at-cron-计划任务使用方法
  • 日志的种类和记录的方式

计划任务-at-cron-计划任务使用方法

计划任务的作用:是做一些周期性的任务,在生产中的主要用来定期备份数据
Crond:这个守护进程是为了周期性执行任务或处理等待事件而存在
任务调度分两种:系统任务调度,用户任务调度

计划任务的安排方式分两种:

  • 一种是定时性的,也就是例行。就是每隔一定的周期就要重复来做这个事情
  • 一种是突发性的,就是这次做完了这个事,就没有下一次了,临时决定,只执行一次的任务

at和crontab这两个命令:

  • at:它是一个可以处理仅执行一次就结束的指令
  • crontab:它是会把你指定的工作或任务,比如:脚本等,按照你设定的周期一直循环执行下去

at计划任务的使用

语法格式: at 时间 ;服务:atd
[root@love ~]# systemctl start atd # 开启atd服务
[root@love ~]# systemctl status atd # 查看atd服务状态
[root@love ~]# systemctl is-enabled atd # 查看是否开始开机启动服务,如果弹出enabled,说明开机启动此服务
# 在Centos6查看开机启动服务:
[root@love ~]# chkconfig --list | grep atd # 此命令在centos7上不能执行

实战-使用at创建计划任务

[root@love ~]# date # 查看系统时间
2018年 05月 21日 星期一 20:43:29 CST
[root@love ~]# at 20:46 # 注意:如果是上午时间,后面加上am,比如9:20am
at> mkdir /tmp/xuegod # 输入你要执行的命令
at> touch /tmp/xuegod/a.txt
at> <EOT>        # 结束:ctrl+d
[root@love ~]# at -l # 查看计划任务
[root@love ~]# atq # 查看计划任务
# 检查at计划任务运行结果:
[root@love ~]# ls /tmp/xuegod/
a.txt

查看和删除at将要执行的计划任务

这个查看,只能看到还没有执行的。如果这个任务已经开始执行或者执行完成了,是看不到的

[root@love ~]# at -l
5 Sat Aug 19 20:50:00 2017 a root
# 任务编号 执行的时间 队列 执行者
# 5 Fri Oct 28 20:55:00 2016 a root
[root@love ~]# at -c 5 #-c 打印任务的内容到标准输出, 查看5号计划任务具体内容
# 查看定时任务内容
[root@love ~]# ls /var/spool/at/
a00003018452cb a0000501845084 spool
[root@love ~]# tail -5 /var/spool/at/a0000501845084

# at计划任务的特殊写法
[root@love ~]# at 20:00 2018-10-1 在某天
[root@love ~]# at now +10min 在 10分钟后执行
[root@love ~]# at 17:00 tomorrow 明天下午5点执行
[root@love ~]# at 6:00 pm +3 days 在3天以后的下午6点执行
[root@love ~]# at 23:00 < a.txt

删除at计划任务

语法: atrm 任务编号
[root@love ~]# at -l
3 Tue May 22 08:43:00 2018 a root
5 Mon May 21 23:00:00 2018 a root
[root@love ~]# atrm 5
[root@love ~]# at -l
3 Tue May 22 08:43:00 2018 a root

crontab定时任务的使用

crond命令定期检查是否有要执行的工作,如果有要执行的工作便会自动执行该工作。
cron是一个linux下的定时执行工具,可以在无需人工干预的情况下运行作业。

启动crond服务

systemctl start crond

systemctl enable crond

cron命令参数介绍:

crontab的参数:

  • -u hr # 指定hr用户的cron服务
  • -l # 列出当前用户下的cron服务的详细内容
  • -u mk -l # 列出指定用户mk下的cron服务的详细内容
  • -r # 删除cron服务
  • -e # 编辑cron服务

例如:

crontab -u root -l # root查看自己的cron计划任务
crontab -u san -r # root想删除san的cron计划任务

cron -e 编辑时的语法

星期日用0或7表示
一行对应一个任务,特殊符号的含义:

*代表取值范围内的数字(任意/每)
/指定时间的间隔频率*/10 0-23/2
-代表从某个数字到某个数字8-17
,分开几个离散的数字6,10-13,20

创建计划任务

例:每天凌晨2点1分开始备份数据

crontab -e #添加计划任务

1 2 * tar zcvf /opt/grub2.tar.gz /boot/grub2

crontab -l # 查看

例:黑客以非root用户添加计划任务。 最好使用已经存在系统用户添加。这里使用bin用户来添加

crontab -u bin -e

1 echo "aaaaaaa" >> /tmp/bin.txt

排查:

crontab -u bin -l

1 echo "aaaaaaa" >> /tmp/bin.txt

注:所有用户的计划任务,都会在/var/spool/cron/下产生对应的文件

系统级别的计划任务

ll /etc/crontab

这个是系统任务调度的配置文件

vim /etc/crontab
SHELL=/bin/bash #指定操作系统使用哪个shell
PATH=/sbin:/bin:/usr/sbin:/usr/bin #系统执行命令的搜索路径
MAILTO=root #将执行任务的信息通过邮件发送给xx用户

# For details see man 4 crontabs
# Example of job definition:
# .---------------- minute (0 - 59)
# | .------------- hour (0 - 23)
# | | .---------- day of month (1 - 31)
# | | | .------- month (1 - 12) OR jan,feb,mar,apr ...
# | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# | | | | |
#              *  *  *  *  * user-name  command to be executed

也可以直接在/etc/crontab中添加计划任务

使用crontab命令的注意事项:

  • 环境变量的问题
  • 清理你的邮件日志 ,比如使用重定向 >/dev/null 2>&1
ls /etc/cron # 按两下tab键

cron.d/ cron.deny cron.monthly/ cron.weekly/
cron.daily/ cron.hourly/ crontab

  • cron.d/ # 是系统自动定期需要做的任务,但是又不是按小时,按天,按星期,按月来执行的,那么就放在这个目录下面。

    • cron.deny # 控制用户是否能做计划任务的文件;
    • cron.monthly/ # 每月执行的脚本;
    • cron.weekly/ # 每周执行的脚本;
    • cron.daily/ # 每天执行的脚本;
    • cron.hourly/ # 每小时执行的脚本;
    • crontab # 主配置文件 也可添加任务;

日志的种类和记录的方式-自定义ssh服务日志类型和存储位置

在centos7中,系统日志消息由两个服务负责处理:systemd-journald和rsyslog

常见日志文件的作用

系统日志文件概述:/var/log目录保管由rsyslog维护的,里面存放的一些特定于系统和服务的日志文件

日志文件用途
/var/log/message大多数系统日志消息记录在此处。有也例外的:如与身份验证,电子邮件处理相关的定期作业任务等
/var/log/secure安全和身份验证相关的消息和登录失败的日志文件。 ssh远程连接产生的日志
/var/log/maillog与邮件服务器相关的消息日志文件
/var/log/cron与定期执行任务相关的日志文件
/var/log/boot.log与系统启动相关的消息记录
/var/log/dmesg与系统启动相关的消息记录

日志的记录方式

分类 级别
日志的分类:

  • daemon 后台进程相关
  • kern 内核产生的信息
  • lpr 打印系统产生的
  • authpriv 安全认证
  • cron 定时相关
  • mail 邮件相关
  • syslog 日志服务本身的
  • news 新闻系统
  • local0~7 自定义的日志设备
  • local0-local7 8个系统保留的类, 供其它的程序使用或者是用户自定义

日志的级别: 轻重

编码优先级严重性
7debug信息对开发人员调试应用程序有用,在操作过程中无用
6info正常的操作信息,可以收集报告,测量吞吐量等
5notice注意,正常但重要的事件,
4warning警告,提示如果不采取行动。将会发生错误。比如文件系统使用90%
3err错误,阻止某个模块或程序的功能不能正常使用
2crit关键的错误,已经影响了整个系统或软件不能正常工作的信息
1alert警报,需要立刻修改的信息
0emerg紧急,内核崩溃等严重信息

声明:Rock 版权所有,内容均为原创,欢迎转载。

转载:转载请注明原文链接 - Linux计划任务与日志的管理


我是一个程序员,致力于网页开发,我还很年轻,什么也不懂。