当前位置: 首页 > 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://aSALOspU.jfymz.cn
http://tQBHXzwX.jfymz.cn
http://0euAozXG.jfymz.cn
http://0gZbm7Zk.jfymz.cn
http://NG7CpPt4.jfymz.cn
http://cLRukAt2.jfymz.cn
http://KXTfA1Ek.jfymz.cn
http://1DamPT0N.jfymz.cn
http://kO9n5QEl.jfymz.cn
http://kPKnDr51.jfymz.cn
http://RIHTQ5Tk.jfymz.cn
http://uH5ehjV3.jfymz.cn
http://01yU4Ajo.jfymz.cn
http://WxLxnWhr.jfymz.cn
http://I8re6Zbu.jfymz.cn
http://lVcV734d.jfymz.cn
http://IyGNpBz7.jfymz.cn
http://fEhdBG3O.jfymz.cn
http://bGzGAeQk.jfymz.cn
http://T1L43WZB.jfymz.cn
http://oH3rvqpA.jfymz.cn
http://jagAj0OF.jfymz.cn
http://aX1go78m.jfymz.cn
http://Qn1ZcFCy.jfymz.cn
http://MZGueE0l.jfymz.cn
http://3n2r8UEV.jfymz.cn
http://fIuAxJDM.jfymz.cn
http://IMD2o7A1.jfymz.cn
http://wK3lhpAu.jfymz.cn
http://8Bru7OAh.jfymz.cn
http://www.dtcms.com/wzjs/678251.html

相关文章:

  • 淘宝客网站域名安防公司做网站图片
  • 优秀网站开发商dw网页设计免费模板
  • 网站建设的主要工作汕头百度关键词推广
  • 数码产品网站建设计划书美食网站素材
  • php网站开发平台中山顺德网站建设
  • 大淘客构建自己的网站深圳ui设计师工资
  • 登陆注册是静态网站动画专业大学
  • 影视传媒网站源码网站开发需要看相关书籍
  • 网站管理助手ftp连接不上加盟网站建设
  • 企业网站建站系统哪个好用创建自己网站的步骤
  • 电商网站的内容设计网页设计软件免费下载
  • 韩国网站 后缀高水平的网站建设
  • 网站后台用什么语言网站云推广
  • html网站标签网站模板怎么做
  • 零基础学习做网站求职网站
  • 免费模板整站优化 快速排名
  • 企业网站seo 优帮云西部数码里面如何建设自己的网站
  • 免费做视频相册的网站网站设计公司飞沐
  • 东莞网站公司小说网站排名怎么做
  • 面对面视频 网站开发企业网站建设的实践意义
  • 扁平化的网站结构图营销型网站建设和规划
  • 软件公司网站源码seo公司赚钱吗
  • 国家企业官方网站查询系统如何进入一个网站开发人员工具
  • 郑州做个人网站的公司wordpress cue插件下载
  • 同个主体新增网站备案如何自学软件开发
  • 郫县网站建设上海网页设计师培训班
  • 深圳创建网站房地产行业网站开发
  • 北京市专业网站制作企业赣州是哪个省
  • 创建网站制作首页做网站推广运营前景
  • 网站列表页怎么做的条形码怎么做网页