tomcat中关于websocket的性能优化配置-阿里云开发者社区

开发者社区> 开发与运维> 正文
登录阅读全文

tomcat中关于websocket的性能优化配置

简介: tomcat中关于websocket的性能优化配置

一、优化Connector 
http://www.aikaiyuan.com/8466.html

tomcat的运行模式有3种 
1)bio 
默认的模式,性能非常低下,没有经过任何优化处理和支持.

2)nio 
利用java的异步io护理技术,noblocking IO技术. 
想运行在该模式下,直接修改server.xml里的Connector节点,修改protocol为 
protocol=”org.apache.coyote.http11.Http11NioProtocol” 启动后,就可以生效。 
( http://www.365mini.com/page/tomcat-connector-mode.htm )

3)apr 
安装起来最困难,但是从操作系统级别来解决异步的IO问题,大幅度的提高性能.

二、Apache Tomcat 8 WebSocket How-To 中文翻译版 
http://blog.csdn.net/hills/article/details/39368951

Java WebSocket 1.0 规范要求在一个不同的线程上执行到发起写入的线程的异步写入回调。 
由于容器线程池不是通过Servlet API被暴露,因此WebSocket实现必须提供自己的线程池。该线程池可以通过下列servlet context初始化参数被控制: 
org.apache.tomcat.websocket.executorCoreSize: executor线程池的核心大小。如果不设置,则默认为0。 
org.apache.tomcat.websocket.executorMaxSize:executor线程池所允许的最大值。如果不设置,则默认为200。 
org.apache.tomcat.websocket.executorKeepAliveTimeSeconds:executor线程池中空闲进程所保留的最大时间。如果未指定,则默认为60秒。 
设置方法: 
web.xml中

<!--websocket executor 线程池的核心容量大小 -->
<context-param>
<param-name>org.apache.tomcat.websocket.executorCoreSize</param-name>
<param-value>200</param-value>
</context-param>
<!--websocket executor 线程池的最大容量大小 -->
<context-param>
<param-name>org.apache.tomcat.websocket.executorMaxSize</param-name>
<param-value>1000</param-value>
</context-param>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

三、设置最大线程数 
apache-tomcat-7.0.73\conf\server.xml

<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
  • 1
  • 2
  • 3

修改为:

<Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
maxThreads="1000" minSpareThreads="4"/>

<Connector executor="tomcatThreadPool"
port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"

redirectPort="8443" />总结:我采用第三种方案优化,使用tomcat8.5.3 ,

        <Executor name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="500" minSpareThreads="20" />

        <Connector executor="tomcatThreadPool" port="8080" protocol="HTTP/1.1" connectionTimeout="40000" redirectPort="8443" acceptCount="1000" />

静待效果中参考:https://blog.csdn.net/jkxqj/article/details/72640037




版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
开发与运维
使用钉钉扫一扫加入圈子
+ 订阅

集结各类场景实战经验,助你开发运维畅行无忧

其他文章