您的位置:首页 > 数据库 > SQL

mysql Got error 28 from storage engine /usr/bin/mysqld_safe: line 183

2017-10-12 17:53 661 查看
mysql用的好好的忽然很蛋疼的给我来了一句,mysql Got error 28 from storage engine。后来一查才知道:

Mysql Got error 28 from storage engine错误

磁盘临时空间不够导致。  解决办法:  
清空/tmp目录,或者修改my.cnf中的tmpdir参数,指向具有足够空间目录  linux版本是my.cnf,一般会放在/etc/my.cnf,/etc/mysql/my.cnf
win下的是my.ini,一般会在安装目录的根目录
还有就是,mysql就算没有这个配置文件也能运行的

Mysql导致tmp目录空间耗尽问题

 收到磁盘空间告警的信息,/tmp目录磁盘使用率99%。  www.2cto.com  mysql 的 tmpdir 设置在/tmp目录,第一时间查看 ls -alth 并为发现大文件,也没有mysql临时表之类的文件。连接mysql,show processlist 并为发现异常查询 …… 整个/tmp目录8GB,用查看df -h 发现/tmp Avail 值剩下100MB左右;du -sh 发现tmp目录只用了几十MB。7GB多的空间哪里去了?未释放? 通过lsof |grep tmp |more 发现其中一个mysql实例很多类似 /tmp/MLXvlID8 (deleted) 


查看mysqld.err中发现有多行: [ERROR] /mysql_base/bin/mysqld: Sort aborted  www.2cto.com  猜测:Sql异常终止,导致sort aborted 。而临时目录下的/tmp/ML****** 等文件虽然删除,但由于mysql线程连接是长连接,线程还存在,暂时不会释放空间。 若想释放空间:1.重启mysql;2.重启应用程序,断开长连接。 结果:应用程序重启,长连接断开,删除的空间就释放了。后来使用了mysql停止和重启的命令1、使用 service 启动:service mysqld start

2、使用 mysqld 脚本启动:/etc/inint.d/mysqld start

3、使用 safe_mysqld 启动:safe_mysqld&

二、停止

1、使用 service 启动:service mysqld stop

2、使用 mysqld 脚本启动:/etc/inint.d/mysqld stop

3、 mysqladmin shutdown 

三、重启

1、 使用 service 启动:service mysqld restart

2、使用 mysqld 脚本启动:/etc/inint.d/mysqld restart
结果启动的时候 


找了很多原因后来猜测是磁盘问题;df -h; 查看磁盘占用情况;

du -sh /* 统计一下哪个磁盘占用的多;



看到data占用的多,没办法只能删除一些东西了。然后重启OK 完美解决问题。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: