业务处理器。根据消息具体处理业务的地方。这里接收到的消息对象是解码之后的消息对象,它会有序且阻塞地接收消息,意味着如果处理一个消息阻塞了,后面的消息也不能被及时处理。所以这里处理业务的过程要放到线程池里运行。
package minabase.server;
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.LinkedBlockingDeque;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
import minabase.server.business.MainBusiness;
import org.apache.mina.core.service.IoHandlerAdapter;
import org.apache.mina.core.session.IoSession;
/**
* Class Description: 业务处理器
* Copyright: Copyright (c)
*
*/
public class BusinessHandler extends IoHandlerAdapter
{
private static int coreThreadNum = 50;
private static int maxThreadNum = 100;
private static int threadKeepAliveTime = 10;
private static int queueSize = 150;
private static ThreadPoolExecutor pool = null;
static
{
pool =
new ThreadPoolExecutor(coreThreadNum, maxThreadNum, threadKeepAliveTime,
TimeUnit.SECONDS, new ArrayBlockingQueue<Runnable>(queueSize),
new ThreadPoolExecutor.DiscardPolicy());
}
@Override
public void messageReceived(IoSession session, Object message)
{
pool.execute(new MainBusiness((String)message));
}
@Override
public void exceptionCaught(IoSession session, Throwable cause)
{
}
}