我是靠谱客的博主 迅速小蝴蝶,最近开发中收集的这篇文章主要介绍netty优化,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

  为了提高单机netty服务器的并发处理能力,可以从以下几个方面对netty进行优化。

 

      首先,在服务器初始化的时候需要设置两个线程池: 一个是用来接收客户端的连接,可以命名为eventLoopGroupBoss, 由于接收连接是非常快速的事情,所以这个线程池的线程数通常设置为1,设置为多个线程时可能会在多个线程之间产生对资源的竞争,反而不利于服务器处理能力的提高;另一个是用来处理客户端的读写操作,命名为eventLoopGroupWorker,由于处理网络IO操作是非常耗时的,为了能够尽可能多的处理客户端的连接,所以这个线程池的线程数通常设为多个,具体需要设置的数量可以根据业务量和CPU核数进行调整,一般设置成CPU核数的两倍到三倍是一个好的选择。在这个过程中,为了方便系统BUG 的解决,可以为每个线程池设置一个自定义的ThreadFactory,这个factory的作用是根据线程池的类型为创建的线程设置一个特殊的名称,如boss线程的名称是NettyBoss_,工作线程的名称是NettyServerSelector_%d_%d,这样可以在以后的问题排除过程中利用这个名称识别不同的线程,分析这些线程的资源占用率,便于找到问题的根源。

 

     此外,如果部署服务器的操作系统是Linux, 在选中worker线程池的时候可以考虑用epoll代替传统的select,前者对应neitty提供的EpollEventLoopGroup,后者对应的是NioEventLoopGroup。之所以要这样做,是因为传统的select基于轮询的方式来进行事件处理,随着fd数量的增加,导致

最后

以上就是迅速小蝴蝶为你收集整理的netty优化的全部内容,希望文章能够帮你解决netty优化所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(58)

评论列表共有 0 条评论

立即
投稿
返回
顶部