数据库排错与mysql_install_db重新实例化数据库_第1张图片

数据库报MySQL 启动报错 Table 'mysql.plugin' doesn't exist 错误,一直没法启动。


最开始的时候我是根据提示运行的mysql_upgrade 命令

mysql_upgrade --protocol=tcp -P3306 -u root -p
Enter password:
Looking for 'mysql' as: mysql
Looking for 'mysqlcheck' as: mysqlcheck
FATAL ERROR:Upgrade failed

mysql_upgrade是一个binary命令,用来检查mysql在upgrade后所有数据库表(包括mysql库)是否与升级后的mysql版本兼容,同时也会升级mysql库下的系统表,它是用来代替mysql_fix_privilege_tables。它会check所有表并尝试对发现问题的表进行repair,执行完后会在datadir目录下生成mysql_upgrade_info文件记录mysql的版本号,以便再执行mysql_upgrade时判断是否还需检查所有表。

mysql_upgrade会等价执行以下命令:

mysqlcheck --all-databases --check-upgrade --auto-repair
mysql < fix_priv_tables
mysqlcheck --all-databases --check-upgrade --fix-db-names --fix-table-names

 

然后尝试运行mysqlcheck 修复数据student,但是同样无法成功。

mysqlcheck -r -q -uroot -ppassword student


最后发现没有成功的原因是没有一个初始化数据库,不能启动mysql守护进程,所以我用mysql_install_db重新实例化了一个数据库。

mysql_install_db --user=mysql --defaults-file=/etc/my.cnf --datadir=/data/mysql/


参考链接:http://www.linuxidc.com/Linux/2013-11/93252.htm#userconsent#

          http://www.oschina.net/question/169513_77019

          http://blog.itpub.net/29071259/viewspace-1368508/