一、环境
阿里云CentOS、Navicat 15、MySQL 8
二、步骤
1.安装MySQL(这一大步主要参考https://blog.csdn.net/qq_38591756/article/details/82958333,感谢该博主)
(1).下载mysql源安装包
在MySQL官网中下载YUM源rpm安装包:http://dev.mysql.com/downloads/repo/yum/
复制下载链接:https://dev.mysql.com/get/mysql80-community-release-el7-1.noarch.rpm
本次下载目录为:/home/目录,因此进入:cd /home
执行下载命令:
wget https://dev.mysql.com/get/mysql80-community-release-el7-1.noarch.rpm
(2).安装mysql源
下载完成后使用下面命令安装源:
yum localinstall mysql80-community-release-el7-1.noarch.rpm
(3).检查源是否安装成功
输入命令:
yum repolist enabled | grep "mysql.*-community.*"
如果是下图,则表示源安装成功
(4).安装MySQL
yum install mysql-community-server
(5).如果报错“Error:Unable to find a match: mysql-community-server”
则先执行下列代码,先禁用本地的 MySQL 模块
yum module disable mysql
再执行安装即可
yum install mysql-community-server
2.初始化MySQL
(1).系统中启动MySQL
systemctl start mysqld
或者
service mysqld start
(2).查看MySQL的启动状态
systemctl status mysqld
或者
service mysqld status
如果是下图所示,则表示已经成功启动
(3).设置MySQL Server开机启动
systemctl enable mysqld
systemctl daemon-reload
(这两行指令都要执行)
(4).修改MySQL登录密码
mysql安装完成之后,在/var/log/mysqld.log文件中给root生成了一个默认密码。通过下面的方式找到root默认密码,然后登录mysql进行修改
grep 'temporary password' /var/log/mysqld.log
下图便是默认的初始化的密码
记住上面的密码,下面修改密码
登录MySQL控制台
mysql -uroot -p
输入自己的密码,密码默认要求大小写字母、数字和特殊符号,并且长度不能少于8位。(如果想修改密码要求,则可以参考https://blog.csdn.net/qq_38591756/article/details/82958333中间部分)
ALTER USER 'root'@'localhost' IDENTIFIED BY 'TestBicon@123';
(5).添加远程登录账户
默认只允许root帐户在本地登录,如果要在其它机器上连接mysql,必须修改root允许远程连接,或者添加一个允许远程连接的帐户。
修改root用户远程访问权限:
use mysql;
授权 root 用户的所有权限并设置远程访问:
GRANT ALL ON *.* TO 'root'@'%';
如果报错“ERROR 1410 (42000): You are not allowed to create a user with GRANT”,则使用下面的指令代替上面的指令:
update user set host='%' where user ='root';
然后使用下面命令使修改生效(如有需要再执行之前授权报错的命令即可成功,最后同样使用“flush privileges;”命令刷新。)
flush privileges;
3.配置远程Navicat连接
(1).查看默认的端口,在MySQL控制台输入
show global variables like 'port';
返回下图内容,3306即为MySQL的默认端口
(2).在系统中让端口3306允许通行
我这里系统是阿里云Centos,所以需要在阿里云网页端进行配置端口,具体如下(其他系统请百度如何防火墙放行端口):
(3).在MySQL中添加连接账户
在MySQL控制台中输入:
create user '用户名'@'访问主机IP' identified by '密码';
”访问主机IP“就是Navicat所在的主机的对外IP,如果是局域网的话注意不要写错了,局域网中的网络IP是内网IP,并不是对外IP。对外IP的查询方法请百度,我用比特彗星可以查看对外IP。
比如我的:
create user 'boyLen'@'155.133.1.22' identified by '043000.Aa';
添加完毕后系统便会记录,使用如下指令查看是否添加成功
select host,user from mysql.user;
下图是返回内容,可见添加成功
(4).配置Navicat
推荐Navicat版本为15,因为旧版经过我的使用发现对MySQL8.0兼容性一般,查询指令会报错。
在Navicat中直接新建数据库,然后输入信息即可:
此时已经配置完毕。