1.下载MySQL安装包 (这里是有技巧的,说不定我这时写这个的时候版本还是你看到时的旧版本了,如果已经不是8.0了,可以根据这样来 下新版本)  

  先进入官网

再将这两者一结合,就是最新版本的了  

所以

[root@h1 ~]# rpm -ivh http://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm

2.安装mysql

[root@localhost ~]# yum install -y mysql-server
或
[root@localhost ~]# yum install mysql-community-server

如果显示以下内容说明安装成功  

Complete!

3.设置mysql

设置开机启动Mysql

[root@localhost ~]# systemctl enable mysqld.service 

检查是否已经安装了开机自启动

[root@localhost ~]# systemctl list-unit-files | grep mysqld

如果显示以下内容说明已经完成自动启动安装

mysqld.service enabled

设置开启服务

[root@localhost ~]# systemctl start mysqld.service

这里需要稍微注释下:mysql8.0版本和以前版本的修改密码方式不一样               

4.登录修改mysql密码

查看mysql默认密码

[root@localhost ~]# grep 'temporary password' /var/log/mysqld.log

第一次登录mysql,输入账号和默认密码

[root@localhost ~]# mysql -uroot -p

修改当前密码

#MySQL8.0修改密码需要有大小写字母、数字、特殊字符组合
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'MyNewPass4!';

官方给的密码修改说明

5. 命令立即执行生效  

mysql>flush privileges;

补充:外网/客户端访问问题,比如navicat连接

解决方案,登录MySQL,修改user表登录用户的host    

#远程设置
mysql> use mysql;
mysql> update user set host='%' where user='root';
#授权用户名的权限,赋予任何主机访问数据的权限
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;
mysql> FLUSH PRIVILEGES;

然后都ok后,又出现个错误2059,原因是安全端口未开放

mysql登录用户密码设置好后,需要开发安全组端口,并且好像上面的不是mysql8.0版本,因为8.0版本的加密方式改变了,mysql8以后的加密规则为caching_sha2_password,所以我们需要将mysql用户登录的加密规则修改为mysql_native_password,且需要关闭防火墙的说,然后安全端口设置一个(注意,由于之前改了user,这里@"%")

mysql> ALTER USER 'root'@'%' IDENTIFIED BY 'Root!!2018' PASSWORD EXPIRE NEVER;
Query OK, 0 rows affected (0.03 sec)

mysql> ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'Root!!2018';
Query OK, 0 rows affected (0.01 sec)
mysql> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.00 sec)
sudo systemctl stop firewalld.service
sudo systemctl disable firewalld.service

并且,需要在 阿里云控制台防火墙处,添加新的规则 开放3306端口

然后再连接,ok

补充:数据库的相关操作

#启动mysql
systemctl start mysqld.service

#结束
systemctl stop mysqld.service

#重启
systemctl restart mysqld.service

#开机自启
systemctl enable mysqld.service