springboot的事务处理,ApplicationEvent的应用

1.ApplicationEvent的应用

在springboot项目中,ApplicationEvent的应用会和切面AOP相结合,做一些本身功能以外的事务处理,例如数据同步,在自己系统中,新建只需要将自己的数据插入数据库,而同步数据到另一个系统中就是额外的事务,还能做一些操作验证的事务。最关键是,当一个事件发布(注册),可以被多个监听器监听,执行事务逻辑。

2.ApplicationEvent的使用

2.1基础ApplicationEvent

首先我们需要继承ApplicationEvent,将该事务所需的参数封装在一个实体里。
代码示例:


@Slf4j
@Setter
@Getter
public class TempDocumentEvent extends ApplicationEvent {
    
    private String eventName;
    
    private String concent;

    //能够避免在多线程使用时候,改变ThreadLocal里的内容不会改变,子线程使用时候,get,set,就不是单独一个ThreadLocal,里面的内容可以让多人同时get,set
    public static ThreadLocal<Map<Object, Object>> documentEntityLocal = new InheritableThreadLocal<Map<Object, Object>>();

    public TempDocumentEvent(Object source, String eventName,String concent;) {
        super(source);
        this.eventName = eventName;
        this.concent = concent;
    }
}

2.2监听器的使用

首先还是要了解相关的注解:
1.注解TransactionalEventListener:这是一个springboot4.2版本以上才能使用的注解,这个注解有几个值可以从源码来看一下:一开始我是从源码的注释复制起来翻译的,但觉得不太好,就从网上找到了比较好的说明。

// @since 4.2  显然,注解的方式提供得还是挺晚的,而API的方式第一个版本就已经提供了
// 另外最重要的是,它头上有一个注解:`@EventListener`  so  
@Target({ElementType.METHOD, ElementType.ANNOTATION_TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@EventListener //有类似于注解继承的效果
public @interface TransactionalEventListener {
    // 这个注解取值有:BEFORE_COMMIT、AFTER_COMMIT、AFTER_ROLLBACK、AFTER_COMPLETION
    // 各个值都代表什么意思表达什么功能,非常清晰~
    // 需要注意的是:AFTER_COMMIT + AFTER_COMPLETION是可以同时生效的
    // AFTER_ROLLBACK + AFTER_COMPLETION是可以同时生效的
    TransactionPhase phase() default TransactionPhase.AFTER_COMMIT;

    // 若没有事务的时候,对应的event是否已经执行  默认值为false表示  没事务就不执行了
    boolean fallbackExecution() default false;

    // 这里巧妙的用到了@AliasFor的能力,放到了@EventListener身上
    // 注意:一般我建议都需要指定此值,否则默认可以处理所有类型的事件  范围太广了
    @AliasFor(annotation = EventListener.class, attribute = "classes")
    Class<?>[] value() default {};
    @AliasFor(annotation = EventListener.class, attribute = "classes")
    Class<?>[] classes() default {};
    String condition() default "";
}

使用方式一:
直接使用上面注解,案例如下:classes的值是你要监听的事务类,fallbackExecution可以让事务没有注入时候开始执行

@Component
@Slf4j
public class ESUpdateEventListener {
    //监听有新事务注入,开始执行
    @TransactionalEventListener(fallbackExecution=true, classes=TempDocumentEvent.class)
    @Async
    @Order(0)//这里是注意注入的顺序,
    public void eventListener(TempDocumentEvent event) {
            //这里是自己的逻辑
            return;
        }
        //参数是list的
}

使用方式二:如果springboot的版本过低就只能继承ApplicationListener来实现onApplicationEvent方法

@Component
@Slf4j
public class ESUpdateEventListener implements ApplicationListener<TempDocumentEvent> {
    @Override
    public void onApplicationEvent(TempDocumentEvent event) {
        //这里是自己的逻辑
    }

    //参数是list的

}

2.3触发事务

在你需要该事务处理的方法里,注入
@Autowired
private ApplicationEventPublisher publisher;
然后使用
publisher.publishEvent(new TempDocumentEvent ());
就🆗了,publish的参数就是你自己的事务实体。

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TApplication.OnIdle   当应用程序变为空闲时,OnIdle事件发生。   使用OnIdle事件,可以写一个应用程序空闲时执行特定处理的事件处理程序。当应用程序不处理代码时,称为应用程序空闲。例如,当应用程序等待来自用户的输入时,应用程序为空闲。   TIdleEvent类型是OnIdle事件的类型,它指向一个应用程序空闲时运行的方法。TIdleEvent类型有一个布尔型参数Done,默认时该参数为True。若参数Done为True,当OnIdle事件返回时,调用Windows API WaitMessage函数。只有在应用程序消息队列中出现一个新消息时,WaitMessage函数才放弃对其他应用程序的控制。参数Done为False时,即使应用程序不忙,也不放弃对其他应用程序的控制。   当应用程序转移到空闲状态时,只调用一次OnIdle事件。除非参数Done设置为False,否则不连续调用OnIdle事件。将参数Done设置为False的应用程序,将消耗过多的CPU时间,从而影响整个系统性能。 在delphi中, 当在一个窗口上放置一个ApplicationEvents控件时,Application将会把所有的事件都转寄到ApplicationEvents; 也就是说,ApplicationEvents可以拦截到应用程序的全部事件,包括OnActivate\OnHelp\OnIdle\OnRestore\OnShortCut等等, 甚至可能通过OnMessage事件,在其中截取所有post到应用程序中所有窗口的消息,如WM_PAINT,WM_KEYDOWN, WM_KEYUP等常见的windows消息; 所以当有消息到来的时候就会触发它的OnMessage事件,在OnMessage中监视消息就可以了。 Action的事件有OnExecute和OnUpdate,OnExecute事件在控制被触发时响应,比如说按钮被按下,菜单被按下,而OnUpdate事件是在应用程序空闲时被调用, APPLICATIONEVENTS是用来捕获程序级事件的 ApplicationEvents1Message(var Msg: tagMSG;var Handled: Boolean); {通过 Perform 向窗体发送 消息; OnMessage 收不到} {通过 SendMessage 向窗体发送 消息; OnMessage 收不到} {通过 PostMessage 向窗体发送  消息; OnMessage 可以收到}
SpringBoot事务是通过使用@EnableTransactionManagement注解在配置类上来开启声明式事务的支持。当使用了@EnableTransactionManagement后,Spring容器会自动扫描注解@Transactional的方法和类。在需要事务的类或方法上使用@Transactional注解即可,当注解在类上时,表示该类的所有public方法都开启事务。被注解的方法成为一个事务整体,共享一个数据库连接,所有操作同时发生。如果在事务内部发生异常,则事务整体会自动回滚。 SpringBoot中的事务隔离级别可以根据具体需要进行配置。事务隔离级别包括读未提交、读已提交、可重复读和串行化。可以通过在@Transactional注解中使用isolation属性来指定事务隔离级别。例如,@Transactional(isolation = Isolation.READ_COMMITTED)表示使用读已提交的事务隔离级别。 @Transactional事务注解由SpringBoot控制,它会在执行具体逻辑时激活事务控制。事务注解的原理是AOP,通过动态代理和反射动态加上事务控制的手动代码逻辑。具体的实现是在逻辑执行前后进行反射动态增强,以实现事务控制的功能。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [SpringBoot(八) SpringBoot中的事务](https://blog.csdn.net/qq_40772692/article/details/121476144)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [SpringBoot事务使用及回滚实现代码详解](https://download.csdn.net/download/weixin_38527978/12721854)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值