我的编程空间,编程开发者的网络收藏夹
学习永远不晚

构建双vip的高可用MySQL集群

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

构建双vip的高可用MySQL集群

一、 项目描述:

    本项目的目的是:
构建一个高可用的能实现读写分离的高效的MySQL集群
确保业务的稳定,能沟通方便的监控整个集群
同时能批量的去部署和管理整个集群。

二、项目环境:

8台服务器(2G,2核),centos7.8
mysql5.7.30 mysqlrouter8.0.21
keepalived2.0.10 zabbix ansible

二、项目步骤:

  1.安装好centos7.8的系统,部署好ansible,在所有的机器之间配置SSH免密通道
2.部署好zabbix监控系统
3.通过ansible去以二进制方式安装部署MySQL
主要是通过编写好的脚本一键安装二进制版本的MySQL
4.使用ansible安装mysqlrouter 和keepalived,在另外2台中间件服务器上
实现读写分离和高可用,在keepalived上配置2个实例,实现2个vip,互为master和backup.
更加好的提升高可用的性能。
5.在3台MySQL服务器上配置好主从复制,建立读写分离使用的用户
形成一个master+2个slave节点(半同步+GTID)的集群,提供数据库服务
部署一台延迟备份的服务器(延迟30分钟)
6.尝试部署mysql的failover插件(自己编写脚本或者使用MHA)
实现自动的故障切换,确保master宕机
作用:能自动提升另外一台slave为主,另外一台slave切换到新的mater上获得二进制日志。
7.验证测试读写分离和高可用以及主从的failover
8.使用压力测试软件(sysbench)测试整个MySQL集群的性能(cpu、IO、内存等)

三、项目概念图:

在这里插入图片描述

四、部署zabbix监控系统

在这里插入图片描述

4.1 准备:

部署一台Zabbix监控服务器,一台被监控主机,为进一步执行具体的监控任务做准备:

安装LNMP环境

源码安装Zabbix

安装监控端主机,修改基本配置

初始化Zabbix监控Web页面

修改PHP配置文件,满足Zabbix需求

安装被监控端主机,修改基本配置

使用1台RHEL7虚拟机,安装部署LNMP环境、Zabbix及相关的依赖包,配置数据库并对Zabbix监控平台进行初始化操作。使用2台被监控端,源码安装Zabbix Agent。完成Zabbix实验需要我们搭建一个实验环境,拓扑结构如表-1所示。

表-1 实验拓扑结构

在这里插入图片描述

4.2 步骤:

步骤一:部署监控服务器

1)安装LNMP环境

Zabbix监控管理控制台需要通过Web页面展示出来
并且还需要使用MySQL来存储数据
因此需要先为Zabbix准备基础LNMP环境。

在这里插入图片描述

2)修改Nginx配置文件

配置Nginx支持PHP动态网站,因为有大量PHP脚本需要执行
因此还需要开启Nginx的各种fastcgi缓存,加速PHP脚本的执行速度。

在这里插入图片描述

3)启动服务

启动Nginx、PHP-FPM、MariaDB服务,关闭SELinux与防火墙。

在这里插入图片描述

4)客户端测试LNMP环境

服务器创建PHP测试页面,浏览器访问页面测试网页连通性。

在这里插入图片描述

步骤二:部署监控服务器Zabbix Server 1)源码安装Zabbix Serve

多数源码包都是需要依赖包的,zabbix也一样,源码编译前需要先安装相关依赖包。

在这里插入图片描述

2)初始化Zabbix

创建数据库,上线Zabbix的Web页面

在这里插入图片描述

在这里插入图片描述

提示:如果是因为配置文件不对,导致服务无法启动时,不要重复执行zabbix_server,
一定要先使用killall zabbix_server关闭服务后,再重新启动一次。
修改Zabbix_agent配置文件,启动Zabbix_agent服务

在这里插入图片描述

提示:如果是因为配置文件不对,导致服务无法启动时,不要重复执行zabbix_agentd,

一定要先使用killall zabbix_agentd关闭服务后,再重新启动一次。
浏览器访问Zabbix_server服务器的Web页面

在这里插入图片描述

修改完PHP配置文件后,再次使用浏览器访问服务器
则会提示如图的提示信息。

在这里插入图片描述

在这里插入图片描述

注意:这里有一个PHP LDAP是warning状态是没有问题的!
在初始化数据库页面,填写数据库相关参数
,如图所示。

在这里插入图片描述

在登陆页面,使用用户(admin)和密码(zabbix)登陆
登陆后设置语言环境为中文,如图所示。

在这里插入图片描述

在这里插入图片描述

步骤三:部署被监控主机Zabbix Agent 1)源码安装Zabbix agent软件

在2.100和2.200做相同操作(以zabbixclient_web1为例)。

在这里插入图片描述

2)修改agent配置文件,启动Agent

在这里插入图片描述

3)拷贝启动脚本(非必须操作,可选做)

 有启动脚本可以方便管理服务,启动与关闭服务

启动脚本位于zabbix源码目录下

在这里插入图片描述

五、项目心得:

 1.一定要规划好整个集群的架构,配置要细心,脚本要提前准备好,边做边修改

 2.防火墙和selinux的问题需要多注意

 3.对MySQL的集群和高可用有了深入的理解

 4.对自动化批量部署和监控有了更加多的应用和理解

 5.keepalived的配置需要更加细心和IP地址的规划有了新的认识

 6.对双vip的使用,添加2条负载均衡记录实现dns轮询,达到向2个vip负载均衡器上分流

到此这篇关于构建双vip的高可用MySQL集群的文章就介绍到这了,更多相关高可用MySQL集群内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

构建双vip的高可用MySQL集群

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL高可用集群的VIP切换

一、目的 实现在mysql高可用集群的VIP切换,不涉及数据补偿 二、基础环境 python3.0+ 三、具体三大部分 1、启动条件检测 检测集群是否down机 方式 select 1 检测主库是否有VIP绑定 方式是 采用vip进行连接 检测从库是否
MySQL高可用集群的VIP切换
2020-04-24

搭建 MySQL 高可用高性能集群

什么是MySQL集群,什么是MySQL集群,如果你想知道什么是MySQL集群,我现在就带你研究。MySQL 是一款流行的轻量级数据库,很多应用都是使用它作为数据存储。作为小型应用的数据库,它完全可以胜任,但是如果是大型应用,高性能高可用的要求,单服务器部署的M
搭建 MySQL 高可用高性能集群
2015-11-09

mysql高可用集群怎么搭建

mysql 高可用集群是一种数据库架构,提供高可用性、容错性和可扩展性。搭建步骤包括:1. 准备基础设施;2. 安装 mysql 并配置集群模式;3. 配置复制,设置主从节点;4. 配置 galera 集群,启用多主机复制;5. 配置监控和
mysql高可用集群怎么搭建
2024-05-22

mysql高可用集群如何搭建

要搭建MySQL高可用集群,可以按照以下步骤进行操作:选择合适的集群架构:常用的MySQL集群架构有主从复制、主备切换和主主复制等。根据业务需求选择合适的架构。安装MySQL数据库:在每个节点上安装MySQL数据库,并确保数据库版本一致。配
2023-10-24

如何搭建 MySQL 高可用高性能集群

目录MySQL NDB Cluster 是什么搭建集群的前置工作开始部署集群部署管理服务器部署数据服务器部署 SQL 服务所有集群服务部署完毕,我们来测试一下集群是否真的部署成功数据库集群部署成功了,总结一下集群的注意事项MySQL NDB
2022-06-01

利用Docker Swarm实现Nginx的高可用集群(Docker Swarm如何助力构建Nginx高可用集群?)

通过DockerSwarm编排,可以构建Nginx高可用集群,提升可用性、性能和可扩展性。集群中的多个Nginx实例提供冗余,自动故障转移确保服务在故障时保持可用。Swarm提供负载均衡,将请求分布到集群实例,提升性能。最佳实践包括使用适当的负载均衡算法、监控集群状态、执行滚动更新和测试故障转移。
利用Docker Swarm实现Nginx的高可用集群(Docker Swarm如何助力构建Nginx高可用集群?)
2024-04-02

MongoDB高可用集群搭建

MongoDB高可用集群搭建   MongoDB副本集搭建 准备三台服务器:   10.175.120.131(主节点)   10.175.121.134(副本节点)   10.175.121.136(副本节点) 1.分别
MongoDB高可用集群搭建
2015-11-17

高可用 | repmgr 构建 PostgreSQL 高可用集群部署文档【建议收藏】

作者:颜博 青云科技数据库研发工程师目前从事 PostgreSQL 产品开发工作,热衷于 PostgreSQL 数据库的学习和研究上一期我们介绍了 PG 集群复制管理工具 repmgr,能够轻松的搭建出 PostgreSQL 的高可用集群,在主节点宕机后,挑选
高可用 | repmgr 构建 PostgreSQL 高可用集群部署文档【建议收藏】
2019-01-10

编程热搜

目录