MYSQL主从(主备)部署

一、环境准备

1、主机规划,示例环境用配置1主2从

类型

服务器IP

数据库版本

Master

192.168.100.1

Mysql:5.7.27

Save1

192.168.100.2

Mysql:5.7.27

Save2

192.168.100.3

Mysql:5.7.27

2、服务器环境准备

2.1 安装docker

在3台服务器上安装docker,安装过程跳过

2.2 mysql镜像上传

......

二、安装

1、创建数据和配置文件挂载目录(3台服务器都需要操作)

$ mkdir -p /data/containers/mysql/data

$ mkdir -p /data/containers/mysql/conf

$ chmod -R 755 /data/containers/mysql

2、将配置文件my.cnf上传到/data/containers/mysql/conf目录下(3台服务器都需要操作)

$cat my.cnf

-------------------------------

[mysqld]

server_id = 1

# 主从复制设置

log-bin = mysql-bin # 开启mysql binlog功能

binlog_format = ROW # binlog记录内容的方式,记录被操作的每一行

binlog_row_image = minimal # 对于binlog_format = ROW模式时,减少记录日志的内容,只记录受影响的列

sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

default-time_zone = '+8:00' #时区设置

lower_case_table_names=1 # 是否对sql语句大小写敏感,1表示不敏感

max_connections=10240 # 最大连接数

character-set-server=utf8mb4 # 数据库默认字符集,主流字符集支持一些特殊表情符号(特殊表情符占用4个字节)

[client]

default-character-set=utf8

!includedir /etc/mysql/conf.d/

!includedir /etc/mysql/mysql.conf.d/

---------------------------------

注意:以上配置仅供参考;实际配置需要根据项目需求进行调整

3、修改从服务器save1和save2的server-id配置

3.1 在save1服务器上执行命令

$ sed -i s/"server-id = 1"/"server-id = 2"/g /data/containers/mysql/conf/my.cnf

3.2 在save2服务器上执行命令

$ sed -i s/"server-id = 1"/"server-id = 3"/g /data/containers/mysql/conf/my.cnf

4、启动数据库

4.1 启动master数据库,在master服务器上执行命令

$ docker run -p 3306:3306 --name mysql_master --restart=always \

-v /data/containers/mysql/data:/var/lib/mysql \

-v /data/containers/mysql/conf/my.cnf:/etc/mysql/my.cnf \

-e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7.27

4.2 启动save1数据库,在save1服务器上执行命令

$ docker run -p 3306:3306 --name mysql_save1 --restart=always \

-v /data/containers/mysql/data:/var/lib/mysql \

-v /data/containers/mysql/conf/my.cnf:/etc/mysql/my.cnf \

-e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7.27

4.3 启动save2数据库,在save2服务器上执行命令

$ docker run -p 3306:3306 --name mysql_save2 --restart=always \

-v /data/mysql_containers/data:/var/lib/mysql \

-v /data/containers/mysql/conf/my.cnf:/etc/mysql/my.cnf \

-e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7.27

至此3台服务器已经启动完成,数据库账号:root 密码 :123456

三、 配置主从

1、master服务器配置

1.1 登录数据库

$ docker exec -it mysql_master bash

$ mysql -uroot -p

输入密码123456登录数据库

1.2 master数据库授权同步账户(在数据库内操作)

$ GRANT REPLICATION SLAVE ON *.* TO 'save'@'%' IDENTIFIED BY '123456';

$ FLUSH PRIVILEGES;

备注: %是指定用户登录IP白名单,‘%’表示全部IP;具体可以根据现场环境设置。

1.3 清空Master日志,查看数据库记录二进制开始文件位置(在数据库内部操作)

$ RESET MASTER;

$ SHOW MASTER STATUS;

2、save1服务器配置

2.1 登录数据库

$ docker exec -it mysql_save1 bash

$ mysql -uroot -p

输入密码123456登录数据库

2.2 配置同步(在数据库内操作)

$ CHANGE MASTER TO MASTER_HOST='192.168.100.1' , MASTER_PORT=3306 , MASTER_USER='save' , MASTER_PASSWORD='123456' , MASTER_LOG_FILE='mysql-bin.000001' , MASTER_LOG_POS=328;

备注:MASTER_LOG_POS的数值是1.3步骤获取

3、Save2服务器配置

3.1 登录数据库

$ docker exec -it mysql_save2 bash

$ mysql -uroot -p

输入密码123456登录数据库

3.2 配置同步(在数据库内操作)

$ CHANGE MASTER TO MASTER_HOST='192.168.100.1' , MASTER_PORT=3306 , MASTER_USER='save' , MASTER_PASSWORD='123456' , MASTER_LOG_FILE='mysql-bin.000001' , MASTER_LOG_POS=328;

备注:MASTER_LOG_POS的数值是1.3步骤获取

4、启动同步

分别在save1和save2数据库上执行

$ START SLAVE;

5、查看master 配置状态(在数据库内部操作)

$ show processlist\G

看到上面的Command: Binlog Dump说明配置成功!

6、查看save1和save2的主从配置状态(在数据库内部操作)

$ SHOW SLAVE STATUS\G;

 出现2个YES表示配置正常

7、设置从库只读(在数据库内部操作)

$ set global read_only=1;

备注:只读设置对root用户无效

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MySQL主从读写分离部署是一种常见的数据库架构,它可以提高系统的性能和可用性。在这种架构中,有一个数据库(Master)用于处理写操作,而多个从数据库(Slaves)用于处理读操作。 以下是MySQL主从读写分离部署的一般步骤: 1. 安装MySQL:在服务器和从服务器上安装MySQL数据库软件。 2. 配置服务器:在服务器上进行以下配置操作: - 在my.cnf配置文件中启用二进制日志(binary log)功能,并设置一个唯一的服务器ID。 - 创建一个用于复制的账户,并授予该账户复制权限。 3. 配置从服务器:在每个从服务器上进行以下配置操作: - 在my.cnf配置文件中设置一个唯一的服务器ID。 - 配置从服务器连接到服务器的信息,包括服务器的IP地址、复制账户的用户名和密码。 4. 启动复制:在从服务器上启动复制进程,使其连接到服务器并开始复制数据。 5. 验证复制:确认从服务器已经成功连接到服务器并开始复制数据。可以通过查看主从服务器的状态信息来验证复制是否正常运行。 6. 读写分离配置:在应用程序中配置读写分离,使读操作通过从服务器处理,写操作通过服务器处理。可以使用中间件或代理来实现读写分离,例如MySQL Proxy、MySQL Router或HAProxy。 7. 监控和维护:定期监控主从服务器的状态,确保复制正常运行。如果服务器发生故障,可以手动将其中一个从服务器提升为新的服务器。 需要注意的是,MySQL主从复制并不能实时同步数据,而是异步复制。因此,主从复制在高并发写入场景下可能存在一定的延迟。此外,主从复制也需要考虑数据一致性和容灾份等问题。在部署过程中,建议参考MySQL官方文档和相关资料,并根据实际情况进行配置和调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值