前言
这两年,tomcat慢慢在新项目里不怎么接触了,因为都被spring boot之类的框架封装进了内部,成了内置server,不用像过去那样打个war包,再放到tomcat里部署了。
但是,内部的机制我们还是有必要了解的,尤其是线程模型和classloader,这篇我们会聚焦线程模型。
其实我本打算将一个问题,即大家知道,我们平时最终写的controller、service那些业务代码,最终是由什么线程来执行的呢?
大家都是debug过的人,肯定知道,线程名称大概如下:
http-nio-8080-exec-2@5076
这个线程是tomcat的线程,假设,我们在这个线程里,sleep个1分钟,模拟调用第三方服务时,第三方服务异常卡住不返回的情况,此时客户端每秒100个请求过来,此时整个程序会出现什么情况?
但是我发现,这个问题,一篇还是讲不太清楚,因此,本篇只讲一下线程模型。
主要线程模型简介
大家可以思考下,一个服务端程序,有哪些是肯定需要的?
我们肯定需要开启监听对吧,大家看看下面的bio程序:
![896fb43ea708b84399e3d452836f32a6.png](https://img-blog.csdnimg.cn/img_convert/896fb43ea708b84399e3d452836f32a6.png)
这个就是个线程,在while(true)死循环里,一直accept客户端连接。
ok,这个线程肯定是需要的。接下来,再看看还是否需要其他的线程。
如果一切从简,我们只用这1个线程也足够了,就像redis一样,redis都是内存操作,做啥都很快,还避免了线程切换的开销;
但是我们的java后端,一般都要操作数据库的,这个是比较慢,自然是希望把这部分工作能够交给单独的线程去做,在tomcat里,确实是这样的,交给了一个线程池,线程池里的线程,就是我们平时看到的,名称类似http-nio-8080-exec-2@5076这样的,一般默认