SpringCloud-Alibaba之Seata入门以及踩坑(二)

本文详细解析了一线大厂Java面试中涉及的分布式事务框架Seata的应用,包括配置、服务交互、异常处理和Feign降级问题的解决方案。作者强调了实践中遇到的问题及应对策略,为面试者提供学习和准备参考。
摘要由CSDN通过智能技术生成

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!
图片

项目新建undo_log表

每个微服务项目有独立的数据库,则需要在库中创建undo_log表

图片

微服务项目中引入mybatis-plus操作数据库,这里老顾就不介绍了。

微服务配置

我们聚焦到seata相关上面;上文中我们seata-server服务是结合nacos的。

我们在rb-order-server、rb-account-server、rb-storage-server3个服务的application.yml配置文件中,都要配置相关seata的配置。

图片

上面的配置比较容易理解,有几个地方很重要:

1)enable-auto-data-source-proxy

这个配置就是启动自动开启数据源代理。

2)tx-service-group:seata_test_tx_group

这个是事务分组,项目的微服务都要配置一样的事务分组,并且要和上文中的seata-server的service.vgroupMapping.seata_test_tx_group=default一致。

数据库代理

因为seata采用了DataSource代理方式操作数据,所以在springboot项目中先要排除datasource初始化,这样yml文件中的seata.enable-auto-data-source-proxy: true 自动代理才会生效。如何排除也是比较简单,三个服务都要排除,启动自动数据库代理。

图片

以上client准备工作就结束了。

Feign调用

因为order服务中要调用account服务、storage服务,所以order中需要引入feign调用,如果把三个服务加入注册中心,能够互动调用;老顾这里就不介绍了,小伙伴们可以看老顾的以前的文章。

图片

图片

我们在来看看各个服务的具体实现。

项目服务代码

库存服务

图片

图片

上面的代码,能够发现如果下单的时候超过库存数,就会抛异常;

用户服务

图片

图片

上面的代码,如果扣减的金额超过用户金额时,就抛异常;

订单服务

图片

图片

上面的订单服务代码中,我们发现引入了@GlobalTransactional;对的,就是加入了@GlobalTransactional这个注解,就实现了分布式事务,简单吧。

我们可以启动postman,请求count参数为1的话,查看业务数据库数据都正常。对应的库存减少了1,金额减少了100,订单成功插入。

图片

图片

图片

如果我们传入的count参数大于库存数,库存服务就会抛异常,那库存服务就会执行失败,这样订单服务,用户服务也会回滚。这样就起到了分布式事务作用。

感觉到这里,小伙伴们是不是感觉seata的强大,这个就是seata推荐的AT模式。

Feign降级坑

在我们微服务使用中,一旦微服务产生异常,我们都会用到降级的功能;如在调用库存服务的时候引入sentinel降级,这个知识老顾之前就介绍过,小伙伴们可以查看之前的文章。

图片

图片

图片

spring:
cloud:
sentinel:
transport:
dashboard: 127.0.0.1:8080
feign:
sentinel:
enabled: true

这样对库存服务的降级处理是实现了,这也是正常的微服务的使用。

但是这样的处理,seata就会失效;我们发现count参数大于库存时,库存服务报异常,但因为有降级处理,订单还是提交了订单数据,用户金额还是减少了。事务不起作用了。

解决方式

官方推荐的方法,就是利用aop方式,手动处理全局事务回滚,我们在库存服务中加入aop

图片

从上述代码中,我们用容易发现,如果执行的service中出现异常,就手动实现全局事务rollback。这样就解决了Feign的降级的问题。

注意:上面的aop代码中,before、after方法中,可以结合自身的业务 本案例中库存服务,只在抛异常的时候做了处理

总结

seata的分布式事务使用起来是非常简单的,但是seata的使用会对现有项目中产生一些意外的错误,但是都可以得到相应的解决;需要小伙伴去实践。谢谢!!!

结局:总结+分享

看完美团、字节、腾讯这三家的一二三面试问题,是不是感觉问的特别多,可能咱们真的又得开启面试造火箭、工作拧螺丝的模式去准备下一次的面试了。

开篇有提及我可是足足背下了Java互联网工程师面试1000题,多少还是有点用的呢,换汤不换药,不管面试官怎么问你,抓住本质即可!能读到此处的都是真爱

  • Java互联网工程师面试1000题

image.png

而且从上面三家来看,算法与数据结构是必备不可少的呀,因此我建议大家可以去刷刷这本左程云大佬著作的 《程序员代码面试指南 IT名企算法与数据结构题目最优解》,里面近200道真实出现过的经典代码面试题。

  • 程序员代码面试指南–IT名企算法与数据结构题目最优解

image.png

  • 其余像设计模式,建议可以看看下面这4份PDF(已经整理)

image.png

  • 更多的Java面试学习笔记如下,关于面试这一块,我额外细分出Java基础-中级-高级开发的面试+解析,以及调优笔记等等等。。。

image.png

以上所提及的全部Java面试学习的PDF及笔记,如若皆是你所需要的,那么都可发送给你!

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!
0439225)]

以上所提及的全部Java面试学习的PDF及笔记,如若皆是你所需要的,那么都可发送给你!

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值