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

  1. 云栖社区>
  2. 博客>
  3. 正文

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

浦涛 2018-09-18 16:31:30 浏览1467
展开阅读全文

一、优化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




网友评论

登录后评论
0/500
评论
浦涛
+ 关注