Dubbo大波剖析——线程模型初探

导引

Dubbo默认的底层网络通讯是使用Netty来做的,在服务提供方NettyServer使用两级线程池,其中EventLoopGroup(boss)主要用来接受客户端的链接请求,并把接受的请求分发给EventLoopGroup(worker)来处理,boss和worker线程组我们称为IO线程。

如果服务提供方的逻辑能迅速完成,并且不会发起新的 IO 请求,则直接在 IO 线程上处理更快,因为这减少了线程池调度。

但如果处理逻辑较慢,或者需要发起新的 IO 请求,比如需要查询数据库,则必须派发到新线程池,否则 IO 线程阻塞,将导致不能接收其它请求。

Dubbo提供的线程模型

Dubbo大波剖析——线程模型初探

其中ThreadPool的spi实现有如下:

  • fixed 固定大小线程池,启动时建立线程,不关闭,一直持有。(缺省)

  • cached 缓存线程池,空闲一分钟自动删除,需要时重建。

  • limited 可伸缩线程池,但池中的线程数只会增长不会收缩。只增长不收缩的目的是为了避免收缩时突然来了大流量引起的性能问题。

    三、结语

dubbo提供了常用的线程模型和线程池扩展各有利弊,如果您有定制化需要,可以按照spi规范进行定制。

本文分享网络,原文地址:http://ifeve.com/dubbo-threadmodel/


Dubbo大波剖析——线程模型初探


分享到:


相關文章: