阿里云 centos7 安装MySQL8.0.13

  1.下载MySQL安装包(这里是有技巧的,说不定我这时写这个的时候版本还是你看到时的旧版本了,如果已经不是8.0了,可以根据这样来 下新版本)
  
   先进入官网
  再将这两者一结合,就是最新版本的了
  所以
[root@h1 ~]# rpm -ivh http://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm
   
   

    2.安装mysql

1 [root@localhost ~]# yum install -y mysql-server
2 3 [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)
1.关闭防火墙:sudo systemctl stop firewalld.service
2. 关闭开机启动:sudo systemctl disable firewalld.service

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

  

  然后再连接,ok

  

补充:数据库的相关操作

#启动mysql
systemctl start mysqld.service
 
#结束
systemctl stop mysqld.service
 
#重启
systemctl restart mysqld.service
 
#开机自启
systemctl enable mysqld.service

猜你喜欢

转载自www.cnblogs.com/xmdykf/p/11369143.html
今日推荐