springboot 整合 seata的配置过程
作者:秋叶清风 发布时间:2023-01-13 01:28:33
前言:
小编引入的图片和文字描述都是来自于尚硅谷的视频讲解,在此感谢尚硅谷的老师,同时也结合 seata文档官方文档进行整合
项目地址(gitee): https://gitee.com/qinenqi/online
springboot整合 seata
1.整合配置
online-project 这个服务调用 online-coupon这个服务
在 这两个被整合的服务对用的数据库中分别 创建 UNDO_LOG 表
-- 注意此处0.3.0+ 增加唯一索引 ux_undo_log
CREATE TABLE `undo_log` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`branch_id` bigint(20) NOT NULL,
`xid` varchar(100) NOT NULL,
`context` varchar(128) NOT NULL,
`rollback_info` longblob NOT NULL,
`log_status` int(11) NOT NULL,
`log_created` datetime NOT NULL,
`log_modified` datetime NOT NULL,
`ext` varchar(100) DEFAULT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `ux_undo_log` (`xid`,`branch_id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
2. 引入依赖
<!-- seata -->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-seata</artifactId>
</dependency>
小编这儿已经引入了 阿里的相关组件,请根据自己的实际情况进行处理
<!-- 服务注册/发现-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<!-- 配置中心来做配置管理-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
引入依赖后,查看自己的 seata-all-0.7.1,要根据这个版本下载相应的seata 服务器
4.下载对应的服务器软件包
下载地址:seata下载地址,小编下载是seata-server-0.7.1,下载完成之后解压文件
5.修改配置文件
进入 conf文件夹,修改registry.conf
在注册中, 小编配置的是nacos, 把type = “file” 改成 type = “nacos”,
在配置信息中,小编用的是默认的文件方式
6.在online-coupon、online-project 新建 MySeataConfig
import com.zaxxer.hikari.HikariDataSource;
import io.seata.rm.datasource.DataSourceProxy;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.jdbc.DataSourceProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.util.StringUtils;
import javax.sql.DataSource;
@Configuration
public class MySeataConfig {
@Autowired
DataSourceProperties dataSourceProperties;
@Bean
public DataSource dataSource(DataSourceProperties dataSourceProperties){
HikariDataSource dataSource = dataSourceProperties.initializeDataSourceBuilder().type(HikariDataSource.class).build();
if (StringUtils.hasText(dataSourceProperties.getName())) {
dataSource.setPoolName(dataSourceProperties.getName());
}
return new DataSourceProxy(dataSource);
}
}
7.分别引入配置文件
(file.conf、registry.conf)并修改 vgroup_mapping.my_test_tx_group = “default”
把这两个配置文件从conf文件夹下复制到项目的resources目录下,分别修改file.conf,把vgroup_mapping.my_test_tx_group = "default"分别修改成vgroup_mapping.online-coupon-fescar-service-group = "default"和 vgroup_mapping.online-project-fescar-service-group = “default”
8.启动nacos 和 seata 服务(startup.cmd、seata-server.bat)
服务启动以后,访问 http://127.0.0.1:8848/nacos/, 可以看到 seata的服务
9.给分布式大事务的入口标注@GlobalTransactional、每一个远程的小事务用 @Transactional
10.具体业务:
在 online-project服务的ProjectController中
/**
* 根据 id 更新数据
* @param project
* @return
*/
@PostMapping("/updateProjectById")
public R updateProjectById(@RequestBody Project project){
projectService.updateProjectById(project);
return R.ok();
}
在 CouponServiceImpl中
/**
* 从 商品哪儿调用 用来测试 seata
*/
@Transactional
public void testSeata(){
CouponEntity couponEntity = new CouponEntity();
couponEntity.setId(4L);
couponEntity.setCouponName("从 商品哪儿调用 用来测试 seata02");
couponMapper.updateById(couponEntity);
// int number = 2/0;
}
在online-coupon服务CouponController中
/**
* 从 商品哪儿调用 用来测试 seata
* @return
*/
@RequestMapping("/testSeata")
public R testSeata(){
couponService.testSeata();
return R.ok();
}
新建 CouponFeignService
import com.example.onlinecommon.utils.R;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.RequestMapping;
@FeignClient("online-coupon")
public interface CouponFeignService {
@RequestMapping("/coupon/couponController/testSeata")
R testSeata();
}
在 CouponServiceImpl中
/**
* 从 商品哪儿调用 用来测试 seata
*/
@Transactional
public void testSeata(){
CouponEntity couponEntity = new CouponEntity();
couponEntity.setId(4L);
couponEntity.setCouponName("从 商品哪儿调用 用来测试 seata02");
couponMapper.updateById(couponEntity);
// int number = 2/0;
}
两个服务之间的调用使用的 openforeign,经过小编的测试,两个微服务实现了分布式事务的一致性
来源:https://blog.csdn.net/weixin_41695138/article/details/119831809


猜你喜欢
- 最近做项目,ORM 使用的是 MyBatis,为了偷懒,我自然而然的想到了使用 MyBatis Generator(MBG)来生成数据库表对
- 由于最近想要阅读下JDK1.8 中HashMap的具体实现,但是由于HashMap的实现中用到了红黑树,所以我觉得有必要先复习下红黑树的相关
- rpc远程调用可能存在的问题超时的问题。安全的问题。服务与服务之间URL地址管理。在我们的微服务架构通讯,服务之间依赖关系非常大,如果通过传
- @Scheduled多个任务同时开始执行只需在springBoot启动类上添加如下代码即可:@Bean publi
- 本文实例讲述了Android编程实现调用相册、相机及拍照后直接裁剪的方法。分享给大家供大家参考,具体如下:package com.cvte.
- 有些SIM卡在出厂时并没有预置VoiceMail number,但运营商又要求能够根据PLMN去自适应的从手机中读取到预设的VM numbe
- 本文实例讲述了Android游戏开发学习①弹跳小球实现方法。分享给大家供大家参考。具体如下:在学习了一点点Android之后,觉得有必要记录
- 概述冒泡排序是一种简单的排序算法。它重复地走访要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行
- 之前从他人的博文,还有一些书籍中了解到 常量是放在常量池 中,细节的内容无从得知,总觉得面前的东西是一个几乎完全的黑盒,总是觉得不舒服,于是
- 话不多说,请看下面//C# 代码int year = DateTime.Now.Year;int month = DateTime.Now.
- 先对问题进行描述:(1)在MyEclipse Servers视图在MyEclipse 10.7.0在某些情况下,可能无法打开。 试图打开视图
- 在之前讨论 ListView 滚动相关需求的文章中(UWP: ListView 中与滚动有关的两个需求的实现)曾经提到了获取元素相对位置的方
- 我们今天来聊下如何做实时通讯(先给知识点,实现原理,最后给出实现实时通信的具体代码--使用工具 android studio)现在先说下用到
- 本文实例为大家分享了android通过usb读取U盘的具体代码,供大家参考,具体内容如下1.关联 compile ‘com.github.m
- 1.代码:import java.math.BigDecimal;import java.text.DecimalFormat;import
- ArrayList底层维护的是一个动态数组,每个ArrayList实例都有一个容量。该容量是指用来存储列表元素的数组的大小。它总是至少等于列
- 理解C#中的闭包1、 闭包的含义首先闭包并不是针对某一特定语言的概念,而是一个通用的概念。除了在各个支持函数式编程的语言中,我们会接触到它。
- 文件比较平常都是用Beyond Compare,可以说离不开的神器,特别是针对代码比较这块,确实挺好用的。不过Beyond Compare平
- 用途项目中使用了 dubbo,注册中心使用的 zookeeper,使用 zookeeper 实现了一个简单的分布式锁(依赖 curator)
- @ConfigurationProperties注入创建一个新的模板此过程就不在这介绍了,在我SpringBoot专栏里有详细过程。⭐⭐⭐注