Netty源码分析系列之四:Netty启动之NioServerSocketChannel创建_netty socketchannel(3)

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前在阿里

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Linux运维全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上运维知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化的资料的朋友,可以点击这里获取!

// If we are here and the promise is not failed, it’s one of the following cases:

// 1) If we attempted registration from the event loop, the registration has been completed at this point.

// i.e. It’s safe to attempt bind() or connect() now because the channel has been registered.

// 2) If we attempted registration from the other thread, the registration request has been successfully

// added to the event loop’s task queue for later execution.

// i.e. It’s safe to attempt bind() or connect() now:

// because bind() or connect() will be executed after the scheduled registration task is executed

// because register(), bind(), and connect() are all bound to the same thread.

return regFuture;

}

创建channel,实际调用的是ReflectiveChannelFactory中的newChannel方法。

public class ReflectiveChannelFactory implements ChannelFactory {

private final Constructor<? extends T> constructor;

public ReflectiveChannelFactory(Class<? extends T> clazz) {

ObjectUtil.checkNotNull(clazz, “clazz”);

try {

this.constructor = clazz.getConstructor();

} catch (NoSuchMethodException e) {

throw new IllegalArgumentException("Class " + StringUtil.simpleClassName(clazz) +

" does not have a public non-arg constructor", e);

}

}

@Override

public T newChannel() {

try {

return constructor.newInstance();

} catch (Throwable t) {

throw new ChannelException("Unable to create Channel from class " + constructor.getDeclaringClass(), t);

}

}

}

从上述代码中我们可以看出,clazz.getConstructor().newInstance()通过反射的方式创建了Channel

Channel创建好之后,进行Channel的初始化操作,

@Override

void init(Channel channel) {

//设置channle选项

setChannelOptions(channel, options0().entrySet().toArray(newOptionArray(0)), logger);

//设置channel属性

setAttributes(channel, attrs0().entrySet().toArray(newAttrArray(0)));

ChannelPipeline p = channel.pipeline();

final EventLoopGroup currentChildGroup = childGroup;

final ChannelHandler currentChildHandler = childHandler;

final Entry<ChannelOption<?>, Object>[] currentChildOptions =

childOptions.entrySet().toArray(newOptionArray(0));

final Entry<AttributeKey<?>, Object>[] currentChildAttrs = childAttrs.entrySet().toArray(newAttrArray(0));

p.addLast(new ChannelInitializer() {

@Override

public void initChannel(final Channel ch) {

final ChannelPipeline pipeline = ch.pipeline();

ChannelHandler handler = config.handler();

if (handler != null) {

pipeline.addLast(handler);

}

ch.eventLoop().execute(new Runnable() {

@Override

小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Java工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频

如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Java)
img

最后

既已说到spring cloud alibaba,那对于整个微服务架构,如果想要进一步地向上提升自己,到底应该掌握哪些核心技能呢?

就个人而言,对于整个微服务架构,像RPC、Dubbo、Spring Boot、Spring Cloud Alibaba、Docker、kubernetes、Spring Cloud Netflix、Service Mesh等这些都是最最核心的知识,架构师必经之路!下图,是自绘的微服务架构路线体系大纲,如果有还不知道自己该掌握些啥技术的朋友,可根据小编手绘的大纲进行一个参考。

最全的Linux教程,Linux从入门到精通

======================

  1. linux从入门到精通(第2版)

  2. Linux系统移植

  3. Linux驱动开发入门与实战

  4. LINUX 系统移植 第2版

  5. Linux开源网络全栈详解 从DPDK到OpenFlow

华为18级工程师呕心沥血撰写3000页Linux学习笔记教程

第一份《Linux从入门到精通》466页

====================

内容简介

====

本书是获得了很多读者好评的Linux经典畅销书**《Linux从入门到精通》的第2版**。本书第1版出版后曾经多次印刷,并被51CTO读书频道评为“最受读者喜爱的原创IT技术图书奖”。本书第﹖版以最新的Ubuntu 12.04为版本,循序渐进地向读者介绍了Linux 的基础应用、系统管理、网络应用、娱乐和办公、程序开发、服务器配置、系统安全等。本书附带1张光盘,内容为本书配套多媒体教学视频。另外,本书还为读者提供了大量的Linux学习资料和Ubuntu安装镜像文件,供读者免费下载。

华为18级工程师呕心沥血撰写3000页Linux学习笔记教程

本书适合广大Linux初中级用户、开源软件爱好者和大专院校的学生阅读,同时也非常适合准备从事Linux平台开发的各类人员。

需要《Linux入门到精通》、《linux系统移植》、《Linux驱动开发入门实战》、《Linux开源网络全栈》电子书籍及教程的工程师朋友们劳烦您转发+评论

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以点击这里获取!

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以点击这里获取!

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 9
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: NioSocketChannel类本身并没有实现Serializable接口,也就是说它本身不能被序列化。如果你想将NioSocketChannel对象序列化,你需要自己定义一个类来实现Serializable接口,并将NioSocketChannel对象作为该类的一个成员变量。然后你就可以将这个自定义类的对象序列化了。 具体实现方式可以参考如下代码: ``` import java.io.Serializable; public class MyClass implements Serializable { private NioSocketChannel socketChannel; public MyClass(NioSocketChannel socketChannel) { this.socketChannel = socketChannel; } public NioSocketChannel getSocketChannel() { return socketChannel; } public void setSocketChannel(NioSocketChannel socketChannel) { this.socketChannel = socketChannel; } } ``` 这样你就可以通过如下代码将MyClass对象序列化: ``` MyClass myObject = new MyClass(socketChannel); // 将myObject对象序列化到文件中 FileOutputStream fos = new FileOutputStream("myObject.ser"); ObjectOutputStream oos = new ObjectOutputStream(fos); oos.writeObject(myObject); oos.close(); ``` ### 回答2: NettyNioSocketChannel对象是一个网络套接字通道,用于在Java NIO(非阻塞I/O)中进行网络通信。NioSocketChannel类本身并没有直接实现Serializable接口,因为它不是一个可序列化的对象。 Serializable接口是一个标记接口,用于指示一个类可以被序列化,即可以将其转换为字节流以便在网络中传输或持久化到存储设备中。可序列化对象需要实现Serializable接口,并提供相应的序列化和反序列化方法。 然而,NioSocketChannelNetty的抽象类实现之一,它的子类AbstractChannel已经实现了Serializable接口。可以通过自定义一个类继承NioSocketChannel,并实现Serializable接口来实现将NioSocketChannel对象序列化。 以下是一个可能的示例代码: ```java import io.netty.channel.socket.nio.NioSocketChannel; import java.io.Serializable; public class SerializableNioSocketChannel extends NioSocketChannel implements Serializable { // 添加一个默认的构造函数 public SerializableNioSocketChannel() { super(); } } ``` 在上述示例中,我们创建了一个新的类SerializableNioSocketChannel,该类继承了NioSocketChannel并实现了Serializable接口。通过将NioSocketChannel对象转换为SerializableNioSocketChannel对象,就可以实现对NioSocketChannel对象的序列化。 需要注意的是,由于NioSocketChannel作为网络套接字通道,它包含了底层网络连接状态等非序列化的信息,因此在实际使用中,可能需要根据具体需求选择序列化对象中需要保留的属性。 ### 回答3: NettyNioSocketChannel对象不能直接实现Serializable接口,因为NioSocketChannel类并没有实现Serializable接口。Serializable接口是Java提供的一种机制,用于将对象转换为字节流,以便能够在网络中传输或持久化到磁盘。 然而,我们可以通过一些其他方式来实现将NioSocketChannel对象序列化和反序列化。比如,可以通过将NioSocketChannel的一些关键信息提取出来,例如远程地址、本地地址、管道选项等,并将这些信息进行序列化和反序列化。 具体实现方式如下: 1. 创建一个包含NioSocketChannel关键信息的可序列化类,例如NioSocketChannelWrapper。 2. 在NioSocketChannelWrapper中定义所需的关键信息字段,例如remoteAddress、localAddress、channelOptions等。 3. 实现NioSocketChannelWrapper类的序列化接口Serializable,并添加序列化和反序列化方法。 4. 在需要将NioSocketChannel对象序列化时,通过构建NioSocketChannelWrapper对象,并将关键信息赋值给NioSocketChannelWrapper的相应字段。 5. 将NioSocketChannelWrapper对象进行序列化处理,并传输到目标。 6. 在需要反序列化NioSocketChannel对象时,接收到NioSocketChannelWrapper对象后,进行反序列化操作,将关键信息提取出来。 7. 通过Netty的Bootstrap或其他相关类,使用提取出的关键信息重新构建NioSocketChannel对象。 需要注意的是,反序列化后的NioSocketChannel对象并不是原始NioSocketChannel对象的完全克隆,而是通过关键信息重新构建的新对象。一些与网络连接、管道状态等相关的信息可能无法被序列化和恢复。 总之,NettyNioSocketChannel对象不能直接实现Serializable接口,但通过提取关键信息并自定义可序列化类,我们可以实现将NioSocketChannel对象进行序列化和反序列化操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值