當前位置: 首頁>>代碼示例>>Java>>正文


Java IdleStateEvent.getState方法代碼示例

本文整理匯總了Java中org.jboss.netty.handler.timeout.IdleStateEvent.getState方法的典型用法代碼示例。如果您正苦於以下問題:Java IdleStateEvent.getState方法的具體用法?Java IdleStateEvent.getState怎麽用?Java IdleStateEvent.getState使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.jboss.netty.handler.timeout.IdleStateEvent的用法示例。


在下文中一共展示了IdleStateEvent.getState方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: channelIdle

import org.jboss.netty.handler.timeout.IdleStateEvent; //導入方法依賴的package包/類
@Override
public void channelIdle(ChannelHandlerContext ctx, IdleStateEvent e) throws Exception {
    if (!isHandshakeComplete()) {
        return;
    }

    if (e.getState() == IdleState.READER_IDLE) {
        // When no message is received on channel for read timeout, then close
        // the channel
        log.info("Disconnecting client {} due to read timeout", getClientInfoString());
        ctx.getChannel().close();
    } else if (e.getState() == IdleState.WRITER_IDLE) {
        // Send keep alive message
        log.debug("Sending keep alive message due to IdleState timeout " + pc.toString());
        pc.sendMessage(Collections.singletonList(pc.factory().buildKeepaliveMsg().build()));
    }
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:18,代碼來源:PcepChannelHandler.java

示例2: channelIdle

import org.jboss.netty.handler.timeout.IdleStateEvent; //導入方法依賴的package包/類
@Override
public void channelIdle(ChannelHandlerContext ctx, IdleStateEvent e) throws Exception {
    if (e.getState() == IdleState.WRITER_IDLE) {
        Channel channel = e.getChannel();
        if (channel != null) {
            //寫空閑  則發送心跳數據
            channel.write(Heartbeat.getSingleton());
        } else {
            logger.warn("writer idle on channel({}), but hsfChannel is not managed.", e.getChannel());
        }
    } else if (e.getState() == IdleState.READER_IDLE) {
        //讀空閑 則斷開連接
        logger.error("channel:{} is time out.", e.getChannel());
        handleUpstream(ctx, new DefaultExceptionEvent(e.getChannel(), new SocketTimeoutException(
            "force to close channel(" + ctx.getChannel().getRemoteAddress() + "), reason: time out.")));
        e.getChannel().close();
    }
    super.channelIdle(ctx, e);
}
 
開發者ID:sunguangran,項目名稱:navi,代碼行數:20,代碼來源:StateCheckChannelHandler.java

示例3: channelIdle

import org.jboss.netty.handler.timeout.IdleStateEvent; //導入方法依賴的package包/類
private void channelIdle(ChannelHandlerContext ctx, IdleStateEvent e) {
    if (e.getState() == IdleState.READER_IDLE) {
        Object a = ctx.getChannel().getAttachment();
        // connect/login timeout
        if (a == null || a instanceof ChannelFuture) {
            ctx.getChannel().close();
            return;
        }
        ChannelData d = (ChannelData)a;
        if (d.timer.elapsed() > TimeUnit.MILLISECONDS.convert(60, TimeUnit.SECONDS)) {
            ctx.getChannel().close();
        } else {
            ctx.sendDownstream(new DownstreamMessageEvent(ctx.getChannel(),
                    new DefaultChannelFuture(ctx.getChannel(), false), PING, null));
        }
    }
}
 
開發者ID:redbooth,項目名稱:jssmp,代碼行數:18,代碼來源:SSMPRequestDecoder.java

示例4: channelIdle

import org.jboss.netty.handler.timeout.IdleStateEvent; //導入方法依賴的package包/類
@Override
public void channelIdle(ChannelHandlerContext ctx, IdleStateEvent e)
    throws Exception {
  if (e.getState() == IdleState.ALL_IDLE) {
    e.getChannel().close();
  }
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:8,代碼來源:RpcProgramPortmap.java

示例5: channelIdle

import org.jboss.netty.handler.timeout.IdleStateEvent; //導入方法依賴的package包/類
@Override
public void channelIdle(ChannelHandlerContext ctx, IdleStateEvent e) throws Exception {
	 super.channelIdle(ctx, e);  

	 if(e.getState() == IdleState.ALL_IDLE) {
		 e.getChannel().close();
		 System.out.println("idle channel was closed!");
	 }
   }
 
開發者ID:tangaiyun,項目名稱:Netty-Resteasy-Spring,代碼行數:10,代碼來源:HealthCheckHandler.java

示例6: channelIdle

import org.jboss.netty.handler.timeout.IdleStateEvent; //導入方法依賴的package包/類
@Override
public void channelIdle(ChannelHandlerContext ctx, IdleStateEvent e) {
    logger.info("In IDLE event handler for TCP...");
    
    //there are 3 states. READER/WRITER/ALL
    if (e.getState() == IdleState.ALL_IDLE){
        int statusCodeInt = 0;
        String statusCode = statusCodeInt + " SUCCESSFUL";
        String errMsg="idleTimeout to finish";
        
        tcpWorker.onComplete(tcpWorker.responseSb.toString(), false, 
                errMsg, errMsg, statusCode, statusCodeInt);
    }
}
 
開發者ID:eBay,項目名稱:parallec,代碼行數:15,代碼來源:TcpWorker.java

示例7: channelIdle

import org.jboss.netty.handler.timeout.IdleStateEvent; //導入方法依賴的package包/類
/**
 * this case is like a read timeout where did not get anything from the
 * server for a long time.
 * 
 * For UDP need to mark as error
 * 
 * @see org.jboss.netty.handler.timeout.IdleStateAwareChannelHandler#channelIdle
 *      (org.jboss.netty.channel.ChannelHandlerContext,
 *      org.jboss.netty.handler.timeout.IdleStateEvent)
 */
@Override
public void channelIdle(ChannelHandlerContext ctx, IdleStateEvent e) {
    logger.debug("In IDLE event handler for UDP..timeout.");

    // there are 3 states. READER/WRITER/ALL
    if (e.getState() == IdleState.ALL_IDLE) {
        int statusCodeInt = 1;
        String statusCode = statusCodeInt + " FAILURE";
        String errMsg = "UDP idle (read) timeout";

        udpWorker.onComplete(udpWorker.responseSb.toString(), true,
                errMsg, errMsg, statusCode, statusCodeInt);
    }
}
 
開發者ID:eBay,項目名稱:parallec,代碼行數:25,代碼來源:UdpWorker.java

示例8: channelIdle

import org.jboss.netty.handler.timeout.IdleStateEvent; //導入方法依賴的package包/類
public void channelIdle(ChannelHandlerContext ctx, IdleStateEvent e) {
    if (e.getState() == IdleState.READER_IDLE) {
        if (_timer.elapsed() > TimeUnit.MILLISECONDS.convert(60, TimeUnit.SECONDS)) {
            ctx.getChannel().close();
        } else {
            L.debug("send ping");
            ctx.sendDownstream(new DownstreamMessageEvent(ctx.getChannel(),
                    new DefaultChannelFuture(ctx.getChannel(), false), PING, null));
        }
    }
}
 
開發者ID:redbooth,項目名稱:jssmp,代碼行數:12,代碼來源:SSMPResponseDecoder.java

示例9: channelIdle

import org.jboss.netty.handler.timeout.IdleStateEvent; //導入方法依賴的package包/類
@Override
public void channelIdle(ChannelHandlerContext ctx, IdleStateEvent e)
        throws InterruptedException {
    if (e.getState() == IdleState.ALL_IDLE) {
        this.closeChannel(ctx, 1011, Text.REACH_MAX_IDLE);
        this.logger.info(Text.REACH_MAX_IDLE_AND_CLOSE, this.maxIdleTimeSeconds);
    }
}
 
開發者ID:kuiwang,項目名稱:my-dev,代碼行數:9,代碼來源:MaxIdleTimeHandler.java

示例10: channelIdle

import org.jboss.netty.handler.timeout.IdleStateEvent; //導入方法依賴的package包/類
@Override
public void channelIdle(ChannelHandlerContext ctx, IdleStateEvent e) {
  if (e.getState() == IdleState.WRITER_IDLE && enabledTimeout) {
    e.getChannel().close();
  }
}
 
開發者ID:hopshadoop,項目名稱:hops,代碼行數:7,代碼來源:ShuffleHandler.java


注:本文中的org.jboss.netty.handler.timeout.IdleStateEvent.getState方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。