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

相关文章

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Mysql虚拟列的使用场景

《Mysql虚拟列的使用场景》MySQL虚拟列是一种在查询时动态生成的特殊列,它不占用存储空间,可以提高查询效率和数据处理便利性,本文给大家介绍Mysql虚拟列的相关知识,感兴趣的朋友一起看看吧... 目录1. 介绍mysql虚拟列1.1 定义和作用1.2 虚拟列与普通列的区别2. MySQL虚拟列的类型2

mysql数据库分区的使用

《mysql数据库分区的使用》MySQL分区技术通过将大表分割成多个较小片段,提高查询性能、管理效率和数据存储效率,本文就来介绍一下mysql数据库分区的使用,感兴趣的可以了解一下... 目录【一】分区的基本概念【1】物理存储与逻辑分割【2】查询性能提升【3】数据管理与维护【4】扩展性与并行处理【二】分区的

windos server2022的配置故障转移服务的图文教程

《windosserver2022的配置故障转移服务的图文教程》本文主要介绍了windosserver2022的配置故障转移服务的图文教程,以确保服务和应用程序的连续性和可用性,文中通过图文介绍的非... 目录准备环境:步骤故障转移群集是 Windows Server 2022 中提供的一种功能,用于在多个

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

MySQL中时区参数time_zone解读

《MySQL中时区参数time_zone解读》MySQL时区参数time_zone用于控制系统函数和字段的DEFAULTCURRENT_TIMESTAMP属性,修改时区可能会影响timestamp类型... 目录前言1.时区参数影响2.如何设置3.字段类型选择总结前言mysql 时区参数 time_zon

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

关于Maven中pom.xml文件配置详解

《关于Maven中pom.xml文件配置详解》pom.xml是Maven项目的核心配置文件,它描述了项目的结构、依赖关系、构建配置等信息,通过合理配置pom.xml,可以提高项目的可维护性和构建效率... 目录1. POM文件的基本结构1.1 项目基本信息2. 项目属性2.1 引用属性3. 项目依赖4. 构

龙蜥操作系统Anolis OS-23.x安装配置图解教程(保姆级)

《龙蜥操作系统AnolisOS-23.x安装配置图解教程(保姆级)》:本文主要介绍了安装和配置AnolisOS23.2系统,包括分区、软件选择、设置root密码、网络配置、主机名设置和禁用SELinux的步骤,详细内容请阅读本文,希望能对你有所帮助... ‌AnolisOS‌是由阿里云推出的开源操作系统,旨