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

相关推荐
Jim6002 天前
【吃透 MySQL InnoDB连载】第 1 章・解密线上数据库高频故障
mysql
GreatSQL2 天前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql
云技纵横5 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二5 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
小猿姐6 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
云技纵横6 天前
Gap Lock 死锁实战:5 秒在本地复现 MySQL 间隙锁死锁
后端·mysql
无响应de神6 天前
三、用户与权限管理
数据库·mysql
摇滚侠7 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql