![跟闪电侠学Netty:Netty即时聊天实战与底层原理](https://wfqqreader-1252317822.image.myqcloud.com/cover/384/43738384/b_43738384.jpg)
4.3 服务端启动的其他方法
4.3.1 handler()方法
![](https://epubservercos.yuewen.com/6C3355/23020652909769306/epubprivate/OEBPS/Images/txt005_5.jpg?sign=1739335752-U0QNa5LpXe0DOtyBakaUm8WQVogkxnuA-0-37b18dc4c0a3e6c4278719f205a33f19)
handler()方法可以和前面分析的childHandler()方法对应起来:childHandler()方法用于指定处理新连接数据的读写处理逻辑;handler()方法用于指定在服务端启动过程中的一些逻辑,通常情况下用不到这个方法。
4.3.2 attr()方法
![](https://epubservercos.yuewen.com/6C3355/23020652909769306/epubprivate/OEBPS/Images/txt005_6.jpg?sign=1739335752-eBL9UixpjyID8NMKvxljgOxEeAW9bcyv-0-8fc613a445a8cce538ebe77895ce8978)
attr()方法可以给服务端Channel,也就是NioServerSocketChannel指定一些自定义属性,然后通过channel.attr()取出这个属性。比如,上面的代码可以指定服务端Channel的serverName属性,属性值为nettyServer,其实就是给NioServerSocketChannel维护一个Map而已,通常情况下也用不上这个方法。
4.3.3 childAttr()方法
除了可以给服务端Channel即NioServerSocketChannel指定一些自定义属性,我们还可以给每一个连接都指定自定义属性。
![](https://epubservercos.yuewen.com/6C3355/23020652909769306/epubprivate/OEBPS/Images/txt005_7.jpg?sign=1739335752-Q0NmTCgcxFhOVW4sXmPmnXQWvgWV0xWk-0-958db68a48af7ca11e6ab4d9c95c3050)
上面的childAttr()方法可以给每一个连接都指定自定义属性,后续我们可以通过channel.attr()方法取出该属性。
4.3.4 option()方法
option()方法可以给服务端Channel设置一些TCP参数,最常见的就是so_backlog,设置如下。
![](https://epubservercos.yuewen.com/6C3355/23020652909769306/epubprivate/OEBPS/Images/txt005_8.jpg?sign=1739335752-y5cokh1pPHekZ6h89pUd4cRENwNmdL64-0-e092c0158ed7745de401cf527a906d68)
这个设置表示系统用于临时存放已完成三次握手的请求的队列的最大长度,如果连接建立频繁,服务器处理创建新连接较慢,则可以适当调大这个参数。
4.3.5 childOption()方法
childOption()方法可以给每个连接都设置一些TCP参数。
![](https://epubservercos.yuewen.com/6C3355/23020652909769306/epubprivate/OEBPS/Images/txt005_9.jpg?sign=1739335752-HLeP7IK8GSCd37c6mDik56fsuJHKQSgv-0-196142661d0584c77e0eb082f7778fb2)
上述代码中设置了两种TCP参数,其中:
● ChannelOption.SO_KEEPALIVE表示是否开启TCP底层心跳机制,true表示开启。
● ChannelOption.TCP_NODELAY表示是否开启Nagle算法,true表示关闭,false表示开启。通俗地说,如果要求高实时性,有数据发送时就马上发送,就设置为关闭;如果需要减少发送次数,减少网络交互,就设置为开启。
其他参数这里就不一一讲解了,读者有兴趣可以自行研究。