帮助文档
专业提供香港服务器、香港云服务器、香港高防服务器租用、香港云主机、台湾服务器、美国服务器、美国云服务器vps租用、韩国高防服务器租用、新加坡服务器、日本服务器租用 一站式全球网络解决方案提供商!专业运营维护IDC数据中心,提供高质量的服务器托管,服务器机房租用,服务器机柜租用,IDC机房机柜租用等服务,稳定、安全、高性能的云端计算服务,实时满足您的多样性业务需求。 香港大带宽稳定可靠,高级工程师提供基于服务器硬件、操作系统、网络、应用环境、安全的免费技术支持。
服务器资讯 / 香港服务器租用 / 香港VPS租用 / 香港云服务器 / 美国服务器租用 / 台湾服务器租用 / 日本服务器租用 / 官方公告 / 帮助文档
MYSQL主从(主备)部署
发布时间:2024-03-06 17:08:10   分类:帮助文档
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用户无效









香港云服务器租用推荐
服务器租用资讯
·广东云服务有限公司怎么样
·广东云服务器怎么样
·广东锐讯网络有限公司怎么样
·广东佛山的蜗牛怎么那么大
·广东单位电话主机号怎么填写
·管家婆 花生壳怎么用
·官网域名过期要怎么办
·官网邮箱一般怎么命名
·官网网站被篡改怎么办
服务器租用推荐
·美国服务器租用
·台湾服务器租用
·香港云服务器租用
·香港裸金属服务器
·香港高防服务器租用
·香港服务器租用特价