MySQL中清理日志

 
  1. 今天发现网站不能正常访问,于是登陆服务器查找问题。

  2. 机智的我随手用命令:df -l 发现 硬盘爆满了,于是就知道

  3. 问题所在了。

  4.  
  5. Filesystem 1K-blocks Used Available Use% Mounted on

  6. /dev/xvda1 20641404 16963004 16929876 100% /

  7. tmpfs 960368 0 960368 0% /dev/shm

  8. /dev/xvdb1 51599192 4845536 44132564 10% /home/sam/share

  9.  
  10. 然后通过命令 du -sh * 一路检查,发现mysql的日志文件占据了大部

  11. 分空间 , 整整27G,于是现在的任务就是清理mysql的日志文件

  12. (主要是清理.log文件和mysql-bin.00000X二进制日志文件)

一、删除mysql日志文件

 
  1. 第一步:登陆进入mysql,并使用 show binary logs; 查看日志文件。

  2.  
  3. mysql> show binary logs;

+------------------+-----------+
| Log_name | File_size |
+------------------+-----------+
| mysql-bin.000001 | 234592362 |
| mysql-bin.000002 | 425234342 |
| mysql-bin.000003 | 425345345 |
| mysql-bin.000004 | 234234222 |
| mysql-bin.000005 | 425994852 |
+------------------+-----------+

 
  1. 第二步:查看正在使用的日志文件:show master status;

  2. mysql> show master status;

+------------------+-----------+--------------+------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+-----------+--------------+------------------+-------------------+
| mysql-bin.000005 | 425994852 | | | |
+------------------+-----------+--------------+------------------+-------------------+
row in set (0.00 sec)

 
  1. 当前正在使用的日志文件是mysql-bin.000005,那么删除日志文件的时候应该排除掉该文件。

  2. 删除日志文件的命令:purge binary logs to ‘mysql-bin.000005’;

  3. mysql> purge binary logs to 'mysql-bin.000005';

  4.  
  5. 删除除mysql-bin.000005以外的日志文件。

  6. 删除后就能释放大部分空间。

二、mysql 定时清理日志文件

 
  1. 如果每次等到发现空间不足的时候才去手动删除日志文件,

  2. 这种方式是很不理想的。

  3. 那么,我们就需要设置mysql,让它能自动清理日志文件。

  4. 编辑mysql的配置文件,设置expire_logs_days(mysql定时

  5. 删除日志文件)

[root@sam ~]# vim /etc/my.cnf

 
  1. 在my.cnf中,添加或修改expire_logs_days的值 (这里设置的自动

  2. 删除时间为10天, 默认为0不自动删除)

  3. expire_logs_days=10

  4. 修改后,重启mysql就会生效。

  5. 但是,在生产环境中,重启mysql数据库往往会付出很高的代价。

  6. 于是,可以在不重启mysql的情况下,修改expire_logs_days值

  7. 登陆到mysql,并输入一下命令。 如下:

mysql> show variables like '%log%';
mysql> set global expire_logs_days = 10;

 
  1. 设置完后,可以通过 show variables like ‘%log%’;

  2. 看到expire_logs_days的值已被修改成10。

  3. 注意:通过这种方式设置expire_logs_days虽然不需要重启mysql

  4. 即可生效,但是该方式在重启mysql之后,值会被恢复。

  5. 于是,建议通过mysql命令设置expire_logs_days的同时,

  6. 也修改/etc/my.cnf下的expire_logs_days=10配置,这样在

  7. 下次重启mysql的时候,expire_logs_days也一样是10;

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值