说明:本次安装的MySQL版本为5.7,采用的是在线安装模式,在线安装比较慢,甚至有可能会安装失败。安装环境是自己电脑上装的虚拟机,虚拟机装好之后通过宿主机的Navicat进行连接。虚拟机已经配置好了IP,我这里配置的是:192.168.147.129
1.执行语句
yum -y install mysql57-community-release-el7-10.noarch.rpm
如果出现以下错误:
2.下载mysql-server rpm包
出现第一步问题的原因是因为没有mysql-server rpm包,所以需要先下载mysql-server rpm包,运行
wget -i -c http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm
3.MySQL服务器
yum -y install mysql-community-server
执行成功之后就完成了安装,接下来是运行mysql
4.启动MySQL
执行:systemctl start mysqld
或systemctl start mysqld.service
5.查看MySQL运行状态
systemctl status mysqld.service
走到这步说明MySQL已经正常启动了,接下来就是登录MySQL
6. 登录数据库
执行:mysql -uroot -p
提示需要登录密码,输入123456或者不输入均不能登录,百度发现原来是安装MySQL的时候会自动生成一个密码
7.查看默认密码
执行:grep "password" /var/log/mysqld.log
就可以看到自动生成的密码:mqAfdWHy&297
8.成功登录MySQL
首先执行:mysql -uroot -p
然后输入密码:mqAfdWHy&297就可以登录
9.通过Navicat连接虚拟机数据库
正确输入IP和密码后报错,猜测应该是没有关闭防火墙。
10.查看防火墙的状态
执行:systemctl status firewalld
果然防火墙是开启的,于是可以选择关闭防火墙或者开放3306端口,当然开放3306端口要比直接关闭防火墙安全,于是:
执行:
firewall-cmd --zone=public --add-port=3306/tcp --permanent
开放端口号的相关说明:
## zone -- 作用域
## add-port=80/tcp -- 添加端口,格式为:端口/通讯协议
## permanent -- 永久生效,没有此参数重启后失效
## 开启3306端口后,workbench或naivcat 就能连接到MySQL数据库了
开放了3306端口号之后需要重启防火墙,执行:
firewall-cmd --reload
但是还是报错,但是很明显的是错误类型已经变了,所以说明我们之前的修改已经生效,现在这个错应该是MySQL没有开启远程访问,于是需要开启MySQL的远程访问。
11.开启MySQL的远程访问
进入MySQL,执行:grant all privileges on *.* to 'root'@'%' identified by 'password' with grant option;
但是还是报错:
从这个错误中,我们可以看到我们必须要修改MySQL的初始密码,所以我们就需要先修改密码。
12.修改密码
执行:set PASSWORD = PASSWORD('Root@147258');
接着执行:flush privileges;
可以看到当我设置密码为:123456时提示我的密码安全性不够,所以重新设置了:Root@147258就通过了。修改密码之后就需要修改远程访问了。
13.再次开启MySQL的远程访问
执行:GRANT ALL ON *.* TO user@'%' IDENTIFIED BY 'Root@123456' WITH GRANT OPTION;
接着执行:flush privileges;
注意:这里设置的不是root用于的远程登录而是user,并且登录密码是:Root@123456
14.通过Navicat再次连接
通过user和Root@123456可以登录成功,到此MySQL的安装设置就基本完成了。