千家信息网

MySQL5.7密码修改方法

发表于:2024-09-22 作者:千家信息网编辑
千家信息网最后更新 2024年09月22日,下面讲讲关于MySQL5.7密码修改方法,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完MySQL5.7密码修改方法这篇文章你一定会有所受益。MySQL5.7出来蛮久了,今
千家信息网最后更新 2024年09月22日MySQL5.7密码修改方法

下面讲讲关于MySQL5.7密码修改方法,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完MySQL5.7密码修改方法这篇文章你一定会有所受益。

MySQL5.7出来蛮久了,今天用官方的RPM包安装玩了一遍,与值之前的版本有些差异,MARK下。

OS PLATFORM:Centos 7.3

安装MySQL 5.7版本,官网http://dev.mysql.com/downloads/repo/yum/

rpm -ivh http://dev.mysql.com/get/mysql57-community-release-el7-9.noarch.rpm

YUM安装:

yum -y install mysql-community-server

速度不是很快,慢慢等。。。。。。。。。

更改DATADIR

sed- i 's/datadir=/var/lib/mysql/datadir=/data/mysql/' /etc/my.cnf

启动数据库

/etc/init.d/mysqld start #该过程包含初始化数据库

MySQL5.7新特性,为了加强安全性,为root用户随机生成了一个密码,在/var/log/mysqld.log文件中给root生成了一个默认密码。通过下面的方式找到root默认密码,然后登录mysql进行修改:

# grep 'temporary password' /var/log/mysqld.log2017-08-16 T14:51:45.705458Z 1 [Note] A temporary password is generated for root@localhost: a&sqr7dou7N_mysql -uroot -p'a&sqr7dou7N_'

登陆上过后,进行正常操作会受限,提示你必须修改密码后才能进行操作,根据提示修改密码:

mysql> SET PASSWORD = PASSWORD('123456'); ERROR 1819 (HY000): Your password does not satisfy the current policy requirementsmysql> SET PASSWORD = PASSWORD("root");ERROR 1819 (HY000): Your password does not satisfy the current policy requirements

但是提示根据当前密码策略,设置的密码不允许。
查阅官方文档后发现有以下三种密码策略:
Policy Tests Performed
0 or LOW Length
1 or MEDIUM Length; numeric, lowercase/uppercase, and special characters
2 or STRONG Length; numeric, lowercase/uppercase, and special characters; dictionary file

当前密码策略默认为1 也就是 MEDIUM

mysql root@localhost:(none)> show VARIABLES like "%password%"+---------------------------------------+---------+| Variable_name                         | Value   ||---------------------------------------+---------|| default_password_lifetime             | 0       || disconnect_on_expired_password        | ON      || log_builtin_as_identified_by_password | OFF     || mysql_native_password_proxy_users     | OFF     || old_passwords                         | 0       || report_password                       |         || sha256_password_proxy_users           | OFF     || validate_password_dictionary_file     |         || validate_password_length              | 8       || validate_password_mixed_case_count    | 1       || validate_password_number_count        | 1       || validate_password_policy              | MEDIUM  || validate_password_special_char_count  | 1       |+---------------------------------------+---------+13 rows in setTime: 0.030s

更改密码的策略是 数字 小写字母 大写字母 特殊字符 长度至少8位 。
更改完密码就可以进行数据库的操作了。

mysql root@localhost:(none)> show DATABASES;+--------------------+| Database           ||--------------------|| information_schema || mysql              || performance_schema || sys                |+--------------------+4 rows in setTime: 0.009s

接下来修改默认密码策略(当然实际环境是不推荐修改为更低安全策略的)

mysql root@localhost:(none)> set global validate_password_policy = 0;Query OK, 0 rows affectedTime: 0.003s

设置完默认密码策略后,就只有 密码长度限制 了。默认为字符长度至少8位。

想要永久关闭密码复杂安全策略,则在配置文件中加入以下并重启mysqld即可:
[mysqld]
validate_password=off

对于以上MySQL5.7密码修改方法相关内容,大家还有什么不明白的地方吗?或者想要了解更多相关,可以继续关注我们的行业资讯板块。

0