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

相关文章

MySQL 主从复制部署及验证(示例详解)

《MySQL主从复制部署及验证(示例详解)》本文介绍MySQL主从复制部署步骤及学校管理数据库创建脚本,包含表结构设计、示例数据插入和查询语句,用于验证主从同步功能,感兴趣的朋友一起看看吧... 目录mysql 主从复制部署指南部署步骤1.环境准备2. 主服务器配置3. 创建复制用户4. 获取主服务器状态5

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

MySQL 迁移至 Doris 最佳实践方案(最新整理)

《MySQL迁移至Doris最佳实践方案(最新整理)》本文将深入剖析三种经过实践验证的MySQL迁移至Doris的最佳方案,涵盖全量迁移、增量同步、混合迁移以及基于CDC(ChangeData... 目录一、China编程JDBC Catalog 联邦查询方案(适合跨库实时查询)1. 方案概述2. 环境要求3.

JAVA中安装多个JDK的方法

《JAVA中安装多个JDK的方法》文章介绍了在Windows系统上安装多个JDK版本的方法,包括下载、安装路径修改、环境变量配置(JAVA_HOME和Path),并说明如何通过调整JAVA_HOME在... 首先去oracle官网下载好两个版本不同的jdk(需要登录Oracle账号,没有可以免费注册)下载完

nginx 负载均衡配置及如何解决重复登录问题

《nginx负载均衡配置及如何解决重复登录问题》文章详解Nginx源码安装与Docker部署,介绍四层/七层代理区别及负载均衡策略,通过ip_hash解决重复登录问题,对nginx负载均衡配置及如何... 目录一:源码安装:1.配置编译参数2.编译3.编译安装 二,四层代理和七层代理区别1.二者混合使用举例

Java JDK1.8 安装和环境配置教程详解

《JavaJDK1.8安装和环境配置教程详解》文章简要介绍了JDK1.8的安装流程,包括官网下载对应系统版本、安装时选择非系统盘路径、配置JAVA_HOME、CLASSPATH和Path环境变量,... 目录1.下载JDK2.安装JDK3.配置环境变量4.检验JDK官网下载地址:Java Downloads

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.