# CentOS7 设置mysql的 root 用户密码时,报错 ERROR 1819(HY000)...ERROR1193... 解决方法。

CentOS7 设置mysql的 root 用户密码时,报错 ERROR 1819(HY000)...ERROR1193... 解决方法。

一、错误描述:

bash 复制代码
mysql  ALTER USER 'root'@'localhost' IDENTIFIED BY '123';
ERROR 1819 (HY000) Your password does not satisfy the current policy requirements

ERROR1819提示密码不符合安全策略,那么就修改安全策略。

二、解决方法

1、如果是第一次登录 mysql需要先修改密码,才能进行其他操作,所以先设置一个带特殊字符的长密码。

bash 复制代码
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY ':UNy3qH15=zF-dih';

2、查看MySQL安全策略

bash 复制代码
 show variables ike 'validate_password%';

3、修改 mysql 安全策略

bash 复制代码
mysql> set global validate_password.policy=0;
Query OK, 0 rows affected (0.00 sec)

mysql> 
mysql> set global validate_password.length=1;
Query OK, 0 rows affected (0.00 sec)

mysql> set global validate_password_policy=0; 
Query OK, 0 rows affected (0.00 sec)

mysql> 
mysql> set global validate_password_length=1; 
Query OK, 0 rows affected (0.00 sec)

# 再次查看安全策略,发现已经修改过来
mysql> show variables like 'validate_password%';

4、刷新权限

bash 复制代码
mysql> flush privileges;
Query OK, 0 rows affected (0.07 sec)

5、再次修改成短密码,已经可以成功修改。

bash 复制代码
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '12311';
Query OK, 0 rows affected (0.02 sec)

退出 mysql 尝试用新密码登录

bash 复制代码
mysql> exit
Bye

[root@bogon mysql]# mysql -uroot -p12311

mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 13
Server version: 8.0.39 MySQL Community Server - GPL
Copyright (c) 2000, 2024, Oracle and/or its affiliates.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

三 、如果修改 mysql 安全策略报错 ERROR1193,说明没有密码验证插件,需要退出 mysql 在终端打开 /etc/my.cnf 配置文件,修改保存。

1、修改 mysql 配置文件 /etc/my.cnf

bash 复制代码
# 退出mysql
mysql> exit
Bye
# 打开 mysql 配置文件
[root@bogon mysql]# vim /etc/my.cnf         

# 在文件最后,添加如下内容。

[mysqld]

datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock

log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

# 添加插件
# 插件的加载方法,每次服务器启动时都必须给出该选项
plugin-load-add=validate_password.so

# 在服务器启动时使用该选项来控制插件的激活
validate-password=FORCE_PLUS_PERMANENT

2、修改了配置之后一定要重启MySQL服务,重新登录 mysql 服务,进行安全策略修改。

bash 复制代码
# 重启 mysql
[root@bogon mysql]# systemctl restart mysqld

# 登录 mysql
[root@bogon mysql]# mysql -uroot -p 

# 修改 mysql 安全策略
mysql> set global validate_password.policy=0;
mysql> set global validate_password.length=1;

mysql> set global validate_password_policy=0; 
mysql> set global validate_password_length=1; 

# 再次查看安全策略,发现已经修改过来
mysql> show variables like 'validate_password%';

# 刷新权限
mysql> flush privileges;

# 修改密码
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '12311';
相关推荐
Sapphire~2 小时前
Linux-07 ubuntu 的 chrome 启动不了
linux·chrome·ubuntu
伤不起bb2 小时前
NoSQL 之 Redis 配置与优化
linux·运维·数据库·redis·nosql
广东数字化转型2 小时前
nginx怎么使用nginx-rtmp-module模块实现直播间功能
linux·运维·nginx
啵啵学习2 小时前
Linux 里 su 和 sudo 命令这两个有什么不一样?
linux·运维·服务器·单片机·ubuntu·centos·嵌入式
半桔3 小时前
【Linux手册】冯诺依曼体系结构
linux·缓存·职场和发展·系统架构
网硕互联的小客服3 小时前
如何利用Elastic Stack(ELK)进行安全日志分析
linux·服务器·网络·安全
冰橙子id4 小时前
linux——磁盘和文件系统管理
linux·运维·服务器
无聊的小坏坏5 小时前
环境变量深度解析:从配置到内核的全链路指南
linux·bash
才鲸嵌入式5 小时前
01 Ubuntu20.04下编译QEMU8.2.4,交叉编译32位ARM程序,运行ARM程序的方法
linux·c语言·单片机·嵌入式·arm·qemu·虚拟机
天天摸鱼的java工程师6 小时前
高考放榜夜,系统别崩!聊聊查分系统怎么设计,三张表足以?
java·后端·mysql