<亲测>CentOS7 安装mysql8.0(YUM方式)
1.下载mysql源安装包
shell> wget http://dev.mysql.com/get/mysql80-community-release-el7-1.noarch.rpm
2.安装mysql源
shell> yum localinstall mysql80-community-release-el7-1.noarch.rpm
3.检查mysql源是否安装成功
shell> yum repolist enabled | grep "mysql.*-community.*"
4.修改 vim /etc/yum.repos.d/mysql-community.repo源,改变默认安装的mysql版本。比如要安装5.6版本,将5.7源的enabled=1改成enabled=0。然后再将5.6源的enabled=0改成enabled=1即可。
5.安装MySQL
shell> sudo yum install mysql-server --nogpgcheck
6.启动MySQL服务
shell> systemctl start mysqld
7.开机启动
shell> systemctl enable mysqld
shell> systemctl daemon-reload
8.修改root本地登录密码
1)查看mysql密码
shell> grep 'temporary password' /var/log/mysqld.log
2)连接mysql
shell> mysql -uroot -p
3)修改密码,注意:后面的分号一定要跟上
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'Root@123';
或者:
mysql> set password for 'root'@'localhost'=password('Root@123');
mysql> show variables like '%password%';
9.添加远程登录用户
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%'WITH GRANT OPTION;
PS:
这是 mysql 初始化时,使用临时密码,修改自定义密码时,由于自定义密码比较简单,就出现了不符合密码策略的问题。
一、密码策略问题异常信息:
ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
解决办法:
1、查看 mysql 初始的密码策略,
输入语句 show variables like '%password%'; 进行查看,
2、首先需要设置密码的验证强度等级,设置 validate_password_policy 的全局参数为 LOW 即可,
输入设值语句 “ set global validate_password_policy=LOW; ” 进行设值,
3、当前密码长度为 8 ,如果不介意的话就不用修改了,按照通用的来讲,设置为 6 位的密码,设置 validate_password_length 的全局参数为 6 即可,
输入设值语句 “ set global validate_password_length=6; ” 进行设值,
4、现在可以为 mysql 设置简单密码了,只要满足六位的长度即可,
输入修改语句 “ ALTER USER ‘root’@‘localhost’ IDENTIFIED BY ‘123456’; ” 可以看到修改成功,表示密码策略修改成功了!!!
注:在默认密码的长度最小值为 4 ,由 大/小写字母各一个 + 阿拉伯数字一个 + 特殊字符一个,
只要设置密码的长度小于 3 ,都将自动设值为 4 ,
关于 mysql 密码策略相关参数;
1)、validate_password_length 固定密码的总长度;
2)、validate_password_dictionary_file 指定密码验证的文件路径;
3)、validate_password_mixed_case_count 整个密码中至少要包含大/小写字母的总个数;
4)、validate_password_number_count 整个密码中至少要包含阿拉伯数字的个数;
5)、validate_password_policy 指定密码的强度验证等级,默认为 MEDIUM;
关于 validate_password_policy 的取值:
0/LOW:只验证长度;
1/MEDIUM:验证长度、数字、大小写、特殊字符;
2/STRONG:验证长度、数字、大小写、特殊字符、字典文件;
6)、validate_password_special_char_count 整个密码中至少要包含特殊字符的个数;
二、2059错误码,原因:mysql8之前版本中加密规则为mysql_native_password,mysql8以后的加密规则为caching_sha2_password,将mysql用户登录加密规则修改为mysql_native_password即可!
1.进入doc: 点击Window+R 输入cmd
2.登陆数据库:输入mysql -uroot -p
3.输入你的数据库密码,正确后显示登陆成功 出现Welcome to the MySQL monitor.
4.输入use mysql; 出现Database changed
5.输入select user,host from user; 目的为了查看user的root 对应host是什么 我的对应为localhost
6.修改加密规则:输入ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'Root@123';
注:第一个root为数据库用户名 第二个root为数据库密码。切记换成自己的用户名和密码