Java ApacheMina执行器过滤器
我有一个基于ApacheMina 2.0.4的应用程序,其中我使用ExecutorFilter在message_received事件上创建一个线程 我发现在生产环境中,ExecutorFilter在某个时候并没有创建线程。相反,它会阻止请求消息 有谁能指导如何正确使用ExecutorFilter?我希望最多有100个同时连接到我的应用程序 这是覆盖ExecutorFilter类的我的类-Java ApacheMina执行器过滤器,java,apache-mina,Java,Apache Mina,我有一个基于ApacheMina 2.0.4的应用程序,其中我使用ExecutorFilter在message_received事件上创建一个线程 我发现在生产环境中,ExecutorFilter在某个时候并没有创建线程。相反,它会阻止请求消息 有谁能指导如何正确使用ExecutorFilter?我希望最多有100个同时连接到我的应用程序 这是覆盖ExecutorFilter类的我的类- public class OneIExecutorFilter extends ExecutorFilter
public class OneIExecutorFilter extends ExecutorFilter {
public OneIExecutorFilter(IoEventType...eventTypes){
super(eventTypes);
}
@Override
public void sessionCreated(NextFilter nextFilter, IoSession session)
throws Exception {
super.sessionCreated(nextFilter, session);
}
@Override
protected void fireEvent(IoFilterEvent event) {
super.fireEvent(event);
}
}
您可能已经没有线程了。尝试使用
ExecutorFilter(int-maximumPoolSize,IoEventType…eventTypes)
构造函数,将maximumPoolSize
设置为100以上。您不必以这种方式重写ExecutorFilter。请尝试以下方法:
final int min = 1;
final int max = Integer.MAX_VALUE;
// RE: java.util.concurrent.Executors.newCachedThreadPool()
Executor executor = new ThreadPoolExecutor(min, max, 60, TimeUnit.SECONDS,
new SynchronousQueue<Runnable>())
ExecutorFilter ef = new ExecutorFilter(executor);
final int min=1;
最终int max=整数最大值;
//RE:java.util.concurrent.Executors.newCachedThreadPool()
Executor Executor=新线程池Executor(最小、最大、60、TimeUnit.s、,
新建SynchronousQueue())
ExecutorFilter ef=新的ExecutorFilter(executor);
谢谢您的建议。我已经解决了我的问题,但我会在下一个版本中尝试。