Netty中Channel、ChannelPipeline、ChannelHandler、ChannelHandlerContext之间的关系

在这里插入图片描述

public interface Channel extends AttributeMap, ChannelOutboundInvoker, Comparable<Channel> {
// ...
ChannelPipeline pipeline();
// ...

}

每一个 Channel 被创建,就会生成一个与其绑定的 ChannelPipeline。

// io.netty.channel.AbstractChannel

protected AbstractChannel(Channel parent) {
    this.parent = parent;
    id = newId();
    unsafe = newUnsafe();
    pipeline = newChannelPipeline();
}

protected AbstractChannel(Channel parent, ChannelId id) {
    this.parent = parent;
    this.id = id;
    unsafe = newUnsafe();
    pipeline = newChannelPipeline();
}

protected DefaultChannelPipeline newChannelPipeline() {
    return new DefaultChannelPipeline(this);
}

ChannelPipeline 中包含了一个处理该 Channel 消息的 ChannelHandler 执行链。
在这里插入图片描述

当每一个 ChannelHandler 被注册到该 ChannelPipeline 中就会生成一个对应的 ChannelHandlerContext,和该 ChannelHandler 进行绑定。

ChannelHandler 的执行器链 ChannelPipeline 是由 ChannelHandlerContext 作为结点组成的双向链表。

public interface ChannelHandlerContext extends AttributeMap, ChannelInboundInvoker, ChannelOutboundInvoker {
    // ...
    Channel channel();
    ChannelHandler handler();
	// ...
}	

一个 ChannelHandler 可以从属于(注册到)多个 ChannelPipeline。所以,一个 ChannelHandler 可以绑定多个 ChannelHandlerContext
不过,这样的ChannelHandler必须使用 @Sharable 注解标注,保证它的线程安全性,否则试图将它注册到多个 ChannelHandlerPipeline 中时将会抛出异常。

在这里插入图片描述


https://netty.io/4.0/api/io/netty/channel/ChannelPipeline.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

N3verL4nd

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值