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

Spring在业务中常见的使用方式

目录

通过IOC实现策略模式

通过AOP实现拦截

通过Event异步解耦

通过Spring管理事务


  • 通过IOC实现策略模式

  • 很多时候,我们需要对不同的场景进行不同的业务逻辑处理
  • 举个例子,譬如不同的场景需要不同支付方式,普通的逻辑是使用if-else,如下所示:

  • 如果sence越来越多,这种if-else显然非常不合适,这就需要我们借助Spring来完成策略模式

  • 这样调用方只需要调用Payfactory#get即可,不需要感知内部的实现细节和逻辑
  • 需要说明的是,这里使用了InitializingBean只是实现方式之一,还有其他的实现方式,如通过Autowired注解,BeanPostProcess等,这里不做过多赘述
  • 通过AOP实现拦截

  • 很多时候,我们一般是通过注解和AOP相结合
  • 大概的实现思路就是先定义一个注解,然后通过AOP去发现使用过该注解的类,对该类的方法进行代理处理,增加额外的逻辑,譬如参数校验,缓存,日志打印等等,如下代码所示:
  • 参数校验

  • 缓存逻辑

  • 日志打印

  • 通过Event异步解耦

  • 很多时候,可能一个单据状态的改变,要触发很多下游的行为
  • 举个例子:订单从确认订单变为支付成功,就要触发物流的发货,财务的记账,edm触达等等
  • 但是如果订单状态改变同步触发下游的动作,这样对订单业务非常不友好,下游的每次变动都需要上游感知
  • 所以,对于这种情况,我们就需要Event异步解耦
  • 具体说就是订单状态改变后,可以发出来一个Event事件,下游只感知这个Event事件,如果监听到这个事件,就去做自己对应的业务处理;如下代码所示:

  • 需要注意的是,SpringEvent有同步模式和异步模式,这里可以根据具体的业务进行配置
  • 通过Spring管理事务

  • Spring的事务抽象了下游不同DataSource的实现(如,JDBC,Mybatis,Hibernate等),让我们不用再关心下游的事务提供方究竟是谁,直接启动事务即可
  • 如下代码所示:

  • 但是,我们在使用事务的时候,一定要注意,不能在事务中处理分布式缓存,RPC等操作,这样做有两个坏处,一个是RPC的RT很长,有可能引起长事务的问题,另一方面是如果事务执行失败进行回滚,RPC操作的调用是无法回滚的,当然对于声明式的事务也不能滥用,它有可能会导致一些问题
http://www.lryc.cn/news/187524.html

相关文章:

  • PyTorch 深度学习实战
  • 学生用RockyLinux9.2模板虚拟机说明
  • BUUCTF reverse3 1
  • 关于webWorker未解问题
  • 自然语言处理(NLP)的开发框架
  • Spring Boot与Kubernetes结合:构建高可靠、高性能的微服务架构
  • Qt自带的日志重定向机制
  • 笔记36:CNN的多通道卷积到底是什么样的
  • 【eigen】解决报错 return type of RCmpEQReturnType Eigen::operator== is not ‘bool’
  • QT 实现mysql的长连接
  • Vue 使用 setup 语法糖
  • Feign(替代RestTemplate)远程调用
  • 查找算法 —— 斐波拉契查找法
  • PL/SQL全量同步
  • IO类型游戏研发定制开发
  • Eclipse iceoryx(千字自传)
  • 竞赛 深度学习 opencv python 公式识别(图像识别 机器视觉)
  • Pikachu靶场——跨站请求伪造(CSRF)
  • 软件测试简历项目经验怎么写?大厂面试手拿把掐
  • 图像处理与计算机视觉--第七章-神经网络-单层感知器
  • pyserial,win11,串口总是被占用
  • 网站上线如何检查?
  • 如何理解pytorch中的“with torch.no_grad()”?
  • Linux虚拟机克隆之后使用ip addr无法获取ip地址
  • 日报系统:优化能源行业管理与决策的利器
  • linux安装idea
  • vue启动项目,npm run dev出现error:0308010C:digital envelope routines::unsupported
  • vue-devtools插件安装
  • const关键字
  • HTML5+CSS3+JS小实例:仿优酷视频轮播图