mysql日志定时转储

mysql日志定时转储

mysql的general_log日志都是记录日常的业务操作内容,如果业务量非常大,那么该日志短时间内就会很大,占用了大量的磁盘空间,所以就需要对日志进行转储。不仅清理了磁盘空间,又可以方便日志进行转储;

编写shell

#!/bin/bash
sqldir=/data/mysql/data
cd $sqldir
echo $sqldir
today=`date +%Y%m%d`
yestoday=`date +%Y%m%d -d "-1 days"`

mysql -uroot -p密码 <<EOF
SET GLOBAL general_log = 'OFF';
EOF
mv general_host.log  general_host.log${yestoday}
#touch general.log
mysql -uroot -p密码 <<EOF
SET GLOBAL general_log = 'ON';
EOF

if [ -f"/data/mysql/data/general_host.log${yestoday}" ];then
  echo "`date +%Y%m%d`:bak is success"
else
  echo "`date +%Y%m%d`:bak is fail"
fi

if [ -f"/data/mysql/data/general_host.log" ];then
  echo "`date +%Y%m%d`:touch file success"
else
  echo "`date +%Y%m%d`:touch file fail"
fi

设置定时

执行crontab -e ,设置定时任务如下,定时时间根据实际情况修改

0 3 * * * sh /root/work/mysql_generallog.sh >> /root/work/mysql_generallog.log

MySQL日志命令扩展

show variables like 'general_log'; -- 查看日志是否开启

set global general_log=on; -- 开启日志功能

show variables like 'general_log_file'; -- 看看日志文件保存位置

set global general_log_file='tmp/general.lg'; -- 设置日志文件保存位置

show variables like 'log_output'; -- 看看日志输出类型 table或file

set global log_output='table'; -- 设置输出类型为 table

set global log_output='file'; -- 设置输出类型为file
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值