背景
- 它是怎么设计初始化逻辑和注册逻辑的?
- 这段代码有哪些可以借鉴学习的?
过程
- 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实例是存在的,这个时候是强制关闭。
小结
- 当某个实例在后面的逻辑需要的时候,前面的逻辑代码就可以提前进行判断。一旦出现错误,也就没有必要继续执行下去的必要。
- 学习思路:对异常情况的考虑和处理。
- 容错考虑无处不在。