成功解决@Async注解不生效的问题,异步任务处理问题

首先,有这样一个异步监听方法

然后配置好了异步线程池

package com.fdw.study.config;


import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
import java.util.concurrent.ThreadPoolExecutor;


@ComponentScan(basePackages = {"com.fdw.study.event", "com.fdw.study.eventListener"})
@Configuration
public class EventConfig {

    //自定义线程池
    @Bean
    public ThreadPoolTaskExecutor asyncThreadPoolExecutor() {
        ThreadPoolTaskExecutor taskExecutor = new ThreadPoolTaskExecutor();
        // 核心线程数
        taskExecutor.setCorePoolSize(4);
        // 线程池维护线程的最大数量,只有在缓冲队列满了之后才会申请超过核心线程数的线程
        taskExecutor.setMaxPoolSize(20);
        // 缓存队列
        taskExecutor.setQueueCapacity(50);
        // 空闲时间,当超过了核心线程数之外的线程在空闲时间到达之后会被销毁
        taskExecutor.setKeepAliveSeconds(200);
        // 异步方法内部线程名称
        taskExecutor.setThreadNamePrefix("fdw-async-executor-");

        /**
         * 当线程池的任务缓存队列已满并且线程池中的线程数目达到maximumPoolSize,如果还有任务到来就会采取任务拒绝策略
         * 通常有以下四种策略:
         * ThreadPoolExecutor.AbortPolicy:丢弃任务,抛出RejectedExecutionException异常。
         * ThreadPoolExecutor.DiscardPolicy:丢弃任务,但不抛出异常。
         * ThreadPoolExecutor.DiscardOldestPolicy:丢弃队列最前面的任务,然后重新尝试重新执行任务。
         * ThreadPoolExecutor.CallerRunsPolicy:重试添加当前的任务,自动重复调用 execute() 方法,直到成功。
         */
        taskExecutor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
        taskExecutor.initialize();
        return taskExecutor;
    }

}

执行测试

package com.fdw.study.test;

import com.fdw.study.config.EventConfig;
import com.fdw.study.event.UserChangePasswordEvent;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;

public class EventTest {
    public static void main(String[] args) {
        ApplicationContext context = new AnnotationConfigApplicationContext(EventConfig.class);
        context.publishEvent(new UserChangePasswordEvent("145623"));

    }
}

发现还是走的main线程,没有实现异步

原因:后来发现是配置类缺少了**@EnableAsync**注解,加上后再测试

现在才是真的异步

相关推荐
zxctsclrjjjcph3 分钟前
【C语言】常见的C语言概念
c语言·开发语言
小灰灰爱代码8 分钟前
C++——求3个数中最大的数(分别考虑整数、双精度数、长整数的情况),用函数模板来实现。
开发语言·c++·算法
严文文-Chris11 分钟前
【设计模式-享元】
android·java·设计模式
Eiceblue14 分钟前
Python 复制Excel 中的行、列、单元格
开发语言·python·excel
项目題供诗18 分钟前
尚品汇-秒杀商品存入缓存、Redis发布订阅实现状态位(五十一)
开发语言·php
m0_7145902626 分钟前
汇编(实现C语言程序的调用)
c语言·开发语言·汇编
Flying_Fish_roe27 分钟前
浏览器的内存回收机制&监控内存泄漏
java·前端·ecmascript·es6
做技术的Pandaer30 分钟前
Go 第二期
开发语言·golang
新知图书30 分钟前
Rust编程的作用域与所有权
开发语言·后端·rust
c#上位机37 分钟前
C#事件的用法
java·javascript·c#