MySql8.0以上版本正确修改ROOT密码的方法

作者:奥斯维克鸡腿学徒 时间:2024-01-22 12:24:40 

部署环境:

安装版本red hat Cent 7.0

MYSQL 版本 8.0.2.0

成功部署完毕后出现故障情况:

1.      正常启动MYSQL服务后,敲Linux中root账户和密码进入不去。

MySql8.0以上版本正确修改ROOT密码的方法

2.      从/etc/my.cnf 配置文件中加入skip-grant-table后正常登陆,但是不能创建用户等多操作

MySql8.0以上版本正确修改ROOT密码的方法

MySql8.0以上版本正确修改ROOT密码的方法

总结来说:

想进去mysql后不能操作多指令,操作多指令又不能进去mysql,死循环

挖坑环节:

网上找了很多办法,首先加入skip-grant-table.后进去刷新权限表,重启服务,不用密码的root进去,在改root密码后,重新刷新权限表。方法试了很多个都不对。修改root环节始终不对。

MySql8.0以上版本正确修改ROOT密码的方法

给了我提醒,是不是mysql8.0以上的版本密码策略和更改语法不对了。

重新操作一遍:

#vim /etc/my.cnf

【mysql】

添加skip-grant-table


#systemctl stop mysqld.service
#systemctl start mysqld.service
#mysql –u root

[敲回车进入]


mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
mysql> alter user 'root'@'localhost'IDENTIFIED BY 'MyNewPass';
ERROR 1819 (HY000): Your password does notsatisfy the current policy requirements
mysql> alter user 'root'@'localhost'IDENTIFIED BY 'MyNewPass@123';
ERROR 1396 (HY000): Operation ALTER USERfailed for 'root'@'localhost'
mysql> alter user'root'@'%' IDENTIFIED BY 'MyNewPass@123';

 【mysql8.0以上密码策略限制必须要大小写加数字特殊符号,我之前用mysqladmin,set,update,参考修改root密码的前人:在文章末尾有介绍。

Query OK, 0 rows affected (0.05 sec)

退出,把Skip-grant-table语句删除,重新启动数据库


[root@localhost ~]# vim /etc/my.cnf【删除省略】
[root@localhost ~]# systemctl stopmysqld.service
[root@localhost ~]# systemctl startmysqld.service
[root@localhost ~]# mysql -uroot –p
mysql> CREATE USER dbadmin@localhost
-> IDENTIFIED BY 'pwd123';
ERROR 1819 (HY000): Your password does notsatisfy the current policy requirements
mysql> CREATE USER dbadmin@localhost
-> IDENTIFIED BY 'Pwd123';
ERROR 1819 (HY000): Your password does notsatisfy the current policy requirements
mysql> CREATE USER dbadmin@localhost
-> IDENTIFIED BY 'Pwd@123';
ERROR 1819 (HY000): Your password does notsatisfy the current policy requirements
mysql> CREATE USER dbadmin@localhost
-> IDENTIFIED BY 'MyNewPass@123';
Query OK, 0 rows affected (0.10 sec)

【可以正常创建用户,密码安全性还是要求着设置复杂度要高一些】

MySql8.0以上版本正确修改ROOT密码的方法

第二使用SQL工具进行远程连接,这里使用SQLyog进行远程连接。

  一般来说,直接用ROOT用户的账号密码去连接是不行,即时密码正确。

MYSQL 8.0内新增加mysql_native_password函数,通过更改这个函数密码来进行远程连接。

2.1 第一可以更改ROOT用户的native_password密码


mysql> ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY'MyPass@123';
Query OK, 0 rows affected (0.15 sec)

MySql8.0以上版本正确修改ROOT密码的方法

2.2 第二可以用Root用户登录新增加用户,进行授权再远程连接。


mysql> CREATE USER 'super'@'%'IDENTIFIED BY 'MyPass@123';
Query OK, 0 rows affected (0.10 sec)
Query OK, 0 rows affe mysql> GRANT ALLON *.* TO 'super'@'%' WITH GRANT OPTION;
Query OK, 0 rows affected (0.10 sec)
mysql> Flush privileges;
Query OK, 0 rows affected (0.00 sec)cted(0.01 sec)
mysql> ALTER USER 'super'@'%' IDENTIFIEDWITH mysql_native_password BY 'MyPass@123';
Query OK, 0 rows affected (0.10 sec)

MySql8.0以上版本正确修改ROOT密码的方法

注意:更改了mysql_native_passwd密码,等同更改用户原始密码。MYSQL 8.0 内以mysql-native_passwd为主,从Shell界面登录需要注意了。

ps:下面看下MySQL修改root密码的多种方法

在 Navicat for MySQL 下面直接执行  SET PASSWORD FOR 'root'@'localhost' = PASSWORD('newpass');   就可以

方法1: 用SET PASSWORD命令


mysql -u root
mysql> SET PASSWORD FOR 'root'@'localhost' = PASSWORD('newpass');

方法2:用mysqladmin

mysqladmin -u root password "newpass"

如果root已经设置过密码,采用如下方法

mysqladmin -u root password oldpass "newpass"

方法3: 用UPDATE直接编辑user表


mysql -u root
mysql> use mysql;
mysql> UPDATE user SET Password = PASSWORD('newpass') WHERE user = 'root';
mysql> FLUSH PRIVILEGES;

在丢失root密码的时候,可以这样


mysqld_safe --skip-grant-tables&
mysql -u root mysql
mysql> UPDATE user SET password=PASSWORD("new password") WHERE user='root';
mysql> FLUSH PRIVILEGES;

总结

以上所述是小编给大家介绍的MySql8.0以上版本正确修改ROOT密码的方法,网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

来源:https://blog.csdn.net/yi247630676/article/details/80352655

标签:mysql,8.0,修改,root,密码
0
投稿

猜你喜欢

  • Python NumPy教程之数组的基本操作详解

    2021-08-15 16:20:12
  • tensorflow2.0如何实现cnn的图像识别

    2022-05-01 21:19:58
  • Python格式化输出字符串的五种方法总结

    2023-03-30 02:07:42
  • 支持多类型数据库的c#数据库模型示例

    2024-01-13 16:41:15
  • Python Pandas 获取列匹配特定值的行的索引问题

    2023-11-01 06:37:42
  • django 创建过滤器的实例详解

    2023-07-09 16:25:00
  • Python异常处理知识点总结

    2023-01-04 16:03:36
  • Jupyter Notebook内使用argparse报错的解决方案

    2023-05-08 21:43:52
  • 根据多条件查询临时表 想得到不同结果集的方法

    2024-01-23 22:49:37
  • ORACLE 10G修改字符编码没有超字符集的限制

    2024-01-16 21:29:57
  • Python Pandas中布尔索引的用法详解

    2023-11-04 08:37:45
  • php+Memcached实现简单留言板功能示例

    2023-11-15 09:30:02
  • Pytorch实现神经网络的分类方式

    2021-02-26 05:20:47
  • asp函数判断服务器是否安装了某种组件

    2008-10-11 14:45:00
  • Python对象与引用的介绍

    2023-04-30 12:51:59
  • JS获取当前时间的实例代码(昨天、今天、明天)

    2024-04-23 09:28:36
  • Pytorch技巧:DataLoader的collate_fn参数使用详解

    2023-12-11 00:20:48
  • CSS兼容IE6,IE7,FF的技巧

    2010-04-01 12:34:00
  • 利用Python的tkinter模块实现界面化的批量修改文件名

    2023-08-30 20:45:15
  • Vue 2.0入门基础知识之内部指令详解

    2024-05-10 14:17:19
  • asp之家 网络编程 m.aspxhome.com