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

网站建设的平台下载百度免费版

网站建设的平台,下载百度免费版,关于酒店网站规划建设方案书,天津网站建设公司推荐Java系列文章 文章目录 Java系列文章前言一、环境准备与Docker配置1.1 环境配置1.2 目录结构1.3 读写分离1.3.1 读写分离方案1.3.2 自定义Docker网络 二、双主四从节点配置2.1 创建MySQL_1节点2.1.1 Mysql_1容器2.1.2 Navicat创建连接2.1.3 创建配置账户 2.2 创建MySQL_2节点2.…

Java系列文章


文章目录

  • Java系列文章
  • 前言
  • 一、环境准备与Docker配置
    • 1.1 环境配置
    • 1.2 目录结构
    • 1.3 读写分离
      • 1.3.1 读写分离方案
      • 1.3.2 自定义Docker网络
  • 二、双主四从节点配置
    • 2.1 创建MySQL_1节点
      • 2.1.1 Mysql_1容器
      • 2.1.2 Navicat创建连接
      • 2.1.3 创建配置账户
    • 2.2 创建MySQL_2节点
      • 2.2.1 Mysql_2容器
      • 2.2.2 配置my.cnf
      • 2.2.3 日志订阅
    • 2.3 创建MySQL_3节点
      • 2.3.1 Mysql_3容器
      • 2.3.2 配置my.cnf
      • 2.3.3 日志订阅
    • 2.4 创建MySQL_4节点
      • 2.4.1 Mysql_4容器
      • 2.4.2 配置my.cnf
    • 2.5 创建MySQL_5节点
      • 2.5.1 Mysql_5容器
      • 2.5.2 配置my.cnf
      • 2.5.3 日志订阅
    • 2.6 创建MySQL_6节点
      • 2.6.1 Mysql_6容器
      • 2.6.2 配置my.cnf
      • 2.6.3 日志订阅
  • 三、配置双向主从同步
    • 3.1 配置MySQL_1节点
    • 3.2 配置MySQL_4节点
    • 3.3 数据演示


前言

本文将介绍如何使用docker搭建mysql双主四从集群服务。


一、环境准备与Docker配置

1.1 环境配置

  • 系统:Linux (CentOS/Ubuntu)
  • 资源:建议 4核CPU/8GB内存+
  • Docker 版本:≥20.10
  • Mysql 版本:5.0+

1.2 目录结构

在这里插入图片描述

1.3 读写分离

1.3.1 读写分离方案

一共要创建6个MySQL节点,其中前三个和后三个节点。

  • mysql_1和mysql_4为主节点
  • mysql_2和mysql_3节点订阅mysql_1的日志文件,实现主从同步
  • mysql_5和mysql_6节点订阅mysql_4的日志文件,实现主从同步
  • mysql_1和mysql_4配置订阅日志,实现双向同步数据
    在这里插入图片描述

1.3.2 自定义Docker网络

Docker默认的网段是172.17.0.x的,需要创建一个新的网段,创建容器的时候,把它们的IP地址绑定到该网段。

docker network create --subnet=172.18.0.0/18 mynet

二、双主四从节点配置

2.1 创建MySQL_1节点

2.1.1 Mysql_1容器

docker run -it -d --name mysql_1 -p 7001:3306 \
--net mynet --ip 172.18.0.2 \
-m 400m -v /root/mysql_1/data:/var/lib/mysql \
-v /root/mysql_1/config:/etc/mysql/conf.d  \
-e MYSQL_ROOT_PASSWORD=abc123456 \
-e TZ=Asia/Shanghai --privileged=true \
mysql:5.7.41 \
--lower_case_table_names=1

2.1.2 Navicat创建连接

使用Navicat连接云主机的7001端口

在这里插入图片描述

2.1.3 创建配置账户

在Navicat上面给MySQL_1创建一个新账户,将来MySQL_2和MySQL_3订阅binlog日志的时候就用这个帐户登陆MySQL_1节点。
在这里插入图片描述
新账户的用户名为sync,密码是abc123456,密码加密策略设置成mysql_native_password。
在这里插入图片描述
服务器权限,勾选下面的三个订阅日志的权限。
在这里插入图片描述
2.1.4 配置my.cnf
修改配置文件,所以要先关闭MySQL容器,配置完成后重新启动容器,在/root/mysql_1/config目录里创建my.cnf文件,配置文件的内容如下:

[mysqld]
#数据库字符集
character_set_server = utf8
#MySQL编号(只可以是数字)
server_id = 1#开启binlog日志,规定日志文件名称
log_bin = mysql_bin
#开启relaylog日志,规定日志文件名称
relay_log = relay_bin
#从库的写操作是否写入binlog日志
log-slave-updates = 1
#采用严格的SQL语句模式
sql_mode = NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

2.2 创建MySQL_2节点

2.2.1 Mysql_2容器

docker run -it -d --name mysql_2 -p 7002:3306 \
--net mynet --ip 172.18.0.3 \
-m 400m -v /root/mysql_2/data:/var/lib/mysql \
-v /root/mysql_2/config:/etc/mysql/conf.d  \
-e MYSQL_ROOT_PASSWORD=abc123456 \
-e TZ=Asia/Shanghai --privileged=true \
mysql:5.7.41 \
--lower_case_table_names=1

2.2.2 配置my.cnf

在/root/mysql_2/config目录里创建my.cnf文件:

[mysqld]
#数据库字符集
character_set_server = utf8
#MySQL编号(只可以是数字)
server_id = 2#为什么从节点要开启binlog日志?(下面有解答)
log_bin = mysql_bin
relay_log = relay_bin#限制普通帐户无法INSERT、DELETE、UPDATE语句,但是该配置对管理员帐户无效
read-only = 1
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

2.2.3 日志订阅

在Navicat上面通过MySQL_2节点执行SQL语句,让MySQL_2订阅MySQL_1的日志文件,实现数据同步。

#停止数据同步服务
stop slave;#设置与MySQL_1同步数据
change master to master_host='172.18.0.2',master_port=3306,master_user='sync',master_password='abc123456';#开启数据同步服务
start slave;#查询数据同步状态
show slave status;

出现两个YES,主从同步就配置成功了。
在这里插入图片描述

2.3 创建MySQL_3节点

2.3.1 Mysql_3容器

docker run -it -d --name mysql_3 -p 7003:3306 \
--net mynet --ip 172.18.0.4 \
-m 400m -v /root/mysql_3/data:/var/lib/mysql \
-v /root/mysql_3/config:/etc/mysql/conf.d  \
-e MYSQL_ROOT_PASSWORD=abc123456 \
-e TZ=Asia/Shanghai --privileged=true \
mysql:5.7.41 \
--lower_case_table_names=1

2.3.2 配置my.cnf

在/root/mysql_3/config目录里创建my.cnf文件:

[mysqld]
#数据库字符集
character_set_server = utf8
#MySQL编号(只可以是数字)
server_id = 3log_bin = mysql_bin
relay_log = relay_binread-only = 1
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

2.3.3 日志订阅

MySQL_3订阅MySQL_1的日志文件,实现数据同步

#停止数据同步服务
stop slave;#设置与MySQL_1同步数据
change master to master_host='172.18.0.2',master_port=3306,master_user='sync',master_password='abc123456';#开启数据同步服务
start slave;#查询数据同步状态
show slave status;

2.4 创建MySQL_4节点

2.4.1 Mysql_4容器

docker run -it -d --name mysql_4 -p 7004:3306 \
--net mynet --ip 172.18.0.5 \
-m 400m -v /root/mysql_4/data:/var/lib/mysql \
-v /root/mysql_4/config:/etc/mysql/conf.d  \
-e MYSQL_ROOT_PASSWORD=abc123456 \
-e TZ=Asia/Shanghai --privileged=true \
mysql:5.7.41 \
--lower_case_table_names=1

2.4.2 配置my.cnf

在/root/mysql_4/config目录里创建my.cnf文件:

[mysqld]
#数据库字符集
character_set_server = utf8
server_id = 4log_bin = mysql_bin
relay_log = relay_bin
log-slave-updates = 1
sql_mode = NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

2.5 创建MySQL_5节点

2.5.1 Mysql_5容器

docker run -it -d --name mysql_5 -p 7005:3306 \
--net mynet --ip 172.18.0.6 \
-m 400m -v /root/mysql_5/data:/var/lib/mysql \
-v /root/mysql_5/config:/etc/mysql/conf.d  \
-e MYSQL_ROOT_PASSWORD=abc123456 \
-e TZ=Asia/Shanghai --privileged=true \
mysql:5.7.41 \
--lower_case_table_names=1

2.5.2 配置my.cnf

在/root/mysql_5/config目录里创建my.cnf文件:

[mysqld]
#数据库字符集
character_set_server = utf8
#MySQL编号(只可以是数字)
server_id = 5log_bin = mysql_bin
relay_log = relay_binread-only = 1
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

2.5.3 日志订阅

MySQL_5订阅MySQL_4的日志文件,实现数据同步

#停止数据同步服务
stop slave;#设置与MySQL_1同步数据
change master to master_host='172.18.0.5',master_port=3306,master_user='sync',master_password='abc123456';#开启数据同步服务
start slave;#查询数据同步状态
show slave status;

2.6 创建MySQL_6节点

2.6.1 Mysql_6容器

docker run -it -d --name mysql_6 -p 7006:3306 \
--net mynet --ip 172.18.0.7 \
-m 400m -v /root/mysql_6/data:/var/lib/mysql \
-v /root/mysql_6/config:/etc/mysql/conf.d  \
-e MYSQL_ROOT_PASSWORD=abc123456 \
-e TZ=Asia/Shanghai --privileged=true \
mysql:5.7.41 \
--lower_case_table_names=1

2.6.2 配置my.cnf

在/root/mysql_6/config目录里创建my.cnf文件:

[mysqld]
#数据库字符集
character_set_server = utf8
#MySQL编号(只可以是数字)
server_id = 6log_bin = mysql_bin
relay_log = relay_binread-only = 1
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

2.6.3 日志订阅

MySQL_6订阅MySQL_4的日志文件,实现数据同步

stop slave;change master to master_host='172.18.0.5',master_port=3306,master_user='sync',master_password='abc123456';start slave;show slave status;

三、配置双向主从同步

MySQL_1和MySQL_4之间要配置双向主从同步。

3.1 配置MySQL_1节点

在Navicat上面,到MySQL_1节点上执行4条SQL语句。以MySQL_4为主节点,订阅日志同步数据

stop slave;change master to master_host='172.18.0.5',master_port=3306,master_user='sync',master_password='abc123456';start slave;show slave status;

3.2 配置MySQL_4节点

在Navicat上面,MySQL_4节点上执行4条SQL语句,以MySQL_1为主节点,订阅日志同步数据。

stop slave;change master to master_host='172.18.0.2',master_port=3306,master_user='sync',master_password='abc123456';start slave;show slave status;

3.3 数据演示

Mysql_1节点创建测试数据库,测试其它节点是否订阅日志同步数据。
在这里插入图片描述

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

相关文章:

  • 专做批发网站域名停靠网页推广大全2021
  • 兰州建设厅网站进入百度app查看
  • 郑州电商公司排名前十有哪些智能优化大师下载
  • 赣州北京网站建设企点官网
  • 网站建设服务器怎么设置营业推广促销
  • 辅助购卡网站怎么做百度推广客服电话人工服务
  • 企业信用网珠海百度seo
  • 中国海员建设工会网站电商平台排行榜前十名
  • 农产品网站开发技术方案与设施移动慧生活app下载
  • 网站建设企业响应式网站模板seo网站关键词排名快速
  • 电梯行业网站怎么做成都seo整站
  • 灯饰 东莞网站建设品牌搜索引擎服务优化
  • 做产品包装的3d网站十大软件培训机构
  • 宁波做网站互联网站
  • 珠海门户网站建设多少钱申请域名的方法和流程
  • java网站开发流程微网站
  • 为什么建设营销型网站网络营销案例
  • 科技医疗网站建设深圳营销型网站定制
  • 南通网站建设规划百度一下你就知道啦
  • 贵阳网站建设公司网页开发公司
  • opencart 构建电子商务网站今日热搜榜官网
  • 外贸公司代理注册上海专业seo排名优化
  • 金华企业做网站外贸seo网站建设
  • 深圳品牌营销型网站建设seo短视频加密路线
  • wordpress 清空 demo北京seo代理计费
  • 建立一个网店网站颜色广告
  • 做电影网站会违法吗seo官网
  • 做网站首页的要素网站推广和优化系统
  • pandorabox做网站青岛谷歌推广
  • 西安网站建设公司排百度一下你就知道了百度一下