En el trabajo real, encontraremos algunas operaciones que consumen mucho tiempo. En este momento, si la respuesta no es oportuna, devolverá un error. Si desea realizar operaciones asincrónicas y devolver datos con un retraso, puede utilizar los siguientes métodos
Usar asyncSupported = true
anotaciones
@WebServlet(name = "apitest", asyncSupported = true)
Si no usa esta anotación, se informará un error durante el acceso
El siguiente es el código fuente
@WebServlet(name = "apitest", asyncSupported = true)
public class apitest extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request,response);
}
private volatile ExecutorService executorService;
@Override
public void init() throws ServletException {
super.init();
//newFixedThreadPool 创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。
executorService = Executors.newFixedThreadPool(100);
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
AsyncContext asyncCtx = request.startAsync();
executorService.submit(new Runnable() {
@Override
public void run() {
//延时5秒 ,模拟耗时操作
try {
Thread.sleep (5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
PrintWriter writer = null;
try {
writer = asyncCtx.getResponse().getWriter();
} catch (IOException e) {
e.printStackTrace();
}
//返回数据
writer.println("servlevt异步处理成功");
writer.flush();//记得关闭
asyncCtx.complete();//记得关闭
}
}, asyncCtx);
}
}
Reinicie Tomcat, acceda a la interfaz / apitest, puede ver que después de esperar 5 segundos, se devuelve el éxito del procesamiento asincrónico del servlevt. thread.sleep (), esto generalmente no es necesario, y las operaciones que consumen mucho tiempo se pueden escribir en aplicaciones reales.