springboot 整合 sharding-jdbc 主从 读写分离

news2024/11/18 9:31:42

目录

0 课程视频

1 mysql 主从搭建

1.1 docker mysql 主从搭建

1.2 非docker mysql 主从搭建

2 springboot sharding-jdbc 主从 读写分离

2.1 pom 加依赖

2.1 yml 配置文件

2.2 druid数据源冲突解决 -> 视频15:20 秒处

2.3 注入数据源对象

3 测试 -> 直接使用 就是读写分离

3.1 实体类User -> 数据字段 对象字典

3.2 Mapper -> 增删改查的接口

3.3 Service -> 调用Mapper中增删改查方法

3.4 Controller -> 客户端/postman 请求的路径 -> 调用Service

4 日志-postman 验证 读写分离

4.0 日志使用课程 -> 查询日志(增删改查的都记录)

4.1 配置日志在 /opt/mysql-s/data/slave.log -> 映射/var/lib/mysql:q

4.2 日志文件夹下 -> tail -f slave.log  -> get一次请求自动刷新

5 Debug 验证读写分离

5.1 打断点 ->Debug 运行后 光标放到 DataSource 上 点进去

 5.2 完全运行 -> 前提是spring.shardingsphere.props.sql:show. true 可以打印sql


0 课程视频

SpringBoot Sharding-JDBC实现数据库读写分离 一主一从 一主多从 多主多从_哔哩哔哩_bilibili《100个SpringBoot实战项目》将持续推出,不管是学习SpringBoot,还是温习SpringBoot将受益匪浅。本系列将以合集的形式系统化推出,欢迎持续关注。共建知识区 你我共同努力。免·费领源码:转发本视频到朋友圈,24小时之后免·费私信领取源代码【作弊视为放弃资格,需截图验证】-------免费资料-------➡️ 技术博客 https://www.altitude.xin ➡️, 视频播放量 2481、弹幕量 2、点赞数 64、投硬币枚数 20、收藏人数 110、转发人数 11, 视频作者 赛泰先生, 作者简介 源代码 技术答疑 远程排错 唯信: dream4s,相关视频:SpringBoot 整合Sharding Jdbc 实现分库分表 缓解单表压力 最强实战,SpringBoot 苞米豆实现数据库读写分离,比Navicat还快,堵上我的码农生涯,这款SQL开发工具真的是天花板!,精讲MySQL数据库两大知识点:主从复制与读写分离,进阶面试题:你有没有做过MySQL的读写分离?,尚硅谷Sharding Sphere,Sharding JDBC,分库分表利器,数据库中间件,springboot整合Sharding-jdbc代替mybatis快速实现多数据源配置,并实现读写分离,及如何实现事务管控机制,架构摆渡人-Sharding Sphere,Sharding JDBC-真实订单业务,亿级数据带你实战分库分表,SpringBoot+Sharding-JDBC分库分表实战,【IT老齐112】高频面试题,MySQL读写分离后,先写后查如何保障一致性?https://www.bilibili.com/video/BV12o4y1a7Zf/?spm_id_from=333.337.search-card.all.click&vd_source=ff8b7f852278821525f11666b36f180a

https://www.bilibili.com/video/BV13a411q753?p=176&spm_id_from=pageDriver&vd_source=ff8b7f852278821525f11666b36f180ahttps://www.bilibili.com/video/BV13a411q753?p=176&spm_id_from=pageDriver&vd_source=ff8b7f852278821525f11666b36f180a

1 mysql 主从搭建

1.1 docker mysql 主从搭建

docker Mysql部署主从集群_tenc1239的博客-CSDN博客

1.2 非docker mysql 主从搭建

Mysql 主从 读写分离_tenc1239的博客-CSDN博客

2 springboot sharding-jdbc 主从 读写分离

2.1 pom 加依赖

 <dependency>
            <groupId>org.apache.shardingsphere</groupId>
            <artifactId>sharding-jdbc-spring-boot-starter</artifactId>
            <version>4.1.1</version>
        </dependency>

<dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.5.0</version>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.2.15</version>
        </dependency>

 <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.49</version>
        </dependency>

2.1 yml 配置文件

spring:
  shardingsphere:
    datasource:
      names:
        master, slave

      master:
        type: com.alibaba.druid.pool.DruidDataSource
        driver-class-name: com.mysql.cj.jdbc.Driver
        url: jdbc:mysql://8.219.87.87:3306/test001?useUnicode=true&characterEncoding=utf-8 # 这个url 不能写错 
        username: 
        password: 

      slave:
        type: com.alibaba.druid.pool.DruidDataSource
        driver-class-name: com.mysql.cj.jdbc.Driver
        url: jdbc:mysql://8.219.87.87:3307/test001?useUnicode=true&characterEncoding=utf-8
        username: 
        password: 
    masterslave:

      load-balance-algorithm-type: round_robin

      name: dataSource

      master-data-source-name: master

      slave-data-source-names: slave
    props: # 显示sql
      sql:
        show: true
  main:
    allow-bean-definition-overriding: true

2.2 druid数据源冲突解决 -> 允许bean定义覆盖 -> 视频15:20 秒处

项目优化Day2-06-读写分离案例_入门案例_哔哩哔哩_bilibili项目优化Day2-06-读写分离案例_入门案例是黑马程序员Java项目实战《瑞吉外卖》,轻松掌握springboot + mybatis plus开发核心技术的真java实战项目的第176集视频,该合集共计191集,视频收藏或关注UP主,及时了解更多相关视频内容。https://www.bilibili.com/video/BV13a411q753?p=176&spm_id_from=pageDriver&vd_source=ff8b7f852278821525f11666b36f180a

spring: 
  main:
    allow-bean-definition-overriding: true

2.3 注入数据源对象

@Autowired
private DataSource dataSource;

3 测试 -> 直接使用 就是读写分离

3.1 实体类User -> 数据字段 对象字典

3.2 Mapper -> 增删改查的接口

3.3 Service -> 调用Mapper中增删改查方法

3.4 Controller -> 客户端/postman 请求的路径 -> 调用Service

4 日志-postman 验证 读写分离

4.0 日志使用课程 -> 查询日志(增删改查的都记录)

Mysql 日志_tenc1239的博客-CSDN博客【代码】Mysql 日志。https://blog.csdn.net/tenc1239/article/details/130451019?spm=1001.2014.3001.5501

4.1 配置日志在 /opt/mysql-s/data/slave.log -> 映射/var/lib/mysql:q

general_log = 1
general_log_file = /var/lib/mysql/slave.log # /var/lib/mysql是mysql配置是设置的映射路径

4.2 日志文件夹下 -> tail -f slave.log  -> get一次请求自动刷新

5 Debug 验证读写分离

5.1 打断点 ->Debug 运行后 光标放到 DataSource 上 点进去

 

 

 5.2 完全运行 -> 前提是spring.shardingsphere.props.sql:show. true 可以打印sql


 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/492656.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java使用Milo实现OPC UA客户端,封装spring boot starter

文章目录 一、milo库二、OPC UA服务端三、工具使用3.1 依赖3.2 配置3.3 连接池3.4 写3.4.1 通用类型3.4.2 已提供方法的类型3.4.3 其他类型 3.5 读3.6 遍历节点 一、milo库 由eclipse开源&#xff0c;地址&#xff1a;https://github.com/eclipse/milo&#xff0c;可以基于此开…

ChatGPT如何提问?30句ChatGPT提问公式,快收藏

在使用ChatGPT过程中&#xff0c;总感觉用chatgpt的效果没有那么好。经过多次使用和摸索&#xff0c;终于发现了问题&#xff0c;原来不是ChatGPT不好用&#xff0c;效果不好&#xff0c;而是因为我之前不会提问。 话不多说&#xff0c;给大家准备了30句ChatGPT提问公式 1、撰…

Python入门(四)列表(一)

列表&#xff08;一&#xff09; 1.列表简介1.1 什么是列表&#xff1f;1.2 访问列表元素 2.修改、添加和删除列表元素2.1 修改列表元素2.2 在列表中添加元素2.2 从列表中删除元素 作者&#xff1a;Xiou 1.列表简介 列表让你能够在一个地方存储成组的信息&#xff0c;其中可以…

【并发编程】探索可见性背后的本质以及vloatile原理

文章目录 可见性造成不可见性的原因缓存一致性指令重排序 JMMvloatile原理Happens-Before模型案例说明 可见性 在单线程的环境下&#xff0c;如果向一个变量先写入一个值&#xff0c;然后在没有写干涉的情况下读取这个变量的值&#xff0c;那 这个时候读取到的这个变量的值应该…

java学习之异常

目录 一、引出异常 实例 运行结果 二、异常体系图 三、五大运行时异常 一、NullPointerException 空指针异常 二、ArithmeticException 数学运算异常 三、ArrayIndexOutOfBoundsException 数组下标越界异常 四、ClassCastException 类型转换异常 ​编辑五、 NumberFormat…

Redis整合

目录 一、事务 二、乐观锁 三、Jedis 四、Springboot整合Redis 4.1创建springboot项目&#xff0c;勾选对应的依赖 4.2源码分析 4.3配置文件 4.4测试 4.5自定义序列化方式 4.5.1JSON序列化 4.5.2String序列化 一、事务 事务本质&#xff1a;一组命令的集合&#xff0c;…

腾讯云服务器实例规格组大全及应用场景有哪些?

腾讯云服务器包含很多种实例规格族&#xff0c;不同实例规格族之间处理器CPU、内存、硬盘和内网都会有所区别。今天小白将详细介绍下现阶段所有的腾讯云实例规格族&#xff0c;以及其对应的应用场景。 腾讯云实例规格族按照功能会有很多区别&#xff0c;一般会已它独有的特性命…

2023年腾讯云轻量服务器性能评测

腾讯云轻量应用服务器性能评测 轻量应用服务器是腾讯云推出的一款开箱即用的轻量级的云服务器&#xff0c;轻量服务器CPU内存带宽配置更高&#xff0c;价格却又很便宜&#xff0c;很多同学认为是不是轻量应用服务器性能不行呀&#xff0c;轻量服务器和云服务器有什么区别&…

Shell+VCS学习3---VCS-lint

lint lintTFIPC-L LINTPCWMlintTFIPC-L(如果有的模块的端口定义了&#xff0c;但是没有连接&#xff0c;用这个选项&#xff0c;编译器会给出哪些端口没有连接) 其中CAWM貌似直接写成lintCAWM&#xff0c;vcs是不认的&#xff0c;得写成lintCAWM-L 不过CAWM的检查规则有点奇怪…

国产化NI虚拟仪器高精度数据采集卡控制器进口替代方案

什么是CompactDAQ&#xff1f; CompactDAQ系统可在任何距离和环境下&#xff0c;采集并交付满足您测试需求的验证数据。这些可定制的便携式解决方案由不同的数据采集模块组成&#xff0c;可通过网络实现同步测量&#xff0c;帮助您将数据数字化&#xff0c;同时可部署在更靠近…

数据结构与算法基础-学习-22-查找之顺序查找与折半查找(二分查找)

目录 一、概念 1、查找表 2、关键字 3、主关键字 4、次关键字 二、查找表分类 1、静态查找表 2、动态查找表 三、平均查找长度 四、顺序查找 1、适用范围 2、结构体定义 3、函数定义 &#xff08;1&#xff09;生成测试数据&#xff08;创建顺序查询表&#xff09…

git reset和git revert的区别

前提条件 假设现在有三次提交到remote repository: commit abf94bdf743e23737950c36bda381d2aba1803fc(HEAD -> master, origin/master) Author: ztenv <class7classqmm.com> Date: Tue Sep 21 16:36:39 2021 0800feat add 3.gocommit 181cc7131acc18f248aba46384…

2023年值得关注:邮件营销平台的新技术和新趋势

对于希望增加在线影响力和想要接触更广泛受众的企业来说&#xff0c;电子邮件营销是一个非常好用的工具。它能够为企业培养长期的联系人&#xff0c;以极高的投资回报比为企业带来长期收益。特别是对于想要出海的企业或者做跨境贸易的公司来讲&#xff0c;邮件营销可以发挥巨大…

(抄送列表,年会抽奖)笔试强训

博主简介&#xff1a;想进大厂的打工人博主主页&#xff1a;xyk:所属专栏: JavaEE初阶 目录 文章目录 一、[编程题]抄送列表 二、[编程题]年会抽奖 一、[编程题]抄送列表 链接&#xff1a;抄送列表__牛客网 来源&#xff1a;牛客网 题目&#xff1a; NowCoder每天要处理许多邮…

Swift 技术 删除缓存,清空缓存

一直觉得自己写的不是技术&#xff0c;而是情怀&#xff0c;一个个的教程是自己这一路走来的痕迹。靠专业技能的成功是最具可复制性的&#xff0c;希望我的这条路能让你们少走弯路&#xff0c;希望我能帮你们抹去知识的蒙尘&#xff0c;希望我能帮你们理清知识的脉络&#xff0…

测试开发如何进阶?需要哪些能力?吐血整理-你的进阶之路...

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 测试开发&#xff…

Redis底层设计与源码分析(一)__底层数据结构逻辑分析

前言 最近在工作中接触redis&#xff0c;但实际应用不多&#xff0c;可用场景也不是很明确&#xff0c;所以想借机多多学习下redis相关知识&#xff0c;一下内容都是通过自己找资源学习之后归纳总结的知识&#xff0c;若有相关错误点&#xff0c;请指正。 一、redis介绍 1.…

Softing线上研讨会 | 轻松访问XML文件中的过程数据

| 线上研讨会时间&#xff1a;2023年5月8日下午4点或晚上10点 对于传统车间的系统应用和创新的物联网解决方案而言&#xff0c;高效访问机器和流程数据至关重要。而在现有工厂中&#xff0c;过程数据通常以XML文件的形式出现。对此&#xff0c;Softing Industrial提供了一个用…

操作系统——设备管理

0.关注博主有更多知识 操作系统入门知识合集 目录 1.设备管理概念 2.SPOOLing技术 1.设备管理概念 在计算中&#xff0c;除CPU、内存以外的所有设备统称为外设&#xff0c;即外部设备&#xff0c;例如鼠标、键盘、打印机、摄像头、磁盘、硬盘......那么这些只需要连接到计…

多城市门店店铺展示地图导航pc/h5系统开发

多城市门店店铺展示地图导航pc/h5系统开发 系统设置&#xff1a; 网站标题、网站副标题、Logo图、网站背景图、网站底部图、网站底部版权、网站ICP备案、腾讯地图Key。 店铺列表&#xff1a; 店铺名称、店铺图标、设备、电话、省市区、详细地址。 添加店铺&#xff1a; 店铺…