在MySQL執行GRANT命令時出現如下錯誤內容。
mysql> grant all on *.* to ...
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
調查內容
mysql.user表
不小心把mysql.user表清除了的話,可以追加root用戶,但這次好像不是這個問題。
mysql> select user,host, password from mysql.user
+---------+-----------+-----------+
| user | host | password |
+---------+-----------+-----------+
| root | localhost | *XXX1 |
| root | 127.0.0.1 | *XXX2 |
| zabbix | localhost | *XXX3 |
+---------+-----------+-----------+
super用戶權限
查看用戶權限擁有super用戶權限。
mysql> show grants
GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP, RELOAD, SHUTDOWN, PROCESS, FILE, REFERENCES,
INDEX, ALTER, SHOW DATABASES, SUPER, CREATE TEMPORARY TABLES, LOCK TABLES, EXECUTE, REPLICATION SLAVE,
REPLICATION CLIENT, CREATE VIEW, SHOW VIEW, CREATE ROUTINE, ALTER ROUTINE, CREATE USER, EVENT, TRIGGER
ON *.* TO 'root'@'localhost' IDENTIFIED BY PASSWORD '*XXXX' WITH GRANT OPTION
查看MySQL版本
查看MySQL版本不知何時從5.1升級為5.5了,確認/var/log/yum.log發現yum安裝別的軟件的時候MySQL版本也同時被升級了。
對應內容
因為表的結構是5.1版本的因此無法在版本5.5追加用戶,執行mysql_upgrade之後,就可以正常的追加用戶了。
# mysql_upgrade -u root -p
Enter password:
Looking for 'mysql' as: mysql
Looking for 'mysqlcheck' as: mysqlcheck
Running 'mysqlcheck with default connection arguments
Running 'mysqlcheck with default connection arguments
mysql.columns_priv OK
mysql.db OK
mysql.event OK
mysql.func OK
...
執行GRANT命令成功!
mysql> grant all on *.* to ...
Query OK, 0 rows affected (0.00 sec)
結語
在升級MySQL後需要執行mysql_upgrade命令。mysql_upgrade會確認數據庫的表結構和最新MySQL Server的互換性。當表和現在的MySQL Server沒有互換性的時候,會確認該表並修復此表。並且mysql_upgrade命令會升級MySQL使用的表(即System Table),可使用版本升級後的新權限及新功能。