
org.bdware.doip.cluster.client.pooledClient.SimpleChannelPooledHandler Maven / Gradle / Ivy
package org.bdware.doip.cluster.client.pooledClient;
import io.netty.channel.Channel;
import io.netty.channel.ChannelPipeline;
import io.netty.channel.pool.AbstractChannelPoolHandler;
import io.netty.handler.codec.LengthFieldBasedFrameDecoder;
import org.bdware.doip.codec.MessageEnvelopeAggregator;
import org.bdware.doip.codec.MessageEnvelopeCodec;
import org.bdware.doip.codec.doipMessage.MessageEnvelope;
import org.bdware.doip.endpoint.client.ClientConfig;
public class SimpleChannelPooledHandler extends AbstractChannelPoolHandler {
boolean splitEnvelop;
int maxFrameLength;
NettyDoipPooledClientHandler clientHandler;
public SimpleChannelPooledHandler(NettyDoipPooledClientHandler clientHandler) {
this.clientHandler = clientHandler;
}
@Override
public void channelAcquired(Channel ch) throws Exception {
super.channelAcquired(ch);
// System.out.println("--------------------------------------------------------channelAcquired channel's id is:"+ch.id());
}
@Override
public void channelReleased(Channel ch) throws Exception {
super.channelReleased(ch);
// System.out.println("--------------------------------------------------------channelReleased, id is:"+ch.id());
}
/**
* 在创建ChannelPool连接池时会调用此方法对Channel进行初始化
*
* @param ch
* @throws Exception
*/
@Override
public void channelCreated(Channel ch) throws Exception {
// System.out.println("channel created. Channel ID: " + ch.id());
//缓存当前Channel对应的handler
// ioHandlerMap.put(ch.id(), new NettyDoipPooledClientHandler());
this.splitEnvelop = false;
this.maxFrameLength = 5 * 1024 * 1024;
ChannelPipeline p = ch.pipeline();
p.addLast(new LengthFieldBasedFrameDecoder(maxFrameLength, 20, 4, 0, 0))
.addLast(new MessageEnvelopeCodec()).addLast(new MessageEnvelopeAggregator(maxFrameLength - MessageEnvelope.ENVELOPE_LENGTH));
//自定义handler处理
p.addLast(clientHandler);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy