ShardingJdbc准备-Docker安装mysql,以及主从复制配置

本文主要是介绍ShardingJdbc准备-Docker安装mysql,以及主从复制配置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ShardingJdbc准备-docker安装mysql,以及主从复制配置


文章目录

  • ShardingJdbc准备-docker安装mysql,以及主从复制配置
  • 前言
  • 一、Docker安装Mysql
  • 二、主从复制配置
    • 1.主服务器
    • 2.从服务器
    • 3.主从复制测试
  • 三、友情提示-主从复制可能出现的问题
    • 1.主从复制Connecting问题
    • 2。MYSQL镜像服务器因错误停止的恢复 —Slave_SQL_Running: No
    • 3. 从MYSQL服务器Slave_IO_Running: No的解决


前言

以下来自官网的原话:
Apache ShardingSphere 是一套开源的分布式数据库解决方案组成的生态圈,它由 JDBC、Proxy 和 Sidecar(规划中)这 3 款既能够独立部署,又支持混合部署配合使用的产品组成。 它们均提供标准化的数据水平扩展、分布式事务和分布式治理等功能,可适用于如 Java 同构、异构语言、云原生等各种多样化的应用场景。
Apache ShardingSphere 旨在充分合理地在分布式的场景下利用关系型数据库的计算和存储能力,而并非实现一个全新的关系型数据库。 关系型数据库当今依然占有巨大市场份额,是企业核心系统的基石,未来也难于撼动,我们更加注重在原有基础上提供增量,而非颠覆。

准备两台服务器


一、Docker安装Mysql

参考之前的blog

二、主从复制配置

1.主服务器

节点配置

# 查看运行中的容器
[root@VM-4-17-centos ~]# docker ps
CONTAINER ID   IMAGE        COMMAND                  CREATED       STATUS          PORTS                                                  NAMES
007699a3c7d2   mysql        "docker-entrypoint.s…"   2 hours ago   Up 48 minutes   33060/tcp, 0.0.0.0:3344->3306/tcp, :::3344->3306/tcp   mysql01# 进入容器内部
docker exec -it 007699a3c7d2 /bin/bash> vim /etc/my.cnf# 修改id 同一局域网内注意要唯一[mysqld]
server-id=100 # 如果启动是数据卷绑定的是-v /**/conf:/etc/mysql/conf.d,可以将/etc/my.cnf拷贝到/etc/mysql/conf.d目录下

数据库配置


# 登陆mysql,输入密码后
mysql>mysql -u root -p
# 找到当前binlog的位置坐标,记住它,下面要用
mysql> show master status;
+---------------+----------+--------------+------------------+-------------------+
| File          | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+---------------+----------+--------------+------------------+-------------------+
| binlog.000002 |      158 |              |                  |                   |
+---------------+----------+--------------+------------------+-------------------+
1 row in set, 1 warning (0.00 sec)

2.从服务器

按照主服务器的步骤配置完my.cnf后,进入mysql服务

#  master_log_file 和 master_log_pos 都是通过 master服务器通过show master status获得。
mysql> change master to master_host='master服务器ip', master_user='root', master_password='master密码', master_port=master端口, master_log_file='binlog.000002',master_log_pos=158;# 查看salve节点状态,只要红框框内都是yes就代表成功了
mysql> show slave status \G;

在这里插入图片描述

3.主从复制测试

在主库上新建表并插入数据,从库立即同步

在这里插入图片描述

在这里插入图片描述

三、友情提示-主从复制可能出现的问题

1.主从复制Connecting问题

在这里插入图片描述
使用start slave开启主从复制过程后,如果SlaveIORunning一直是Connecting,则说明主从复制一直处于连接状态,这种情况一般是下面几种原因造成的,我们可以根据 Last_IO_Error提示予以排除。

  • 网络不通
  • 检查ip,端口
  • 密码不对
  • 检查是否创建用于同步的用户和用户密码是否正确
  • pos不对

2。MYSQL镜像服务器因错误停止的恢复 —Slave_SQL_Running: No

先stop slave,然后依次执行以下:

  • set global sql_slave_skip_counter=1;
  • start slave;
  • show slave status\G ;

3. 从MYSQL服务器Slave_IO_Running: No的解决

  1. 在master节点执行
mysql > show master status;
  1. slave重新绑定
mysql > stop slave;
mysql > CHANGE MASTER TO MASTER_LOG_FILE='binlog.0000028', MASTER_LOG_POS=228; 
mysql > start slave;

造成这类问题的原因一般是在主从复制的时候,基于创建表,然后又去删除和操作了数据表或者表。


这篇关于ShardingJdbc准备-Docker安装mysql,以及主从复制配置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/759387

相关文章

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

MySQL8 密码强度评估与配置详解

《MySQL8密码强度评估与配置详解》MySQL8默认启用密码强度插件,实施MEDIUM策略(长度8、含数字/字母/特殊字符),支持动态调整与配置文件设置,推荐使用STRONG策略并定期更新密码以提... 目录一、mysql 8 密码强度评估机制1.核心插件:validate_password2.密码策略级

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

QT Creator配置Kit的实现示例

《QTCreator配置Kit的实现示例》本文主要介绍了使用Qt5.12.12与VS2022时,因MSVC编译器版本不匹配及WindowsSDK缺失导致配置错误的问题解决,感兴趣的可以了解一下... 目录0、背景:qt5.12.12+vs2022一、症状:二、原因:(可以跳过,直奔后面的解决方法)三、解决方

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

SpringBoot路径映射配置的实现步骤

《SpringBoot路径映射配置的实现步骤》本文介绍了如何在SpringBoot项目中配置路径映射,使得除static目录外的资源可被访问,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一... 目录SpringBoot路径映射补:springboot 配置虚拟路径映射 @RequestMapp