JavaWeb之异步处理

异步处理

在Servlet3.0版本中引入了异步处理的功能,使线程可以返回到容器,从而执行更多的任务

使用AysncContext来进行异步操作

java 复制代码
public interface ServletRequest {

    // 使用原始请求和响应对象用于异步处理
    public AsyncContext startAsync() throws IllegalStateException;
 
    // 将请求转换为异步模式,并使用给定的请求和响应对象初始化,可以使用ServletRequestWrapper和ServletResponseWrapper
    public AsyncContext startAsync(ServletRequest servletRequest,
                                   ServletResponse servletResponse)
            throws IllegalStateException;
   
    // 检测请求是否为异步模式,使用原始请求和响应对象进行处理
    public boolean isAsyncStarted();

    // 是否支持异步处理
    public boolean isAsyncSupported();

    // 返回由startAsync调用创建的AsyncContext
    public AsyncContext getAsyncContext();

}



public interface AsyncContext {
    // AsyncContext中的请求响应进行分派
    void dispatch();

    // 分派到指定资源
    void dispatch(String path);

    // 分派到指定资源
    void dispatch(ServletContext context, String path);
		// 完成异步操作,并结束与这个异步上下文的关联的响应,在异步上下文中写入响应对象之后调用该方法
    void complete();
		// 容器提供了一个不同的线程,在该线程中处理阻塞操作
    void start(Runnable run);
		// 注册监听器用于接收 onTimeout、onError(用于通知监听器在Servlet上启动的异步操作未能完成)、onComplete(用于通知监听器在Servlet上启动的异步操作完成了)、onStartAsync(用于通知监听器正在通过调用一个ServletRequest.startAsync方法启动一个新的异步周期)通知
    void addListener(AsyncListener listener);

    void addListener(AsyncListener listener, ServletRequest request,
            ServletResponse response);
}

要在servlet上启用异步处理,需要配置asyncSupported为true

以tomcat为例,看一下异步是怎么处理的

java 复制代码
@Override
public AsyncContext startAsync() {
    return startAsync(getRequest(),response.getResponse());
}

@Override
public AsyncContext startAsync(ServletRequest request,
        ServletResponse response) {
  // 先判断asyncSupported是否为ture
    if (!isAsyncSupported()) {
        IllegalStateException ise =
                new IllegalStateException(sm.getString("request.asyncNotSupported"));
        log.warn(sm.getString("coyoteRequest.noAsync",
                StringUtils.join(getNonAsyncClassNames())), ise);
        throw ise;
    }

    if (asyncContext == null) {
        asyncContext = new AsyncContextImpl(this);
    }

    asyncContext.setStarted(getContext(), request, response,
            request==getRequest() && response==getResponse().getResponse());
    asyncContext.setTimeout(getConnector().getAsyncTimeout());

    return asyncContext;
}

zhhll.icu/2021/javawe...

本文由mdnice多平台发布

相关推荐
Mahir081 小时前
Spring 循环依赖深度解密:从问题本质到三级缓存源码级解析
java·后端·spring·缓存·面试·循环依赖·三级缓存
RyFit3 小时前
SpringAI 常见问题及解决方案大全
java·ai
石山代码3 小时前
C++ 内存分区 堆区
java·开发语言·c++
绝知此事3 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
无风听海3 小时前
C# 隐式转换深度解析
java·开发语言·c#
一只大袋鼠4 小时前
Git 进阶(二):分支管理、暂存栈、远程仓库与多人协作
java·开发语言·git
德思特5 小时前
从 Dify 配置页理解 RAG 的重要参数
java·人工智能·llm·dify·rag
YOU OU5 小时前
Spring IoC&DI
java·数据库·spring
один but you5 小时前
从可变参数到 emplace:现代 C++ 性能优化的核心组合
java·开发语言
是码龙不是码农6 小时前
ThreadPoolExecutor 7 个核心参数详解
java·线程池·threadpool