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集群,包括一主一从和多主多从的配置。这将提高数据库的可用性和性能,使您能够更好地处理数据库工作负载和故障容忍性。如果需要更多节点,只需重复配置多主多从的步骤。希望这个博客对您有所帮助!