Netty 4.0 IdleStateHandler无法正常工作

时间:2013-07-10 19:33:16

标签: java netty

编辑:一切正常。问题完全在另一方面。这可以作为一个工作示例。

我正在尝试在我的服务器中使用Netty 4.0.9实现IdleStateHandler。 我得到的问题是它不会触发IdleStateEvent。

测试我只是让客户端“崩溃”,就像我对OIO所做的那样(在这种情况下一切都按预期工作)。

我确定我在任何地方都没有阻止,一切正常(包括来自客户端的正常关闭连接请求)。

这是我的代码...... 管道

public PipelineInitializer(){
    super();
}

@Override
protected void initChannel(SocketChannel ch) throws Exception {
    // Idle Handlers
    ch.pipeline().addLast("IdleChecker", new IdleStateHandler(15,0,0));
    ch.pipeline().addLast("IdleDisconnecter", new IdleDisconnecter());

    // Decoding Handlers
    ch.pipeline().addLast("Framer", new DelimiterBasedFrameDecoder(Integer.MAX_VALUE, Delimiters.lineDelimiter()));
    ch.pipeline().addLast("Decoder", STR_DECODER);

    // Encoding Handlers
    ch.pipeline().addLast("Encoder", STR_ENCODER);

    // Processing Handlers (if Idle Event, disconnects)
    ch.pipeline().addLast("ServiceSelector", new ServiceSelector());
}

和应该处理IdleEvent的Handler:

public class IdleDisconnecter extends ChannelDuplexHandler {

public IdleDisconnecter(){
    super();
}

@Override
public void userEventTriggered(ChannelHandlerContext ctx, Object evt) throws Exception{
    System.out.println("Event Fired"); // Doesn't trigger
    if (evt instanceof IdleStateEvent) {
        System.out.println("Event is IdleStateEvent"); // Doesn't trigger
        if (((IdleStateEvent) evt).state() == IdleState.READER_IDLE) {
            System.out.println("Event is a Reader one"); // Doesn't trigger
            throw new Exception(); //I want this to be catch by the last handler in the pipeline
        }
    }
}

有什么建议吗?可能我做了一些我拒绝看到的愚蠢错误,我不知道,但我完全没有想法。

谢谢

0 个答案:

没有答案