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