mysql 单实例设置密码_MySQL单实例重置密码的两种方法

MySQL单实例重置密码的两种方法

在工作学习中,我们有时会忘记数据库的密码,下面是MySQL单实例密码重置的步骤。

说明:

(1)[root@mysql1 ~]# cat /etc/redhat-release

CentOS release 6.7 (Final)

(2)[root@mysql1 ~]# mysql --version

mysql  Ver 14.14 Distrib 5.7.13, for Linux (i686) using  EditLine wrapper

主要步骤如下:

首先停止MySQL

[root@mysql1 ~]# /etc/init.d/mysqld stop

/etc/init.d/mysqld: line 46: /usr/local/mysql: is a directory

/etc/init.d/mysqld: line 47: /usr/local/mysql/data: is a directory

Shutting down MySQL. SUCCESS!

查看MySQL的状态:

[root@mysql1 ~]# /etc/init.d/mysqld status

/etc/init.d/mysqld: line 46: /usr/local/mysql: is a directory

/etc/init.d/mysqld: line 47: /usr/local/mysql/data: is a directory

ERROR! MySQL is not running

查看MySQL的进程:

[root@mysql1 ~]# ps aux|grep mysql|grep -v grep

使用--skip-grant-tables启用MySQL忽略登入授权验证

[root@mysql1 ~]# mysqld_safe --skip-grant-tables --user=mysql &

[1] 6559

[root@mysql1 ~]# 2017-07-30T14:23:38.600285Z mysqld_safe Logging to '/usr/local/mysql/data/mysqld.err'.

2017-07-30T14:23:38.640326Z mysqld_safe Starting mysqld daemon with databases from /usr/local/mysql/data

无需密码即可登入MySQL

[root@mysql1 ~]# mysql

66e03958b0aa61b5f8da8d94257141fe.png

重置root密码

说明:新安装的MySQL5.7,登录时提示密码错误,安装的时候并没有更改密码,后来通过免密码登录的方式更改密码,输入update mysql.user set password=password('wtf123') where user='root' and host='localhost'时提示ERROR 1054 (42S22): Unknown column 'password' in 'field list',原来是mysql5.7数据库下已经没有password这个字段了,password字段改成了authentication_string.

mysql> update mysql.user set authentication_string=password('wtf123') where user='root’and host='localhost';

Query OK, 1 row affected, 1 warning (0.00 sec)

Rows matched: 1  Changed: 1  Warnings: 1

bb73c0b8ec391449bd03b3c6aeb3742c.png

刷新:mysql> flush privileges;

退出:mysql> quit

说明:不能使用set password=password('wtf1234');

3fe336919cc57de9b07099992ad6f31e.png

重启服务再登入

[root@mysql1 ~]# /etc/init.d/mysqld restart

[root@mysql1 ~]# mysql -uroot -pwtf123

说明:查看数据库密码命令:

mysql> select user,host,authentication_string from mysql.user;

4c9e13bb9845ef590071af4b0e864273.png

扩展:通过修改/etc/my.cnf 配置文件来重置mysql密码

1.打开mysql的配置文件,命令:vim /etc/my.cnf。在配置文件中新增一行skip-grant-tables,结果如下图所示:

881fb5c4b7fb89843a725da835d6009b.png

2.保存并退出!

3.重启mysqld,命令:service mysqld restart

4.无需密码即可登入MySQL

[root@mysql1 ~]# mysql

mysql> update mysql.user set authentication_string=password('123456') where        user='root’and host='localhost';

flush privileges; #刷新权限

6c62eb7f3c743d052efd6c521615b901.png

退出:quit

5.退出后还原my.cnf重启,命令如下:

vim /etc/my.cnf  #打开mysql配置文件,将skip-grant-tables前面加#;

/etc/init.d/mysqld restart  #重新启动mysql;

用新密码登入mysql数据库,命令如下:

#mysql –uroot –p123456即可正常登入数据库了!

本文转自品鉴初心51CTO博客,原文链接:http://blog.51cto.com/wutengfei/1952520,如需转载请自行联系原作者

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值