Linux 定时备份日志

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

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 编辑如图中所示一行
定时任务编写
其中 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是不一样的

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值