一、环境
操作系统
[root@localhost ~]# cat /etc/redhat-release
CentOS Linux release 7.2.1511 (Core)
将要安装的mysql版本
mysql> select version();
+-----------+
| version() |
+-----------+
| 5.7.18 |
+-----------+
1 row in set (0.00 sec)
二、安装
在任意目录执行下述三句命令,即可完成安装mysql。
(1)下载
以下命令是从官网下载mysql的rmp package并保存在当前目录(保存在任意位置均可,但第二步中的安装repo命令也要在当前下载目录执行)。可以从官网找到最新的各个版本的安装包,如果安装其他版本可以将命令中的版本信息替换掉。
[root@localhost ~]# wget https://dev.mysql.com/get/mysql57-community-release-el7-9.noarch.rpm
(2)安装repo
[root@localhost ~]# rpm -ivh mysql57-community-release-el7-9.noarch.rpm
(3)安装mysql-server
[root@localhost ~]# yum install mysql-server
三、设置密码
严格按照步骤来
在上一步安装完成后,启动mysql后会发现,直接输入mysql
,会发现直接就进入了,或者输入mysql -u root -p
,让输入密码时,不输入任何字符直接按enter
键就可以直接进入了。说明初次安装mysql时,root账户没有密码。
在设置密码时,踩了很多坑,mysql5.7与mysql5.6的密码设置方式存在差异,以下是5.7版本的设置方式:
(1)跳过mysql密码验证
打开mysql配置文件my.cnf:
[root@localhost ~]# vim /etc/my.cnf
打开后,在[mysqld]下方插入以下内容:
skip-grant-tables
skip-networking
(2)启动mysql,并匿名登录
启动mysql服务:
[root@localhost ~]# service mysqld start
匿名登录mysql:
[root@localhost ~]# mysql
(3)在mysql中执行下述两条命令
//修改密码
mysql> update mysql.user set authentication_string=PASSWORD('你的密码') where user='root' and host='localhost';
//权限账号信息是在MYSQLD服务启动的时候就加载到内存中的
//所以在原权限表中的任何直接修改都不会直接生效。
//用下述命令把表中的信息更新到内存
mysql> flush privileges;
(4)取消跳过mysql密码认证:
打开mysql配置文件my.cnf:
[root@localhost ~]# vim /etc/my.cnf
打开后,将之前在[mysqld]下方插入的内容注释掉或删掉
#skip-grant-tables
#skip-networking
(5)重启mysql
[root@localhost ~]# service mysqld restart
(6)进入mysql,通过ALTER的方式再次修改密码
//将mysql的密码强度级别设置为 LOW(密码任意,但长度在 8 位或以上)
mysql> set global validate_password_policy=0;
//如果想要设置的密码少于8位,请执行下述命令(最少是4)
mysql> set global validate_password_length=4;
//通过ALTER的方式再次修改密码
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '你的密码'
至此,完成密码的设置。
四、远程连接
//进入mysql,执行以下语句
mysql> GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'%' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;
//上述命令的意思是允许myuser用户使用mypassword从任何主机连接到mysql服务器
//假如我们想让root用户使用密码123456从任何主机连接到mysql服务器,则可以将上述命令修改为:
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;
参考
1、Centos 7 使用Yum 安装 MySQL
2、mysql 5.7 设置root密码方法
3、centos7 mysql数据库安装和配置
4、解决 MySQL 5.7 中 Your password does not satisfy the current policy requirements. 问题
5、mysql 远程访问不行解决方法 Host is not allowed to connect to this MySQL server