关于mysql备份文件错误的是_mysqldump备份数据出错

收到nagios报警,提示mysql备份失败,线上使用的是逻辑备份,也就是使用mysqldump,由于数据比较小,也就没在乎速度神马的问题。好吧,那就查查是什么原因导致备份失败,由于备份是写成脚本定时执行的,我就抽取里面mysqldump命令执行,看是否会抛什么错误,果不其然,报错如下:

2986f4ffa384374e694512ef3fb26dc8.png

又想到去看看错误日志,是否有异常

[root@localhost data]# tail -n 10localhost.localdomain.err140320

140320 9:00:00 [ERROR] /usr/local/mysql-5.1.66/libexec/mysqld: Sort aborted140320 9:00:00 [ERROR] /usr/local/mysql-5.1.66/libexec/mysqld: Sort aborted140320 9:00:00 [ERROR] /usr/local/mysql-5.1.66/libexec/mysqld: Sort aborted140320 10:00:00 [ERROR] /usr/local/mysql-5.1.66/libexec/mysqld: Sort aborted140320 10:00:00 [ERROR] /usr/local/mysql-5.1.66/libexec/mysqld: Sort aborted140320 10:00:00 [ERROR] /usr/local/mysql-5.1.66/libexec/mysqld: Sort aborted140320 10:00:00 [ERROR] /usr/local/mysql-5.1.66/libexec/mysqld: Sort aborted140320 10:00:00 [ERROR] /usr/local/mysql-5.1.66/libexec/mysqld: Sort aborted140320 10:00:00 [ERROR] /usr/local/mysql-5.1.66/libexec/mysqld: Sort aborted

[root@localhost data]#

看的出来是无法排序,mysql在group by,order by的时候,如果无法使用索引排序,就会使用内存临时表,要是超过内存临时表的限制,就会在磁盘上创建临时表,也就是myisam表,默认目录是/tmp

我就郁闷了,group by,order by使用临时表这个知道,难道mysqldump也使用临时表?

mysql> show variables like '%tmpdir%';+-------------------+-----------+

| Variable_name | Value |

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

| slave_load_tmpdir | /data/tmp |

| tmpdir | /data/tmp |

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

2 rows in set (0.00sec)

mysql>

可以看见是在/data/tmp 目录,于是看看/data/目录权限,发现权限是root的,mysql根本没法创建,于是手动在/data/目录下创建tmp,并且

chown mysql.mysql tmp

然后再试着执行mysqldump备份一个表,没有报错了,查看错误日志也没有继续报错了,询问了另外一个运维,说是他改的,将临时表目录/tmp改成了/data/tmp,由于没有注意权限问题,才导致备份失败,以及mysql无法排序。

其实我们可以将临时表的目录设置为/dev/shm,该目录是内存文件系统,速度非常快;这也算是一种优化手段

mysql> show variables like '%tmp%';+-------------------+----------+

| Variable_name | Value |

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

| max_tmp_tables | 32 |

| slave_load_tmpdir | /dev/shm |

| tmp_table_size | 16777216 |

| tmpdir | /dev/shm |

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

4 rows in set (0.01sec)

mysql>

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值