当前位置: 首页 > wzjs >正文

aspnet网站开发选择题一站式营销平台

aspnet网站开发选择题,一站式营销平台,建南沙做网站公司,网站开发接口Docker搭建MySQL 5.7一主两从主从复制架构 本篇教程将带你从零开始,用Docker Compose快速搭建MySQL 5.7的一主两从主从复制架构,详细且易懂,帮你一步步实现数据自动同步与高可用监控。 一、环境准备 1. Docker 和 Docker Compose 安装 Do…

Docker搭建MySQL 5.7一主两从主从复制架构

本篇教程将带你从零开始,用Docker Compose快速搭建MySQL 5.7的一主两从主从复制架构,详细且易懂,帮你一步步实现数据自动同步与高可用监控。

一、环境准备

1. Docker 和 Docker Compose 安装

Docker和Compose必须预先安装,参考官方文档:Docker安装文档

检查安装:

docker -v
docker-compose -v

2. 创建项目结构

创建以下目录结构:

mysql-cluster/
├── docker-compose.yml
├── master/
│   └── my.cnf
├── slave1/
│   └── my.cnf
├── slave2/
│   └── my.cnf
└── init/└── init-replica.sql

二、核心配置

1. 主库配置(master/my.cnf)

[mysqld]
server-id=1
log-bin=mysql-bin
binlog_format=row

2. 从库配置(slave1/my.cnf 和 slave2/my.cnf)

[mysqld]
server-id=2 # slave2 改为 server-id=3
relay-log=relay-log
read-only=1
super_read_only=1

3. 初始化从库SQL脚本(init/init-replica.sql)

CHANGE MASTER TOMASTER_HOST='mysql-master',MASTER_USER='replica',MASTER_PASSWORD='replica_pass',MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=154;START SLAVE;

注意:MASTER_LOG_FILE和MASTER_LOG_POS稍后更新。

三、Docker Compose 文件配置

version: '3.8'services:master:image: mysql:5.7container_name: mysql-masterrestart: alwaysenvironment:MYSQL_ROOT_PASSWORD: rootpassports:- "3307:3306"volumes:- ./master/my.cnf:/etc/mysql/conf.d/my.cnfnetworks:- mysql-netslave1:image: mysql:5.7container_name: mysql-slave1restart: alwaysenvironment:MYSQL_ROOT_PASSWORD: rootpassdepends_on:- mastervolumes:- ./slave1/my.cnf:/etc/mysql/conf.d/my.cnf- ./init/init-replica.sql:/docker-entrypoint-initdb.d/init-replica.sqlnetworks:- mysql-netslave2:image: mysql:5.7container_name: mysql-slave2restart: alwaysenvironment:MYSQL_ROOT_PASSWORD: rootpassdepends_on:- mastervolumes:- ./slave2/my.cnf:/etc/mysql/conf.d/my.cnf- ./init/init-replica.sql:/docker-entrypoint-initdb.d/init-replica.sqlnetworks:- mysql-netnetworks:mysql-net:driver: bridge

四、启动并配置主库

启动容器:

docker-compose up -d

创建复制用户并查询主库binlog位置:

docker exec -it mysql-master mysql -uroot -prootpassmysql> CREATE USER 'replica'@'%' IDENTIFIED BY 'replica_pass';
mysql> GRANT REPLICATION SLAVE ON *.* TO 'replica'@'%';
mysql> FLUSH PRIVILEGES;
mysql> FLUSH TABLES WITH READ LOCK;
mysql> SHOW MASTER STATUS;

记下 File 和 Position 值,更新init-replica.sql

五、初始化从库同步

清理并重启从库让它们重新执行初始化SQL:

docker-compose rm -svf slave1 slave2 && docker-compose up -d slave1 slave2

验证同步状态:

docker exec -it mysql-slave1 mysql -uroot -prootpass -e "SHOW SLAVE STATUS\G"
docker exec -it mysql-slave2 mysql -uroot -prootpass -e "SHOW SLAVE STATUS\G"

出现以下表示成功:

Slave_IO_Running: Yes
Slave_SQL_Running: Yes

六、主从健康监控

创建监控脚本check_slave_status.sh

#!/bin/bash
SLAVES=("mysql-slave1" "mysql-slave2")
MYSQL_USER="root"
MYSQL_PASS="rootpass"
LAG_THRESHOLD=30for SLAVE in "${SLAVES[@]}"; doSTATUS=$(docker exec -i "$SLAVE" mysql -u"$MYSQL_USER" -p"$MYSQL_PASS" -e "SHOW SLAVE STATUS\G")IO_RUNNING=$(echo "$STATUS" | awk -F': ' '/Slave_IO_Running:/ {print $2}' | tr -d '\r')SQL_RUNNING=$(echo "$STATUS" | awk -F': ' '/Slave_SQL_Running:/ {print $2}' | tr -d '\r')SECONDS_BEHIND=$(echo "$STATUS" | awk -F': ' '/Seconds_Behind_Master:/ {print $2}' | tr -d '\r')if [[ "$IO_RUNNING" != "Yes" || "$SQL_RUNNING" != "Yes" ]]; thenecho "[ALERT] $SLAVE replication thread error!"elif [[ "$SECONDS_BEHIND" -gt "$LAG_THRESHOLD" ]]; thenecho "[WARNING] $SLAVE replication lagging ($SECONDS_BEHIND sec)!"elseecho "$SLAVE replication is healthy."fi
done

赋权并执行:

chmod +x check_slave_status.sh
./check_slave_status.sh

加入crontab定时监控即可。


通过以上步骤,你就成功搭建了一套稳定可靠、可监控的MySQL一主两从复制集群!

http://www.dtcms.com/wzjs/56500.html

相关文章:

  • 服务器如何限制每个网站的空间使用大小做百度推广的公司电话号码
  • 赣州新闻最新消息网络搜索优化
  • 广西建设职业学院技术教务系统网站品牌推广的渠道有哪些
  • 商城网站开发哪家好财经新闻最新消息
  • 买个小程序多少钱seo搜索引擎优化总结
  • 网站结构怎么做适合优化百度seo排名优化提高流量
  • 画图软件在线网站排名优化制作
  • 网站滚动的图片是怎么做百度数据分析
  • 深圳企业品牌网站项目营销推广策划
  • 网站开发需要用到的技术网络营销企业有哪些
  • 网站优化内容有哪些自己做一个网站需要多少钱
  • 广州网站建设公司哪家比较好李飞seo
  • 咸宁制作网站微营销平台
  • 河南省内 在哪个网站做商检表网站排名优化培训电话
  • 做网站全过程东莞网站seo公司哪家大
  • 新乡正规网站建设哪家便宜百度识图网页版
  • 网站建设方案2000字seo搜索引擎优化实训
  • 淘宝优惠券网站怎么做域名信息查询网站
  • 怎样加盟网站建设百度一下百度搜索百度
  • 招投标网站建设开发广东宣布即时优化调整
  • 最简单的做网站的工具手机打开国外网站app
  • 网站主持人制作超级外链工具
  • 云南微网站制作如何设计网站
  • 苏州调查公司电话汕头网站建设优化
  • 网站cms下载电商怎么做?如何从零开始学做电商赚钱
  • 重庆承越网站制作公司百度搜索指数
  • 社交网站 ui桔子seo
  • 什么样的网站空间做电影网站不卡seo与sem的区别和联系
  • 织梦网站用户名不存在运营培训班学费大概多少
  • 不同网站对商家做o2o的政策如何搭建网站平台