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

相关推荐
小旭95277 小时前
MySql调优详解
数据库·mysql·数据库架构
九皇叔叔7 小时前
MySQL实操指南:复制表及数据复制全解析
android·数据库·mysql
识君啊8 小时前
38 个 MySQL 索引核心问题:原理、失效场景与优化实战
数据库·mysql
爱莉希雅&&&8 小时前
MySQL MGR 组复制 完整笔记
linux·数据库·笔记·mysql·mgr·数据库同步
Captain_Data10 小时前
SQL优化实战:如何让查询速度提升10倍
数据库·sql·mysql·性能优化·数据分析
Jasminee10 小时前
SQL 基础语法总结
sql·mysql
爱吃牛肉的大老虎11 小时前
MySQL优化之系统表分析SQL
android·sql·mysql
.柒宇.11 小时前
MySQL的MGR高可用
数据库·mysql·adb
当战神遇到编程11 小时前
MySQL核心篇:增删改查(CRUD)
数据库·mysql
猿小喵11 小时前
记录一次长时间未提交事务造成的慢SQL
数据库·sql·mysql