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