【MySQL集群一】CentOS 7上搭建MySQL集群:一主一从、多主多从

news2025/1/17 0:58:26

CentOS 7上搭建MySQL集群

  • 介绍
  • 一主一从
    • 步骤1:准备工作
    • 步骤2:安装MySQL
    • 步骤3:配置主服务器
    • 步骤4:创建复制用户
    • 步骤5:备份主服务器数据,如果没有数据则省略这一步
    • 步骤6:配置从服务器
    • 步骤7:配置主从复制
    • 步骤8:测试主从复制
  • 一主多从
  • 多主多从

在这里插入图片描述

介绍

MySQL集群允许您创建高可用性的数据库环境,提供故障容忍性和负载均衡。在本博客中,我们将演示如何在两台CentOS 7服务器上搭建MySQL集群,包括一主一从和多主多从的配置。

一主一从

步骤1:准备工作

在开始之前,确保您已经完成以下准备工作:

  • 两台CentOS 7服务器,可以是物理机或虚拟机。
  • 确保服务器之间可以互相访问,互相能ping通。
  • 演示环境是两台试用云服务器。
    腾讯云服务器

步骤2:安装MySQL

在两台服务器上安装MySQL,请参考:CentOS7服务器Yum安装MySQL5.7

步骤3:配置主服务器

在主服务器上编辑MySQL配置文件:

sudo vim /etc/my.cnf

添加或修改以下配置项:

[mysqld]
# 每个MySQL服务器都需要一个唯一的标识符(server-id),用于区分主从服务器,以及避免复制冲突。
server-id=22
# 用于开启MySQL的日志功能,以便记录增删改操作。二进制日志文件将记录所有这些更改,并用于主从复制。
log-bin = /var/log/mysql/mysql-bin.log
# 设置logbin格式
binlog_format=STATEMENT
# 用于指定需要同步的数据库。如果你希望同步特定的数据库,可以设置多个binlog-do-db选项,每个选项指定一个数据库;可设置为通配符模式:ddz_*(表示同步以ddz_开头的数据库)
binlog-do-db=ddz_*
# 屏蔽不需要同步的系统库
binlog-ignore-db=mysql
binlog-ignore-db=information_schema
# 从服务器是否记录自己的日志。如果启用(1),从服务器会记录在执行复制时的所有更改。
log-slave-updates=1 
# 用于指定错误日志的文件名和位置。
# log-error=
# 指定MySQL服务器进程ID的文件名和位置。
# pid-file=
# 控制MySQL在处理已经建立的连接时,允许待处理的的最大连接数。
# back_log=
# 限制MySQL的最大连接数。
# max_connections=
# 限制每个用户允许的最大连接数。
# max_user_connections=
# 限制通信缓冲区中的数据量大小,默认大小为1MB。
# max_allowed_packet=

可更具自己需要灵活配置。

binlog_format 主要是用来调整binlog的记录格式。
MySQL的binlog(二进制日志)用于记录数据库中的所有更改,这些日志可以用于主从复制和数据恢复等。binlog_format 选项可以控制binlog的记录格式,它有三个可选值:STATEMENT、ROW和MIXED。

STATEMENT:每一条修改数据的SQL语句都会记录到binlog中,但不会记录每一条sql语句和每一行的数据变化。在slave端复制时,sql进程会解析成和原来master端执行过的相同的sql再次执行。优点是减少binlog日志量,节约磁盘IO,提高性能。缺点是在某些情况下会导致主从复制不一致,比如sleep()函数、last_insert_id()以及user-defined functions(udf)等可能会出现问题。

ROW:在ROW格式下,binlog中会记录每一行数据被修改后的情况,然后在slave端对相同的数据进行修改。优点是可以清楚地记录每一行数据修改的细节。缺点是数据量太大,可能会增加磁盘IO和内存消耗。

MIXED:MIXED模式是以上两种模式的混合使用。一般的复制使用STATEMENT模式保存binlog,对于STATEMENT模式无法复制的操作使用ROW模式保存binlog。MySQL会根据执行的SQL语句选择日志保存方式。

保存并关闭文件。然后重启MySQL服务:

sudo systemctl restart mysqld

步骤4:创建复制用户

登录到MySQL服务器,创建用于复制的用户:

# 登录
mysql -u root -p

# 在MySQL中执行以下命令
# 创建用户
CREATE USER 'replication'@'%' IDENTIFIED BY 'your_password';
# 指定IP
# CREATE USER 'replication'@'192.168.1.13' IDENTIFIED BY 'your_password';
# 配置授权
GRANT REPLICATION SLAVE ON *.* TO 'replication'@'%';
# 指定IP
# GRANT REPLICATION SLAVE ON *.* TO 'replication'@'192.168.1.13';
# 刷新缓存
FLUSH PRIVILEGES;

查看是创建成功,只需执行一下SQL:

SELECT USER,HOST FROM mysql.user;

在这里插入图片描述

步骤5:备份主服务器数据,如果没有数据则省略这一步

在主服务器上创建数据备份:

mysqldump -u root -p --database mydb > mydb.sql

步骤6:配置从服务器

在从服务器上编辑MySQL配置文件:

sudo vim /etc/my.cnf

添加或修改以下配置项:

[mysqld]
# 每个MySQL服务器都需要一个唯一的标识符(server-id),用于区分主从服务器,以及避免复制冲突。
server-id=33
# 用于指定需要同步的数据库。如果你希望同步特定的数据库,可以设置多个binlog-do-db选项,每个选项指定一个数据库;可设置为通配符模式:ddz_*(表示同步以ddz_开头的数据库)
binlog-do-db=ddz_*
# 屏蔽不需要同步的系统库
binlog-ignore-db=mysql
binlog-ignore-db=information_schema
# 主从复制架构中非常重要的一部分,它用于确保从服务器能够及时地获取和应用主服务器的更改,以保持与主服务器的数据一致性。
relay-log=mysql-relay

保存并关闭文件。然后导入主服务器的数据备份(没有数据则省略这一步)

mysql -u root -p < mydb.sql

步骤7:配置主从复制

回到主服务器,获取主服务器的状态:

mysql -u root -p

# 在MySQL中执行以下命令
SHOW MASTER STATUS;

在这里插入图片描述

记录下返回的文件名和位置。

回到从服务器,配置从服务器连接到主服务器:

# 登录
mysql -u root -p

# 在MySQL中执行以下命令,将 'file_name' 和 'position' 替换为上一步中记录的值
CHANGE MASTER TO MASTER_HOST='主服务器的IP地址', MASTER_USER='replication', MASTER_PASSWORD='your_password', MASTER_LOG_FILE='file_name', MASTER_LOG_POS=position;

# 开启同步功能
START SLAVE;

步骤8:测试主从复制

在主服务器上创建一个新的数据库并添加一些数据,然后在从服务器上验证是否同步。

# 创建数据库
CREATE DATABASE ddz_test;
# 创建表
CREATE TABLE ddz_test.test_user (
	`id` INT NOT NULL AUTO_INCREMENT,
	`name` VARCHAR ( 50 ) DEFAULT NULL,
PRIMARY KEY ( `id` )) ENGINE = INNODB DEFAULT CHARSET = utf8;
# 新增一条数据
INSERT INTO ddz_test.test_user(`name`)VALUES('测试你个老六');

进入主从MySQL上验证是否都有数据。

一主多从

要配置多主多从,重复步骤6到步骤8在另一台服务器上。

多主多从

要配置多主多从,重复步骤3到步骤8在另一对服务器上。

总结:
通过完成上述步骤,您将在两台CentOS 7服务器上成功搭建了MySQL集群,包括一主一从和多主多从的配置。这将提高数据库的可用性和性能,使您能够更好地处理数据库工作负载和故障容忍性。如果需要更多节点,只需重复配置多主多从的步骤。希望这个博客对您有所帮助!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1016194.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Javase | 集合-上

目录&#xff1a; 一、集合&#xff1a;1.集合的概述2.集合的分类 二、“单个方式”存储元素&#xff1a;1.Collection1.1 Collection的概述1.2 Collection接口中常用的方法Iterator<T> iterator( ) 1.3 Collection下的子接口 2.Iterable&#xff1a;2.1 Iterable的概述2…

国内AI语言大模型【星火】各类模块及部分功能使用方法介绍

一、前言 现在AI语言大模型是百花齐放,挺好!有竞争,有发展,才能推出更好的产品。现在,科大讯飞就推出了大语言模型——星火!能够学习和理解人类的语言,进行多轮对话,回答问题,高效便捷地帮助人们获取信息、知识和灵感。星火在对话栏设置了三个插件:文档回答、PPT生成…

Java中transient关键字的详细总结

Java中transient关键字的详细总结 概要介绍 本文要介绍的是Java中的transient关键字&#xff0c;transient是短暂的意思。对于transient 修饰的成员变量&#xff0c;在类的实例对象的序列化处理过程中会被忽略。 因此&#xff0c;transient变量不会贯穿对象的序列化和反序列化…

C2基础设施威胁情报对抗策略

威胁情报是指在信息安全和安全防御领域&#xff0c;收集、分析和解释与潜在威胁相关的信息&#xff0c;以便预先发现并评估可能对组织资产造成损害的潜在威胁&#xff0c;是一种多维度、综合性的方法&#xff0c;其通过信息的收集、分析和研判&#xff0c;帮助组织了解可能对其…

Linux学习第11天:字符设备驱动开发:一字一符总见情

本文是驱动开发的第一篇笔记。主要内容是字符设备驱动开发最基础的内容&#xff0c;主要包括字符设备的概念、开发步骤以及一个十分重要的概念&#xff1a;设备号。其思维导图能简单的显示本文的基本框架&#xff0c;如下&#xff1a; 一、字符设备 字符设备就是一个一个字节&a…

MySQL注入绕安全狗脚本 -- MySQLByPassForSafeDog,以及端口爆破工具 -- PortBrute配置使用

工具介绍 此Tamper仅仅适用于MySQL数据库&#xff0c;在SQLMap使用过程中添加参数–tamperMySQLByPassForSafeDog。 安装与使用 1、安装网站安全狗Apache最新版 2、启用安全狗&#xff0c;不加MySQLByPassForSafeDog绕狗Tamper: python sqlmap.py -u "http://192.168.…

又一个Python调试利器

迷途小书童 读完需要 5分钟 速读仅需 2 分钟 1 简介 在编程过程中&#xff0c;几乎难以避免的会出现错误。事实上&#xff0c;程序员为了消除错误&#xff0c;要花费大量的时间在代码调试上。在调试过程中&#xff0c;使用 print() 语句来理解程序流程和发现意外行为无疑是最常…

iOS系统暗黑模式

系统暗黑模式&#xff1a; 暗黑模式颜色适配&#xff1a; 方式1&#xff1a; Assets配置&#xff1a;在Assets中配置好颜色后&#xff0c;可以通过colorNamed: 放大获取到动态颜色。 方式2&#xff1a;代码配置&#xff0c;通过代码colorWithDynamicProvider: 可以看出来生成…

C语言指针进阶(2)

大家好&#xff0c;我们今天继续来分享指针进阶的内容。 目录 5.函数指针 6.函数指针数组 7. 指向函数指针数组的指针 8. 回调函数 5.函数指针 顾名思义函数指针里面存的就是函数的地址了。 那我们通过一段代码来理解函数指针&#xff1a; #include<stdio.h> int Add…

向日葵无法连接服务器(无法登录)

最近在使用向日葵过程中&#xff0c;突然就不能登录向日葵了&#xff0c;网上查了各种解决方案&#xff0c;比如说防火墙是不是把向日葵给拦截了&#xff1f;更换不同的版本等等&#xff0c;都无法解决&#xff0c;最后突然想到是不是电脑对向日葵原安装目录限制了&#xff1f;…

创建表

MySQL从小白到总裁完整教程目录:https://blog.csdn.net/weixin_67859959/article/details/129334507?spm1001.2014.3001.5502 创建表 语法格式: create table 表名(列名1 数据类型,列名2 数据类型,... ,列名n, 数据类型 ); 练习:在czwbkl库中,创建一格test01表 跟大家说…

windows下C++的反射功能

概述 c/c如果在日志中查看某个结构体/类的每个变量名&#xff0c;变量值信息&#xff0c;只能通过printf逐个格式化&#xff0c;非常繁琐&#xff0c;如何做到类似protobuff转json的序列化功能呢&#xff1f;该dll库先通过分析pdb文件获取结构体/类的变量名称、变量地址&#…

WebGL 从0到1绘制一个立方体

目录 前言 组成立方体的面、三角形、顶点坐标和顶点颜色 通过顶点索引绘制物体 gl.drawElements(mode, count, type, offset) 函数规范 示例程序 彩色立方体&#xff08;HelloCube.js&#xff09; 代码详解 向缓冲区中写入顶点的坐标、颜色与索引 gl.ELEMENT_ARRAY_B…

RFID产线自动化升级改造管理方案

应用背景 在现代制造业中&#xff0c;产线管理是实现高效生产和优质产品的关键环节&#xff0c;产线管理涉及到生产过程的监控、物料管理、工艺控制、质量追溯等多个方面&#xff0c;有效的产线管理可以提高生产效率、降低成本、改善产品质量&#xff0c;并满足市场需求的变化…

elasticsearch1

个人名片&#xff1a; 博主&#xff1a;酒徒ᝰ. 个人简介&#xff1a;沉醉在酒中&#xff0c;借着一股酒劲&#xff0c;去拼搏一个未来。 本篇励志&#xff1a;三人行&#xff0c;必有我师焉。 本项目基于B站黑马程序员Java《SpringCloud微服务技术栈》&#xff0c;SpringCloud…

iText实战--在现有PDF上工作

6.1 使用PdfReader读取PDF 检索文档和页面信息 D:/data/iText/inAction/chapter03/image_direct.pdf Number of pages: 1 Size of page 1: [0.0,0.0,283.0,416.0] Rotation of page 1: 0 Page size with rotation of page 1: Rectangle: 283.0x416.0 (rot: 0 degrees) Is reb…

重新认识架构—不只是软件设计

前言 什么是架构&#xff1f; 通常情况下&#xff0c;人们对架构的认知仅限于在软件工程中的定义&#xff1a;架构主要指软件系统的结构设计&#xff0c;比如常见的SOLID准则、DDD架构。一个良好的软件架构可以帮助团队更有效地进行软件开发&#xff0c;降低维护成本&#xff0…

C# 查找迷宫路径

1.导入图像&#xff0c;并且将图像转灰度 using var img new Image<Bgr, byte>(_path); using var grayImg img.Convert<Gray, byte>(); 2.自动二值化图像 using var inputGrayOut new Image<Gray, byte>(grayImg.Size); // 计算OTSU阈值 var threshol…

【图像处理】VS编译opencv源码,并调用编译生成的库

背景 有些时候我们需要修改opencv相关源码&#xff0c; 这里介绍怎么编译修改并调用修改后的库文件。 步骤 1、下载相关源码工具&#xff1a; 下载opencv4.8源码并解压 https://down.chinaz.com/soft/40730.htm 下载VS2019&#xff0c;社区版免费 https://visualstudio.micro…

【C++】动态规划题目总结(随做随更)

文章目录 一. 斐波那契数列模型1. 第 N 个泰波那契数2. 三步问题3. 使用最小花费爬楼梯解法一&#xff1a;从左往右填表解法二&#xff1a;从右往左填表 一. 斐波那契数列模型 解题步骤&#xff1a; 确定状态表示&#xff08;最重要&#xff09;&#xff1a;明确dp表里的值所…