前几日在虚拟机上面安装自己的mysql数据库,中间遇到了很多问题,不管是不能安装还是后面用navicat去连接出错等等问题。所有写下来让各位少走一点弯路。因为我虚拟机已经安装所以在这里借用的都是在网上找的图,如有侵,请联系我删图。
安装mysql数据库
下载wget命令
打开虚拟机centos终端输入下方命令
注意:打开虚拟机时记得将自己的账号切换到最大权限的账号我的时root所以就切换到了root账户,至于怎么切换的可以在控制台输入su命令回车然后输入你的root账号密码即可,如下图所示账号切换成功
yum -y install wget
下载mysql安装包
wget https://dev.mysql.com/get/mysql57-community-release-el7-8.noarch.rpm
安装mysql
可根据不同版本进行安装下载
rpm -ivh mysql57-community-release-el7-8.noarch.rpm
安装mysql服务
1、进入cd /etc/yum.repos.d/目录
cd /etc/yum.repos.d/
2、安装mysql服务(安装过程很慢,并且可能会出现问题)
yum -y install mysql-server
注意:在安装过程中可能会遇到以下类似问题:
1、源 “mysql 5.7 community server” 的 gpg 密钥已安装,但是不适用于此软件包。请检查;
- 从 file:///etc/pki/rpm-gpg/rpm-gpg-key-mysql 检索密钥
- 源 "mysql 5.7 community server" 的 gpg 密钥已安装,但是不适用于此软件包。请检查源的公钥 url 是否配置正确。
- 失败的软件包是:mysql-community-server-5.7.37-1.el7.x86_64
- gpg 密钥配置为:file:///etc/pki/rpm-gpg/rpm-gpg-key-mysql
解决方案:可在安装出现问题后执行下面代码,这段代码执行完成后再来执行安装服务
rpm --import https://repo.mysql.com/rpm-gpg-key-mysql-2022
安装完成后启动mysql服务
systemctl start mysqld
虽然到这一步已经可以将mysql安装好并且启动了,但是这个时候我们还不知道mysql的密码和连接ip这些。所以接下来需要我们去修改mysql的密码和我们去连接mysql的ip等操作
获取mysql临时密码
1、使用下方命令获取mysql临时密码,一定要记住这个密码后续要用到改密码
grep 'temporary password' /var/log/mysqld.log
我的临时密码是:jsxgrs5kz,ju
2、先使用临时密码进行登录mysql,输入以下命令后输入自己的临时密码
mysql -uroot -p
3、把密码校验强度改成低(不改也可以,我这里是为了方便我本地进行测试。但一定要记得自己的数据库密码)
set global validate_password_policy=low;
4、修改密码长度
set global validate_password_length=4;
5、修改mysql密码
alter user 'root'@'localhost' identified by 'root';
完成以上的操作之后linux系统的mysql就算是安装好了,但是如果我们远程访问数据库怎么去操作呢?接下来就是需要允许远程访问
允许远程访问数据库
1、关闭centos防火墙
systemctl disable firewalld
2、设置允许任何人都可以连接mysql
- 2.1、登录mysql
mysql -uroot -proot
- 2.2、查看有那些数据库
show databases;
- 2.3、切换到mysql数据库
use mysql;
- 2.4、查看user表并且查询host和user字段
select host,user from user;
发现
root
用户只允许localhost
主机登录登录,所以需要修改权限,将localhost修改成%,那么都可访问
- 2.5、修改为允许任何地址访问
update user set host='%' where user='root';
- 2.6、刷新一下权限,再查询一下,此时的localhost就变成了%
flush privileges;
- 2.7、退出mysql打开navicat连接数据库
在这里还有一个小问题需要阐述一下;
问题1: 这里关闭防火墙我遇到了一个坑,刚开始我确实是关闭了防火墙,但是我的navicat就是不能连接上这个数据库。然后找问题所在,看是不是权限不够、是不是允许所有人访问、是不是防火墙没关闭。
方案:
修改远程访问权限和登录密码后发现还是不能进行远程连接的时候就要查看防火墙状态和端口是否开放了。 # 1、查看防火墙状态 systemctl status firewalld.service # 2.查看开放端口 firewall-cmd --list-all # 3.开放端口 firewall-cmd --zone=public --add-port=3306/tcp --permanent #4然后在重新添加防火墙 firewall-cmd --zone=public --add-port=3305/tcp
这个方案确实是可以让我用navicat去连接到数据库,但是我如果重启linux之后就不可以了,并且我打开终端之后输入ip a之后竟然报错:ens33网卡失效,提示:ens33: <broadcast,multicast> mtu 1500 qdisc noop state down group default qle 这下好了网卡也失效了,数据库也不能用了
关闭防火墙最终解决方案:
- 1、关闭防火墙
systemctl disable firewalld
- 2、停止networkmanager
systemctl stop networkmanager
- 3、移除networkmanager链接
systemctl disable networkmanager
- 4、重启网络服务
service network restart
- 5、ip addr查看
ip addr
大功告成,打完收工。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。
发表评论