异步处理REST服务

本文探讨了REST服务中的异步处理,包括使用Runnable和DeferredResult两种方式。通过实例解释了如何利用它们实现主线程与副线程的解耦,确保在处理业务逻辑时,主线程仍能接受新的HTTP请求。异步处理有助于提高系统并发能力,避免线程池资源耗尽。文中还详细介绍了异步处理的运行流程和配置方法。
摘要由CSDN通过智能技术生成

在这里插入图片描述
一个http请求进来tomcat获取其他中间件会有一个线程来处理http请求 ,然后给出一个httpx响应,这是同步处理的方式,
但我们知道像tomcat或中间件这种会有线程数量的限制,当线程数量到达一定程度后,再有请求进来tomcat就无法处理。
对于异步处理,当一个http请求进来以后,tomcat的主线程来调取一个副线程来处理业务逻辑,当副线程处理完后,主线程再返回http响应。在副线程处理业务逻辑中,主线程被空闲处理可以继续处理其他http请求

使用Runnable 异步处理REST服务

先看同步处理

在这里插入图片描述

package com.whale.web.async;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class AsyncComtroller{
   

    private Logger logger = LoggerFactory.getLogger(getClass());


    @RequestMapping("/order")
    public String order() throws InterruptedException {
   
        //同步处理的方式 
        logger.info("主线程开始");
        Thread.sleep(1000);
        logger.info("主线程返回");
        return "success";
    }
}

访问 http://127.0.0.1:8080/order
在这里插入图片描述

异步处理


    @RequestMapping("/order")
    public Callable<String>  order() throws InterruptedException {
   
        logger.info("主线程开始");

        Callable<String> result = new Callable<String
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值