MINA使用注意事项
1. 注意内存清理,防止接收数据过多导致的内存溢出OutOfMemory:java heap space
2. 设置jdk
-Xms512m -Xmx512m(视具体情况而定)
2. 在连接关闭后的操作
MINA服务端配置:
1. 配置SessionConfig中的
receiveBufferSize输入缓冲区大小,
sendBufferSize输出缓冲区大小,
IdleTime(10)当客户端与服务器连接无操作,超过10s时转为空闲状态
spring 配置:
<!-- session config -->
<bean id="sessionConfig" factory-bean="ioAcceptor"
factory-method="getSessionConfig" >
<property name="bothIdleTime" value="10"/>
<property name="receiveBufferSize" value="1024"/>
<property name="sendBufferSize" value="1024"/>
</bean>
另外,可配置客户端的最大连接数
2. 问题汇总:
1) 连接开始后,如果内存立即升高,则配置receiveBufferSize和sendBufferSize,将这两个参数设小,或根据情况设定
2) 在连接过程中如果服务器(Weblogic)报:java.io.IoException:Connection reset by peer;则为客户端关闭连接
3) 在连接过程中,出现客户端与服务器链路为已连接状态,但无数据交互,则可设置
SessionConfig中的IdleTime()[acceptor.getSessionConfig().setIdleTime(IdleStatus.BOTH_IDLE,10);],并在IoHandlerAdapter中的sessionIdle()方法进行处理
3. MINA线程池配置
该线程池配置的为IoHandler线程迟
1)MINA中共有3类线程
与Session有关的线程
NioProcess线程
IoHandler线程
若filter中线程池最大线程设置为n(即IoHandler的线程为n),则线程池中最多创建n个名为pool-1-thread-n的线程
若处理时pool-1-thread-n线程不够用时,会将IoHandler与NioProcess共用线程
如果不配置filter线程池,则IoHandler与NioProcess共用线程。