一起养成写作习惯!这是我参与「掘金日新计划 · 4 月更文挑战」的第25天,点击查看活动详情。
背景
-
它是怎么设计初始化逻辑和注册逻辑的?
-
这段代码有哪些可以借鉴学习的?
过程
- initAndRegister()方法概览
- 说明
-
前面的代码逻辑对channelFactory实例进行了非空检查。
-
channelFactory.newChannel()是怎么获取到的?推荐阅读
-
初始化逻辑,init(channel)
-
然后执行注册逻辑,config().group().register(channel)
- initAndRegister()方法中的catch部分代码逻辑分析
-
说明
-
如果捕获到了异常,证明初始化部分相关逻辑是执行失败了。所以代码需要被截断了,后续执行逻辑也没有什么意义了。
-
这个channel也有可能为null,所以进行了一个channel的非空判断。
-
如果不是空的话,就需要强制关闭。在把错误的描述信息,用截断的方式返回。
-
如果是空的话,就不需要关闭channel了。直接返回即可。
-
-
initAndRegister()方法中的config()部分代码逻辑分析
-
说明
-
config()返回一个ServerBootstrapConfig的实例对象,这个实例对象持有一个ServerBootstrap实例的引用,而这个ServerBootstrap实例是提前创建好了的,由开发者显示创建这个ServerBootstrap(bootstrap)实例。
-
这个bootstrap实例的group()方法,返回一个boosGroup的线程池。如果不是主从模式的话,那么bossGroup和workerGroup其实是同一个。这里的同一个是指,group和childGroup都使用同一个线程池。
-
然后这个boosGroup线程池拿着channel去执行后续的注册逻辑过程。
- initAndRegister()方法中的if(regFuture.cause() != null)部分代码逻辑分析
- 说明
-
这里是一段容错代码考虑,保证代码的健壮性,保证后续逻辑一定是对的。
-
如果这个异步逻辑在执行过程中,发生了错误。有两种情况,channel是注册成功了的,那么直接关闭channel。如果channel是没有注册成功的,但是channel实例是存在的,这个时候是强制关闭。
-
小结
-
当某个实例在后面的逻辑需要的时候,前面的逻辑代码就可以提前进行判断。一旦出现错误,也就没有必要继续执行下去的必要。
-
学习思路:对异常情况的考虑和处理。
-
容错考虑无处不在。