Centos7.9下 Mysql8.0 重置密码

一、Linux下 Mysql8.0 密码重置

1.进入 my.cnf,在[mysqld]的段中加上一句: skip-grant-tables。跳过权限。
js 复制代码
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8mb4
[client]
port       = 3306
socket     = /tmp/mysql.sock
# bind-address = 127.0.0.1
# bind-address = 0.0.0.0
 
[mysqld]
port       = 3306
server-id  = 3306
user       = mysql
socket     = /tmp/mysql.sock
#跳过权限
skip-grant-tables
2.重新启动mysqld,清空密码。
javascript 复制代码
[docker]
1.查找运行的mysql容器实例
# docker ps
2.重启容器实例
# docker restart ID

[mysql 实例]
# service mysql restart

[进入Mysql] 清空密码
# mysql -h localhost -u root
# bin/mysql -h 127.0.0.1 -P 3306 -u root -pxxxxxx
MySQL [(none)]> use mysql;
Database changed
MySQL [mysql]> update user set authentication_string='' where user='root' and host= 'localhost';
MySQL [mysql]> select user,host,plugin,authentication_string from user where user='root' and host= 'localhost';
MySQL [mysql]> exit;
3.注掉 skip-grant-tables,重启服务。
javascript 复制代码
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8mb4
[client]
port       = 3306
socket     = /tmp/mysql.sock
# bind-address = 127.0.0.1
# bind-address = 0.0.0.0
 
[mysqld]
port       = 3306
server-id  = 3306
user       = mysql
socket     = /tmp/mysql.sock
#跳过权限
# skip-grant-tables
4.重置密码
javascript 复制代码
1.重启mysql
[docker]
a.查找运行的mysql容器实例
# docker ps
b.重启容器实例
# docker restart ID
[mysql 实例]
# service mysql restart

2.进入mysql
# mysql -u root
# mysql -h localhost -u root

3.进入mysql后, 切换数据库至mysql
MySQL [(none)]> use mysql;
Database changed

4.重置密码,并刷新权限
MySQL [mysql]> ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '新密码';
MySQL [mysql]> flush privileges;

二、Mysql用户授权

javascript 复制代码
1.用户授权
# grant #auth on #databaseName.#table to '#userName'@'#host';
#auth 代表权限,如下:
+ all privileges 全部权限
+ select 查询权限
+ select,insert,update,delete 增删改查权限
+ select,[...]增...等权限
#databaseName 代表数据库名#table 代表具体表,如下
+ *.*代表全部表
+A.B 代表具体A,B表
#userName 代表用户名
#host 代表访问权限,如下
+ %代表通配所有host地址权限(可远程访问)
+ localhost为本地权限(不可远程访问)
+ 指定特殊Ip访问权限 如10.138.106.102

2.查看用户授权
SHOW GRANTS FOR 'username'@'hostname';
SHOW GRANTS FOR 'dsp2waff'@'%';


栗子:
MySQL [mysql]> select user,host,plugin,authentication_string from user where user = 'dsp2';
MySQL [mysql]> create user 'dsp2waff'@'%';
MySQL [mysql]> alter user 'dsp2waff'@'%' identified with mysql_native_password by 'xtdesoft';
MySQL [mysql]> grant select,execute on dsp.* to 'dsp2waff'@'%';
MySQL [mysql]> flush privileges;

MySQL [mysql]> grant select on waff_mini_test.* to 'waffmini'@'%';
MySQL [mysql]> flush privileges;
MySQL [mysql]> SHOW GRANTS FOR 'dsp2waff'@'%';

MySQL [mysql]> create user 'waff'@'%';
MySQL [mysql]> alter user 'waff'@'%' identified with mysql_native_password by 'xtdesoft';
MySQL [mysql]> grant all privileges on waff.* to 'waff'@'%';
MySQL [mysql]> flush privileges;

参考与引用

(46条消息) Linux版mysql8.0强制重置密(详细步骤),再也不怕密码忘记了!_十年少i的博客-CSDN博客 (46条消息) mysql 8.0 创建用户并赋权限_小丶达的博客-CSDN博客_mysql8.0赋予权限

转至:https://juejin.cn/post/7460447225954942985

相关推荐
罗超驿10 小时前
8.数据库约束学习笔记:从非空、默认、唯一与主键约束到主键自增
数据库·mysql
Irene199112 小时前
SQL示例:分别使用 MySQL 和 Oracle 创建表,MySQL 插入数据建索引(自增主键、指定主键的区别,VARCHAR,VARCHAR2)
mysql·oracle
用户42176328140713 小时前
如何用java实现一个简单的并发版本控制MVCC
mysql
阿维的博客日记13 小时前
求解深分页问题,last pk适合什么情况
java·mysql·深分页
__water14 小时前
【下载配置Mysql】
mysql
Dxy123931021616 小时前
MySQL 连表查询更新:从理论到实践
数据库·mysql
阿丰资源17 小时前
基于Springboot+mysql的在线兼职平台(附源码)
spring boot·后端·mysql
怪祝浙17 小时前
从简单项目入手Java(学生系统)V6(Web版本 Spring Boot3 MySQL Vue3 MyBatis)
java·spring boot·mysql
噢,我明白了17 小时前
MySql数据库数据基础操作(增删改查)
数据库·mysql·增删改查
tongluowan00718 小时前
MySql中Binlog,Redolog,Undolog的应用场景及作用的时机
mysql·日志文件