博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Mysql5.7忘记root密码及mysql5.7修改root密码的方法
阅读量:5862 次
发布时间:2019-06-19

本文共 2527 字,大约阅读时间需要 8 分钟。

hot3.png

关闭正在运行的 MySQL :

1

[root@www.woai.it ~]# service mysql stop

运行

1

[root@www.woai.it ~]# mysqld_safe --skip-grant-tables &

为了安全可以这样禁止远程连接:

1

[root@www.woai.it ~]# mysqld_safe --skip-grant-tables --skip-networking &

使用mysql连接server:

1

[root@www.woai.it ~]# mysql -p

更改密码:

1

mysql> update mysql.user set authentication_string=password('123qwe') where user='root' and Host = 'localhost';

*特别提醒注意的一点是,新版的mysql数据库下的user表中已经没有Password字段了

而是将加密后的用户密码存储于authentication_string字段

1

2

mysql> flush privileges;

mysql> quit;

修改完毕。重启

1

[root ~]# service mysql restart

然后mysql就可以连接了

但此时操作似乎功能不完全,还要alter user…

1

mysql> alter user 'root'@'localhost' identified by '123';

这样也可以:

1

mysql> set password for 'root'@'localhost'=password('123');

重点给大家介绍下mysql 5.7 root密码修改

MySQL管理者密码设置或修改:

依据官方说明5.6以后版本,第一次启动时会在root目录下生产一个随机密码,文件名.mysql_secret。

1

2

3

4

5

[root@bright ~]# cat /root/.mysql_secret

# Password set for user 'root@localhost' at 2015-03-27 23:12:10

:Jj+FTiqvyrF

[root@bright ~]# cd /usr/local/mysql/bin/

[root@bright bin]# ./mysqladmin -u root -h localhost password '123456' -p

Enter password: #此行输入.mysql_secret里第二行内容

1

2

mysqladmin: [Warning] Using a password on the command line interface can be insecure.

Warning: Since password will be sent to server in plain text, use ssl connection to ensure password safety.

官方的方式,笔者无论是否使用--skip-grant-tables启动mysql都测试失败,亲们可以测试:

1

2

shell>mysql -uroot -p'password' #password即.mysql_secret里的密码

mysql>SET PASSWORD = PASSWORD('newpasswd');

2016111151524079.jpg?2016011151539

旧版本,安装后ROOT无密码,按如下操作:

方法一:

1

2

3

4

5

6

7

shell>service mysqld stop #停止mysql服务

shell>mysqld_safe --skip-grant-tables & #以不启用grant-tables模式启动mysql

shell>mysql -uroot -p #输入命令回车进入,出现输入密码提示直接回车。

mysql>use mysql;

mysql>update user set password=PASSWORD("123456")where user="root"; #更改密码为 newpassord

mysql>flush privileges; #更新权限

mysql>quit #退出

方法二:

1

2

3

4

shell>service mysqld stop #停止mysql服务

shell>mysqld_safe --skip-grant-tables & #以不启用grant-tables模式启动mysql

shell>mysql -uroot -p #输入命令回车进入,出现输入密码提示直接回车。

mysql > set password for root@localhost = password('mysqlroot');

方法三:

1

shell>/path/mysqladmin -u UserName -h Host password 'new_password' -p

 参考:http://www.jb51.net/article/77858.htm

skip-grant-tables

顾名思义,启动的时候 跳跃权限表的限制,不用验证密码,直接登录。

注意:

这种情况只有在忘记root密码 不得已重启数据库的情况下使用的。现网环境慎用,需要重启数据库,并且安全性也比较难以保证。

1.修改配置参数

/etc/my.cnf

[mysqld] 下面加上:

skip-grant-tables

配置项。

2.重启

使得参数生效:

service mysqld restart

3.注意事项

此时所有用户登录当前数据库都是免密码的,所以此时数据库的安全性是非常低的。

4.修改密码

具体的办法:

5.去掉参数

a.密码修改好了之后再将配置文件中 skip-grant-tables去掉

b.再次重启数据库。

转载于:https://my.oschina.net/u/1260221/blog/876511

你可能感兴趣的文章
达观数据王子豪:这5个例子,小学生都能秒懂分类算法
查看>>
干货!撸一个webpack插件(内含tapable详解+webpack流程)
查看>>
大数据核心知识点:Hbase、Spark、Hive、MapReduce概念理解,特点及机制
查看>>
SQLServer之数据类型解析
查看>>
PHP实现并发请求
查看>>
css自定义属性和聚光灯效果
查看>>
Java知识点总结(反射-反射机制性能问题)
查看>>
命令行笔记
查看>>
5种方法教你用Python玩转histogram直方图
查看>>
HTML_关于现代前端必要知识
查看>>
使用 Laravel 制定 MySQL 数据库备份计划任务
查看>>
什么是模块,什么是组件
查看>>
前端跨域策略实践----cors,jsonp
查看>>
Yii2:教你一步步写一个微信商城(一)
查看>>
第3章:抽象数据类型(ADT)和面向对象编程(OOP) 3.5 ADT和OOP中的等价性
查看>>
备忘录模式(Memento)
查看>>
【跃迁之路】【490天】刻意练习系列249(2018.06.10)
查看>>
js中的数据类型和数据类型转换
查看>>
基于阿里云HiTSDB搭建工业物联网平台实践
查看>>
【跃迁之路】【439天】程序员高效学习方法论探索系列(实验阶段196-2018.04.20)...
查看>>