虚拟机Centos7安装MySQL数据库实践

 更新时间:2025年07月17日 14:29:50   作者:老黄不想胖  
用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止NetworkManager解决网络连接异常问题

前几日在虚拟机上面安装自己的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

 

大功告成,打完收工。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MYSQL 解锁与锁表介绍

    MYSQL 解锁与锁表介绍

    相对其他数据库而言,MySQL的锁机制比较简单,其最显著的特点是不同的存储引擎支持不同的锁机制
    2017-04-04
  • linux下mysql数据库单向同步配置方法分享

    linux下mysql数据库单向同步配置方法分享

    mysql数据库单向同步又叫做主从复制,是通过二进制日志文件完成的,注意:mysql 数据库的版本,两个数据库版本要相同
    2012-06-06
  • 一文详解MySQL是如何解决幻读的

    一文详解MySQL是如何解决幻读的

    事务A按照一定条件进行数据读取,期间事务B插入了相同搜索条件的新数据,事务A再次按照原先条件进行读取操作修改时,发现了事务B新插入的数据称之为幻读,这篇文章主要给大家介绍了关于MySQL是如何解决幻读的相关资料,需要的朋友可以参考下
    2023-04-04
  • MYSQL连接不上本地服务器localhost的问题及解决

    MYSQL连接不上本地服务器localhost的问题及解决

    通过打开DOS窗口输入mysql连接命令时报错,发现本地MySQL服务未启动,按照步骤在services.msc中找到并启动MySQL服务,选择“自动”启动类型,依次点击“启动”、“应用”、“确定”,问题解决
    2026-03-03
  • 关于mysql时间区间问题浅析

    关于mysql时间区间问题浅析

    在很多地方都使用到了mysql的日期查询,下面这篇文章主要给大家介绍了关于mysql时间区间问题的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-04-04
  • 搞定mysql行转列的7种方法以及列转行

    搞定mysql行转列的7种方法以及列转行

    在MySQL数据库中,有时候我们需要将一列数据转化为行数据,以便更好地进行数据分析和处理,下面这篇文章主要给大家介绍了关于搞定mysql行转列的7种方法以及列转行的相关资料,需要的朋友可以参考下
    2024-03-03
  • MySQL PHP 语法详解及实例代码

    MySQL PHP 语法详解及实例代码

    这篇文章主要介绍了MySQL PHP 语法详解及实例代码的相关资料,需要的朋友可以参考下
    2017-01-01
  • MySQL互为主从(双向同步)部署超详细教程

    MySQL互为主从(双向同步)部署超详细教程

    MySQL互为主从是一种特殊的复制架构,其中两个MySQL服务器互为主从,彼此之间互相同步数据,这篇文章主要介绍了MySQL互为主从(双向同步)部署的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-11-11
  • mysql数据库插入速度和读取速度的调整记录

    mysql数据库插入速度和读取速度的调整记录

    由于项目变态需求;需要在一个比较短时间段急剧增加数据库记录(两三天内,由于0增加至4亿)。在整个过程调优过程非常艰辛
    2012-07-07
  • MySQL会发生死锁的几种情况及处理方法

    MySQL会发生死锁的几种情况及处理方法

    数据库的死锁是指不同的事务在获取资源时相互等待,导致无法继续执行的一种情况,当发生死锁时,数据库系统会自动中断其中一个事务,以解除死锁,本文给大家介绍了MySQL什么情况下会死锁,发生了死锁怎么处理呢,需要的朋友可以参考下
    2023-09-09

最新评论