当前位置: 首页 > news >正文

购物网站哪个是正品百度贴吧首页

购物网站哪个是正品,百度贴吧首页,网站建设方案书模版,罗湖做网站哪家好文章目录 分布式事务问题示例Seata概述、官网一个典型的分布式事务过程处理过程全局GlobalTransactional分布式交易解决方案流程图 Seata安装下载修改conf目录下的application.yml配置文件dashboard demo 分布式事务问题示例 单体应用被拆分成微服务应用,原来的三个…

文章目录

  • 分布式事务问题示例
  • Seata概述、官网
    • 一个典型的分布式事务过程
    • 处理过程
    • 全局@GlobalTransactional
    • 分布式交易解决方案流程图
  • Seata安装
    • 下载
    • 修改conf目录下的application.yml配置文件
    • dashboard
  • demo

分布式事务问题示例

单体应用被拆分成微服务应用,原来的三个模块被拆分成三个独立的应用,分别使用三个独立的数据源,
业务操作需要调用三个服务来完成。此时每个服务内部的数据一致性由本地事务来保证,但是全局的数据一致性问题没法保证。
在这里插入图片描述

Seata概述、官网

官网
http://seata.io/zh-cn/
下载
https://github.com/seata/seata/releases

一个典型的分布式事务过程

分布式事务处理过程的一ID+三组件模型

  • Transaction ID XID:全局唯一的事务ID;
  • Transaction Coordinator (TC):事务协调器,维护全局事务的运行状态,负责协调并驱动全局事务的提交或回滚;
  • Transaction Manager ™:控制全局事务的边界,负责开启一个全局事务,并最终发起全局提交或全局回滚的决议;
  • Resource Manager (RM):控制分支事务,负责分支注册、状态汇报,并接收事务协调器的指令,驱动分支(本地)事务的提交和回滚;

处理过程

  1. TM 向 TC 申请开启一个全局事务,全局事务创建成功并生成一个全局唯一的 XID;
  2. XID 在微服务调用链路的上下文中传播;
  3. RM 向 TC 注册分支事务,将其纳入 XID 对应全局事务的管辖;
  4. TM 向 TC 发起针对 XID 的全局提交或回滚决议;
  5. TC 调度 XID 下管辖的全部分支事务完成提交或回滚请求。
    在这里插入图片描述

全局@GlobalTransactional

相较于Spring的注解@Transactional

分布式交易解决方案流程图

在这里插入图片描述

Seata安装

下载

版本1.7
https://github.com/seata/seata/releases

修改conf目录下的application.yml配置文件

  1. 先备份原始application.yml文件
  2. 主要修改:自定义事务组名称+事务日志存储模式为db+数据库连接信息(示例参考application.example.yml)
  3. 建表sql在script/server/db

dashboard

http://localhost:7091/
默认7091端口
切换中文
在这里插入图片描述

demo

@GlobalTransactional(name = “fsp-create-order”,rollbackFor = Exception.class)
name自己取,唯一就可,rollbackFor异常抛出,

  • 未加该注释出现的问题:示例中 accountService.decrease(order.getUserId(),order.getMoney());调用不成功但是会继续修改订单状态并且会减少账户中值
//Service全都使用Feign可设置Time.Sleep来模拟Feign调用不成功
//示例中
//@GlobalTransactional(name = "fsp-create-order",rollbackFor = Exception.class)
public void create(Order order)
{log.info("----->开始新建订单");//1 新建订单orderDao.create(order);//2 扣减库存log.info("----->订单微服务开始调用库存,做扣减Count");storageService.decrease(order.getProductId(),order.getCount());log.info("----->订单微服务开始调用库存,做扣减end");//3 扣减账户log.info("----->订单微服务开始调用账户,做扣减Money");accountService.decrease(order.getUserId(),order.getMoney());log.info("----->订单微服务开始调用账户,做扣减end");//4 修改订单状态,从零到1,1代表已经完成log.info("----->修改订单状态开始");orderDao.update(order.getUserId(),0);log.info("----->修改订单状态结束");log.info("----->下订单结束了,O(∩_∩)O哈哈~");}
//模拟Feign调用不成功示例,Feign默认超时1秒不成功
public void decrease(Long userId, BigDecimal money) {LOGGER.info("------->account-service中扣减账户余额开始");//模拟超时异常,全局事务回滚//暂停几秒钟线程try { TimeUnit.SECONDS.sleep(20); } catch (InterruptedException e) { e.printStackTrace(); }accountDao.decrease(userId,money);LOGGER.info("------->account-service中扣减账户余额结束");
}
http://www.dinnco.com/news/57671.html

相关文章:

  • 宝鸡做网站的系统优化软件
  • 京东商城网站怎么做企业培训课程清单
  • 我自己做的网站一直没有效果怎么办搜索排名竞价
  • 未备案的网站杭州网站设计
  • 商务网站建设总结小程序设计
  • 什么网站可以做推广搜索引擎优化的基本方法
  • 做电影资源网站有哪些必应搜索引擎首页
  • 企业网站改版广州网站设计建设
  • 十大素材网站小红书怎么推广
  • 最流行的网站开发爱站网官网查询域名
  • 建网站用什么软件好seo 关键词优化
  • 网站宣传单页内容营销培训心得体会
  • 四川冠辰网站建设百度平台营销
  • php电影网站开发网站提交入口
  • 网站怎么做修改竞价代运营公司
  • 最近中文字幕在线mv免费宁波seo教程app推广
  • 加快网站速度吗seo标题关键词怎么写
  • 闲鱼网站做交易是先付款吗百度快速查询
  • 宝安网站制作公司简述什么是网络营销
  • 重庆网站建设 吧b站推广链接
  • 时时彩票网站如何做成品网站源码的优化技巧
  • b2b2c网站建设方案游戏推广员拉人犯法吗
  • 一级a做爰片免费网站无毒如何推广店铺呢
  • 邯郸建移动网站费用新冠疫情最新数据
  • 网站浏览器兼容测试平面设计培训班学费一般多少
  • 做网站开发学什么软件百度推广首页
  • 怎样让网站做301处理深圳网络优化推广公司
  • 网站信息维护方案网络软文范例
  • 青岛栈桥景点介绍东莞百度推广优化
  • 做网站职校选什么专业网络广告销售