Java ApacheMina执行器过滤器

Java ApacheMina执行器过滤器,java,apache-mina,Java,Apache Mina,我有一个基于ApacheMina 2.0.4的应用程序,其中我使用ExecutorFilter在message_received事件上创建一个线程 我发现在生产环境中,ExecutorFilter在某个时候并没有创建线程。相反,它会阻止请求消息 有谁能指导如何正确使用ExecutorFilter?我希望最多有100个同时连接到我的应用程序 这是覆盖ExecutorFilter类的我的类- public class OneIExecutorFilter extends ExecutorFilter

我有一个基于ApacheMina 2.0.4的应用程序,其中我使用ExecutorFilter在message_received事件上创建一个线程

我发现在生产环境中,ExecutorFilter在某个时候并没有创建线程。相反,它会阻止请求消息

有谁能指导如何正确使用ExecutorFilter?我希望最多有100个同时连接到我的应用程序

这是覆盖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);

谢谢您的建议。我已经解决了我的问题,但我会在下一个版本中尝试。