SpringCloud的几大痛点 SpringCloud部分组件停止维护和更新,给开发带来不便 SpringCloud部分环境搭建复杂,没有完善的可视化界面,我们需要大量的二次开发和定制 SpringCloud配置复杂,难以上手,部分配置差别难以区分和合理应用 SpringCloud Alibaba的优势 阿里使用过的组件经历了考验,性能强悍,设计合理,现在开源出来大家用 成套的产品搭配完善的可视化界面给开发运维带来极大的便利 搭建简单,学习曲线低 结合SpringCloud Alibaba最终…
seata的使用 1. Seata 概述 Seata 是 Simple Extensible Autonomous Transaction Architecture 的简写,由 feascar 改名而来. Seata 是阿里开源的分布式事务框架,属于二阶段提交模式. 目前github上已经有 12267 颗星了,也很活跃,最新的提交时间很多都是几天前. Seata 有一个重要的机制:行锁+回滚日志. 每个分支事务对应的数据库中都需要有一个回滚日志表 UNDO_LOG,在真正修改数据库记录之前,都…
目录 前言 1. Seata 基础知识 1.1 Seata 的 AT 模式 1.2 Seata AT 模式的工作流程 1.3 Seata 服务端的存储模式 1.4 Seata 与 Spring Cloud 整合说明 1.5 关于事务分组的说明 2. Seata 服务端的安装 2.1 安装包安装 Seata 2.1.1 下载 Seata 2.1.2 修改存储模式为 db 2.1.3 指明注册中心与配置中心,上传 Seata 配置 2.1.4 启动 Seata 服务器 2.2 源码安装 Seata…
读写分离:为了确保数据库产品的稳定性,很多数据库拥有双机热备功能.也就是,第一台数据库服务器,是对外提供增删改业务的生产服务器:第二台数据库服务器,主要进行读的操作. 目前有多种方式实现读写分离,一种是Mycat这种数据库中间件,需要单独部署服务,通过配置来实现读写分离,不侵入到业务代码中:还有一种是dynamic-datasource/shardingsphere-jdbc这种,需要在业务代码引入jar包进行开发. 本框架集成 dynamic-datasource(多数据源+读写分离+分库)+…
源码地址:https://gitee.com/fighter3/eshop-project.git 持续更新中-- 大家好,我是三分恶. 在前面的章节中,我们已经完成了服务间的调用.统一配置等等,在这一章节里,我们会引入微服务体系的一个重要组件--网关. 网关概述 为什么要引入网关 大家都知道,我们服务端的各个服务调用是从服务注册中心拉取服务列表,再由负载均衡策略去调用对应的服务提供方. 那么,在什么都不做的情况下,看看我们的客户端,包括PC.移动端等等是怎么访问我们的服务端的呢? 这么办有什么…
使用Seata版本:1.6.1(2023/2/6最新版)该版本存在很多坑,相较于1.0版本,配置上存在很多差别,如果你的版本不同,请不要参考本文. 1.6.1配置存在许多问题,比较难找,如果你使用1.6.1可以参考本工程,本文工程功能已正常跑通. 本文章的代码工程:zko0/cloudStudy: Springcloud学习工程 (github.com) 1.介绍 ①问题 一个事务需要跨多个数据源或系统进行远程调用,就会产生分布式事务问题 微服务应用的架构图: 单体应用被拆分为微服务应用,原来三…
1. SpringCloud Alibaba简介 1.1 为什么会出现SpringCloud Alibaba Spring Cloud Netflix项目进入到维护模式 什么是维护模式?=> 将模块置于维护模式,意味着Spring Cloud团队将不会再向模块添加新功能(我们将修复block级别的bug以及安全问题,我们也会考虑并审查社区的小型pull request). 进入维护模式意味着?=> SpringCloud Netflix将不再开发新的组件.新组件功能将以其他替代品代替的方法实现…
SpringCloud Alibaba (三):Sentinel 流量控制组件 Sentinel 是什么 随着微服务的流行,服务和服务之间的稳定性变得越来越重要.Sentinel 是面向分布式服务架构的流量控制组件,主要以流量为切入点,从限流.流量整形.熔断降级.系统负载保护.热点防护等多个维度来帮助开发者保障微服务的稳定性. Sentinel 基本概念 资源 资源是 Sentinel 的关键概念.它可以是 Java 应用程序中的任何内容,例如,由应用程序提供的服务,或由应用程序调用的其它应用提…
1.存储设计 在上一章中,我们已经完成了基本业务流程的梳理和服务模块的划分,接下来,开始设计数据存储. 虽然在微服务的理论中,没有对数据库定强制性的规范,但一般,服务拆分之后,数据库也会对应的拆分. 这种结合业务来进行拆分的方式是数据库拆分中的垂直拆分. 数据库设计偷个懒,就不再用比较重的Power Designer,直接拿Navicat开干. 根据服务的拆分,分别建立数据库如下: 用户库(shop_user): 建表语句: SET NAMES utf8mb4; SET FOREIGN_KEY_…
10.1 分布式事务基础 10.1.1 事务 事务指的就是一个操作单元,在这个操作单元中的所有操作最终要保持一致的行为,要么所有操作都成功,要么所有的操作都被撤销.简单地说,事务提供一种"要么什么都不做,要么做全套"机制. 10.1.2 本地事物 本地事物其实可以认为是数据库提供的事务机制.说到数据库事务就不得不说,数据库事务中的四大特性: A:原子性(Atomicity),一个事务中的所有操作,要么全部完成,要么全部不完成 C:一致性(Consistency),在一个事务执行之前和执…