- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
线程池调整真的很重要Java开发Java经验技巧.doc
线程池调整真的很重要-编程开发技术
线程池调整真的很重要
木文由ImportNew - justyoung翻译自o欢迎加入翻译小组。转载请见文末要 求。
知道吗,你的Java web应用其实是使用线程池來处理请求的。这一实现细节被 许多人忽略,但是你迟早都需要理解线程池如何使用,以及如何正确地根据应用 调整线程池配置。这篇文章的目的是为了解释线程模型——什么是线程池、以及 怎样正确地配置线程池。
单线程模型
让我们从一些基础的线程模型开始,然后再随着线程模型的演变进行更深一步的 学习。你使用的任何应用服务器或框架,如Tomcat、Dropwizard Jetty等,它 们的基木原理其实是相同的。Web服务器的最底层实际上是一个socketo这个 socket监听并接受到达的TCP连接。一旦一个连接被建立,就可以通过这个新 建立的连接读取、解析信息,然后将这些信息包装成一个IITTP请求。这个I1TTP 请求还将被移交至web应用程序,来完成请求的动作。
我们将通过一个简单的服务器程序来展示线程在其中所起到的作用。这个服务器 程序展示了大部分应用服务器的底层实现细节。让我们以一个简单?的单?线程web 服务器程序开始,它的代码像下面这样:
ScrvcrSockct listcncr = new ScrvcrSockct(8080);
try {
while (true) {
Socket socket 二 1 i stener. accept ();
try {
handlcRcqucst (socket);
} catch (lOException e) {
e. printStackTrace ();
}
}
} finally {
listener. close ();
}
这段代码在8080端口上创建了一个ServerSocket,紧接着通过循环來监听和接 受新到达的连接。一旦连接建立,会将socket传递给handleRequest方法。这 个方法可能会读取该IITTP请求,处理这个请求,然后写回一个响应。在这个简 单的例子屮,handleRequest方法从socket屮读取简单的一行数据,然后返回 一个简短的HTTP响应。但是,handleRequest冇可能需要处理一些更复杂的任 务,例如读数据库或者执行其它一些10操作。
final static String response -
IITTP/l. 0 200 0Krn〃 +
Content-type: text/plainrnz,+
〃 〃
rn +
“Hello Worldrn,z;
public static void handleRequest(Socket socket) throws IOException { // Read the input stream, and return 〃200 0K〃 try {
BufferedReader in 二 new BufferedReader(
new
InputStreamReader(socket, getlnputStream()));
log. info(in. readLineO);
OutputStream out 二 socket. getOutputStream(); out. wri te(response. getBytes(StandardCharsets. UTF_8));
} fineilly {
socket. closeO ;
}
}
因为只有一个线程处理所有的socket,因此只有在完全处理好一个请求后,才 能再接受下一个请求。在实际的应用中,handleRequest方法口J能需要经过100 毫秒才能返回,那么这个服务器程序在一秒中,只能按顺序处理10个请求。
多线程模型
尽管handleRequesI可能会被10操作阻塞,CPU却可能是空闲的,它可以处理 其它更多请求,但这对单线程模型來说是不能实现的。I大I此,通过创建多个线程, 可以使服务器程序实现并发操作:
public static class HandleRequestRurrnable implements Rurrnable { final Socket socket;
public HandleRequestRurrnable(Socket socket) {
this.socket 二 socket;
}
public void run() { try {
handleRequest( socket);
} catch (IOException e) {
e. printStackTrace ();
}
}
}
// Main loop here
ServerSocket 1i stener 二 n
文档评论(0)