mysql数据库占满磁盘_mysql数据库占满磁盘导致服务器无法运行

第一次查找问题,记录一下查找过程

首先查看数据库的磁盘使用情况: df -hl

然后查看每个文件所占容量:du -h --max-depth=1,然后发现/usr的文件夹占了32G的磁盘,然后一级一级的进入文件夹执行du -h --max-depth=1,最后发现mysql的data文件夹占了30G,于是进入data文件夹中,发现里面有很多的mysql-bin.000011的文件,每个文件有1G的大小,

1.1G mysql-bin.000152

1.1G mysql-bin.000153

1.1G mysql-bin.000154

这个binlog是mysql用来构建复制时候用的文件。默认是不开启的。如果需要开启在my.ini文件中写入log_bin=mysql_bin,重启服务。

为了知道mysql-bin.000152是存放了上面东西,首先一般bin-log日志文件不能打开查看的,需要用到mysql的工具进行。该工具在mysql的bin目录下。

[mysql]mysqlbinlog mysql-bin.000011 -d db1 > db1.sql

执行完毕后在当前目录会生成db1.sql的文件,这时可以用vim/vi来打开文件。

打开文件是这个样子

发现这些文件中thread_id=363每秒都在执行,于是查找mysql中正在进行的进程。

查看数据库中的进程有三种方式:

1.进入mysql/bin目录下输入mysqladmin processlist;

2.启动mysql,输入show processlist;

如果有SUPER权限,则可以看到全部的线程,否则,只能看到自己发起的线程(这是指,当前对应的MySQL帐户运行的线程)。

mysql> show processlist;

+-------+-----------+---------------------+----------+---------+------+-------+------------------+

| Id | User | Host | db | Command | Time | State | Info |

+-------+-----------+---------------------+----------+---------+------+-------+------------------+

| 19161 | test_user | 171.8.216.253:63583 | tbkttest | Sleep | 685 | | NULL |

| 19164 | test_user | 171.8.216.253:63677 | tbkttest | Sleep | 297 | | NULL |

| 19165 | root | localhost | tbkttest | Query | 0 | NULL | show processlist |

| 19166 | root | localhost | NULL | Sleep | 36 | | NULL |

+-------+-----------+---------------------+----------+---------+------+-------+------------------+

4 rows in set (0.00 sec)

3.使用Navicat结束mysql数据库服务进程

点击【工具】菜单,选择【服务器监控】下的【MySql】,此时可以查看mysql进程列表。

找到id,db是操作的数据库名。

MySQL bin-log 作用

1.数据恢复:如果你的数据库出问题了,而你之前有过备份,那么可以看日志文件,找出是哪个命令导致你的数据库出问题了,想办法挽回损失。

2.主从服务器之间同步数据:主服务器上所有的操作都在记录日志中,从服务器可以根据该日志来进行,以确保两个同步。

3.在什么时间会删除过期日志?

每次进行 LOG flush的时会自动删除过期的日志,那么什么时间才能触发log flush,手册上的解释为:重启 MySQL

bin-log 文件大小达到参数 max_binlog_size 限制;

手工执行清理命令

自动清理方法1:(修改配置文件和在mysql内设置参数可无需重启服务)

vim my.cnf

expire_logs_days = 7 // 表示日志保留7天,超过7天则设置为过期的

# mysql -u root -p > show binary logs; > show variables like '%log%'; > set global expire_logs_days = 7;

手动清理方法2:(推荐)

如果没有主从复制,可以通过下面的命令重置数据库日志,清除之前的日志文件:

reset master

但是如果存在复制关系,应当通过 PURGE 的名来清理 bin-log 日志,语法如下:

# mysql -u root -p

> purge master logs to 'mysql-bin.010’; //清除mysql-bin.010日志

> purge master logs before '2016-02-28 13:00:00'; //清除2016-02-28 13:00:00前的日志

> purge master logs before date_sub(now(), interval 3 day); //清除3天前的bin日志

注意,不要轻易手动去删除binlog,会导致binlog.index和真实存在的binlog不匹配,而导致expire_logs_day失效

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值