本文共 1785 字,大约阅读时间需要 5 分钟。
/etc/init.d/mysql stop
mysqld_safe --skip-grant-tables --user=mysql & --
提示:在启动时加-- skip - grant - tables 参数,表示忽略授权验证 shell>mysql
mysql>update mysql.user set password=password("123456") where user='root' and host='localhost';
mysql>flush privileges;
shell>mysqladmin -uroot -p123456 shutdown
shell>/etc/init.d/mysql start
shell>mysql -uroot -p123456
mysqld_mulit stop
mysqld_safe --defaults-files=/data/mysql/mysql3377/mysql3377.cnf --skip-grant-tables &
mysql -uroot -p -S /tmp/mysql3377.sock <==登录时空密码
update mysql.user set password=password("123456") where user='root'
flush privileges;
killall mysqld
mysqld_mulit restart 3377
三、不重启mysqld的方法
1、首先得有一个可以拥有修改权限的mysql数据库账号,当前的mysql实例账号(较低权限的账号,比如可以修改test数据库)或者其他相同版本实例的账号。把data/mysql目录下面的user表相关的文件复制到data/test目录下面。
cp mysql/user.* test/
chown mysql.mysql test/user.*
2、使用另一个较低权限的账号链接数据库,设置test数据库中的user存储的密码数据。
mysql> use testReading table information for completion of table and column namesYou can turn off this feature to get a quicker startup with -ADatabase changedmysql> update user set password=password('xxxx') where user='root';Query OK, 0 rows affected (0.00 sec)Rows matched: 5 Changed: 0 Warnings: 0mysql>
3、把修改后的user.MYD和user.MYI复制到mysql目录下,记得备份之前的文件。
mv mysql/user.MYD mysql/user.MYD.bakmv mysql/user.MYI mysql/user.MYI.bakcp test/user.MY* mysql/ chown mysql.mysql mysql/user.*
4、查找mysql进程号,并且发送SIGHUP信号,重新加载权限表。
[root@localhost mysql]# pgrep -n mysql2184[root@localhost mysql]#
[root@localhost mysql]# kill -SIGHUP 2184
5.登陆测试
[root@localhost mysql]# mysql -uroot -pxxxxmysql>
转载地址:http://azaqa.baihongyu.com/