Linux 定时备份日志

52 阅读2分钟

什么是日志文件?为什么要设立日志文件?

  1. 日志文件是用来记录事务对数据库的更新操作的文件。
  2. 设立日志文件的目的是: 进行事务故障恢复;进行系统故障恢复;协助后备副本进行介质故障恢复。

但是,随着时间,日志文件内存过于增加,将会导致在日志添加过程效率降低,延长时间,这又如何解决呢?本文就来说一说使用脚本文件定时备份项目运行过程产生的日志文件吧~~~~

backup.sh 脚本内容:

#!/bin/bash

mypath='/home/logs/backup'  #日志备份文件存储目录

echo ${mypath}

mylog='/home/logs/console.out' #要备份的文件

echo ${mylog}

time=`date +%Y%m%d%H%M%S` #时间,作为备份文件名

echo ${time}

cp ${mylog} ${mypath}/console.${time}.out #备份文件名

echo ${mypath} ${mypath}/console.${time}.out

#用当前日志的最后1行覆盖当前日志的内容,
#如果日志写入速度很快, 担心备份过程中有丢失, 可以将此值调大
tmp=`tail -1 ${mylog}` 

echo ${tmp} > ${mylog}

将此文件放到可执行的目录,给到 chmod u+x *.sh 权限

设置定时任务:

编辑 Linux 定时任务配置

vi /etc/crontab

按 i 编辑如图中所示一行 1686626978623.jpg 其中 0 0 * * * 表示每天0时0分执行,crontab从左至右分别表示 “分时日月周” root 表示用户名 /home/bin/backup.sh 是备份脚本的绝对路径

然后再执行如下命令,重启定时任务:

systemctl reload crond.service

注:CentOS6和CentOS7的命令是不一样的

CentOS6:

//启动服务
service crond start
//关闭服务
service crond stop
//重启服务
service crond restart
//重新载入配置
service crond reload
//查看状态
service crond status

CentOS7:

//启动服务
systemctl start crond.service
//关闭服务
systemctl stop crond.service
//重启服务
systemctl restart crond.service
//重新载入配置
systemctl reload crond.service
//查看状态
systemctl status crond.service

//或者
crond start
crond stop
crond restart
crond reload
crond status

lock情况

如果出现:crond: can’t lock /var/run/crond.pid 直接把lock删掉就行了,这个我没有出现,还没试过

rm -rf /var/run/crond.pid

查看定时任务执行情况:

tail -f /var/log/cron

定时任务执行情况


总结:

  1. 可以先手动执行backup.sh,确保执行不报错
  2. crontab命令在CentOS6和CentOS7是不一样的