skip-grant-tables的解法
首先,关闭实例
这里,只能通过kill mysqld进程的方式。
注意:不是mysqld_safe进程,也切忌使用kill -9。
# ps -ef |grep mysqld
root 6220 6171 0 08:14 pts/0 00:00:00 /bin/sh bin/mysqld_safe --defaults-file=my.cnf
mysql 6347 6220 0 08:14 pts/0 00:00:01 /usr/local/mysql57/bin/mysqld --defaults-file=my.cnf --basedir=/usr/local/mysql57 --datadir=/usr/local/mysql57/data --plugin-dir=/usr/local/mysql57/lib/plugin --user=mysql --log-error=slowtech.err --pid-file=slowtech.pid --socket=/usr/local/mysql57/data/mysql.sock --port=3307
root 6418 6171 0 08:17 pts/0 00:00:00 grep --color=auto mysqld
# kill 6347
使用--skip-grant-tables参数,重启实例
bin/mysqld_safe --defaults-file=my.cnf --skip-grant-tables --skip-networking &
# mysql -S /usr/local/mysql57/data/mysql.sock
修改密码
mysql> update mysql.user set authentication_string=password('123456') where host='localhost' and user='root';
Query OK, 0 rows affected, 1 warning (0.00 sec)
Rows matched: 1 Changed: 0 Warnings: 1
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
修改密码后,打开mysql客户端连接数据库,执行操作时会提示需要更改密码
set password for root@'localhost'=password('123456');
最后,重启数据库
注意:
而在MySQL 8.0.11版本中,这种方式基本不可行,因为其已移除了PASSWORD()函数及不再支持SET PASSWORD ... = PASSWORD ('auth_string')语法。
不难发现,这种方式的可移植性实在太差,三个不同的版本,就先后经历了列名的改变,及命令的不可用。
其他方法参考:
https://www.cnblogs.com/ivictor/p/9243259.html