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

2025-07-17 19:50

本文主要是介绍虚拟机Centos7安装MySQL数据库实践,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net...

前几日在虚拟机上面安装自己的MySQL数据库,中间遇到了很多问题,不管是不能安装还是后面用navicat去连接出错等等问题。所有写下来让各位少走一点弯路。因为我虚拟机已经安装所以在这里借用的都是在网上找的图,如有侵,请联系我删图。

安装MySQL数据库

下载wChina编程get命令

打开虚拟机Centos终端输入下方命令

注意:打开虚拟机时记得将自己的账号切换到最大权限的账号我的时root所以就切换到了root账户,至于怎么切换的可以在控制台输入su命令回车然后输入你的root账号密码即可,如下图所示账号切换成功

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

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

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

安装MySQL服务

1、进入cd /etc/yum.repos.d/目录

cd /etc/yum.repos.d/

               &nwww.chinasem.cnbsp;                               虚拟机Centos7安装MySQL数据库实践

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的密码和我们去连接M编程China编程ySQL的ip等操作

获取MySQL临时密码

1、使用下方命令获取mysql临时密码,一定要记住这个密码后续要用到改密码

grep 'temporary password' /var/log/mysqld.log

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

 我的临时密码是: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

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

  • 2.2、查看有那些数据库
show databases;

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

  • 2.3、切换到mysql数据库
use mysql;

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

  • 2.4、查看user表并且查询host和user字段
select host,user from user;

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

 发现root用户只允许localhost主机登录登录,所以需要修改权限,将localhost修改成%,那么都可访问

  • 2.5、修改为允许任何地址访问
update user set Host='%' where User='root';
  • 2.6、刷新一下权限,再查询一下,此时的localhost就变成了%
flush privileges;
  • 2.7、退出mysql打开navicat连接数据库

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

在这里还有一个小问题需要阐述一下;

问题1: 这里关闭防火墙我遇到了一个坑,刚开始我确实是关闭了防火墙,但是我的navicat就是不能连接上这个数据库。然后找问题所在,看是不是权限不够、是不是允许所有人访问、是不是防火墙没关闭。

方案:

                修改远程访问权限和登录密码后发现还是不能进行远程连接的时候就要查看防火墙状态和端口是否开放了。
                # 1、查看防火墙状态
                systemctl status firewalld.service
                # 2.php查看开放端口
                firewall-cmd --list-all
                # 3.开放端口
                firewall-cmd --zone=public --add-port=3306/tcp --permanent
                #4然后在重新添加EHamNsV防火墙

                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
service network restart 
  • 5、IP ADDR查看
ip addr

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

大功告成,打完收工。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持China编程(www.chinasem.cn)。

这篇关于虚拟机Centos7安装MySQL数据库实践的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1155412

相关文章

MySQL中比较运算符的具体使用

《MySQL中比较运算符的具体使用》本文介绍了SQL中常用的符号类型和非符号类型运算符,符号类型运算符包括等于(=)、安全等于(=)、不等于(/!=)、大小比较(,=,,=)等,感兴趣的可以了解一下... 目录符号类型运算符1. 等于运算符=2. 安全等于运算符<=>3. 不等于运算符<>或!=4. 小于运

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

MySQL逻辑删除与唯一索引冲突解决方案

《MySQL逻辑删除与唯一索引冲突解决方案》本文探讨MySQL逻辑删除与唯一索引冲突问题,提出四种解决方案:复合索引+时间戳、修改唯一字段、历史表、业务层校验,推荐方案1和方案3,适用于不同场景,感兴... 目录问题背景问题复现解决方案解决方案1.复合唯一索引 + 时间戳删除字段解决方案2:删除后修改唯一字

SpringBoot整合(ES)ElasticSearch7.8实践

《SpringBoot整合(ES)ElasticSearch7.8实践》本文详细介绍了SpringBoot整合ElasticSearch7.8的教程,涵盖依赖添加、客户端初始化、索引创建与获取、批量插... 目录SpringBoot整合ElasticSearch7.8添加依赖初始化创建SpringBoot项

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

MySQL 主从复制部署及验证(示例详解)

《MySQL主从复制部署及验证(示例详解)》本文介绍MySQL主从复制部署步骤及学校管理数据库创建脚本,包含表结构设计、示例数据插入和查询语句,用于验证主从同步功能,感兴趣的朋友一起看看吧... 目录mysql 主从复制部署指南部署步骤1.环境准备2. 主服务器配置3. 创建复制用户4. 获取主服务器状态5

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

MySQL 迁移至 Doris 最佳实践方案(最新整理)

《MySQL迁移至Doris最佳实践方案(最新整理)》本文将深入剖析三种经过实践验证的MySQL迁移至Doris的最佳方案,涵盖全量迁移、增量同步、混合迁移以及基于CDC(ChangeData... 目录一、China编程JDBC Catalog 联邦查询方案(适合跨库实时查询)1. 方案概述2. 环境要求3.