专注于 JetBrains IDEA 全家桶,永久激活,教程
持续更新 PyCharm,IDEA,WebStorm,PhpStorm,DataGrip,RubyMine,CLion,AppCode 永久激活教程

# Spring Boot 实战系列 - 方法异步处理

一般在一个方法中需要处理多个任务,其中某些任务无关紧要(如发送短信、记录操作日志等),可以使用异步处理那些无关紧要的任务,从而提高整个请求的相应时间。下面演示使用 spring boot 快速开发方法异步处理

准备工作

  • pom.xml 依赖如下
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
    </dependency>
</dependencies>

  • UserController 代码如下
@RestController
public class UserController {

    @Autowired
    private UserService userService;

    @GetMapping("/users/{id}")
    public UserDTO get(@PathVariable("id") Long id) {
        return userService.getById(id);
    }
}

  • UserService 相关代码如下
// 接口定义
public interface UserService {

    UserDTO getById(Long id);
}

// 接口实现
@Slf4j
@Service
public class UserServiceImpl implements UserService {

    @Autowired
    private LogService logService;

    @Override
    public UserDTO getById(Long id) {

        log.info("查询用户");
        UserDTO userDTO = new UserDTO();
        userDTO.setId(id);

        log.info("记录操作日志");
        logService.save();

        return userDTO;
    }
}

  • LogService 相关代码如下
// 接口定义
public interface LogService {

    void save();
}

// 接口实现
@Slf4j
@Service
public class LogServiceImpl implements LogService {

    @Async("logServiceExecutor") // @Async 表示该方法异步执行,"logServiceExecutor"用来指定线程池实例
    @Override
    public void save() {

        log.info("{},{},记录日志, start", Integer.toHexString(Thread.currentThread().hashCode()), Thread.currentThread().getName());
        try {
            // 休眠3秒,异步效果更明显
            Thread.sleep(3000);
        } catch (Exception e) {
            e.printStackTrace();
        }
        log.info("{},{},记录日志, end.", Integer.toHexString(Thread.currentThread().hashCode()), Thread.currentThread().getName());
    }
}

  • 线程池配置代码如下
@Slf4j
@EnableAsync
@Configuration
public class ExecutorConfig {

    @Bean("logServiceExecutor")
    public Executor logServiceExecutor() {

        log.info("启动 Log Service Executor");

        ThreadPoolExecutor executor = new ThreadPoolExecutor(3, 10,
                5L, TimeUnit.SECONDS,
                new ArrayBlockingQueue<>(512),
                new CustomizableThreadFactory("save-log-thread-"),
                new ThreadPoolExecutor.DiscardPolicy());

        return executor;
    }
}

总结

  • 从代码可以看出,一共增加了两部分代码
    • 1、线程池配置代码(注意要加上 @EnableAsync 注解,使异步生效)
    • 2、LogServiceImplsave 方法增加了 @Async("logServiceExecutor") 注解
  • 通过如上两步,简单快捷实现方法异步处理,并且线程池与业务隔离

本文完。

文章永久链接:https://tech.souyunku.com/47526

未经允许不得转载:搜云库技术团队 » # Spring Boot 实战系列 - 方法异步处理

JetBrains 全家桶,激活、破解、教程

提供 JetBrains 全家桶激活码、注册码、破解补丁下载及详细激活教程,支持 IntelliJ IDEA、PyCharm、WebStorm 等工具的永久激活。无论是破解教程,还是最新激活码,均可免费获得,帮助开发者解决常见激活问题,确保轻松破解并快速使用 JetBrains 软件。获取免费的破解补丁和激活码,快速解决激活难题,全面覆盖 2024/2025 版本!

联系我们联系我们