没想到吧!关于Dubbo的『消费端线程池模型』官网也写错了。 (4)

简介: 没想到吧!关于Dubbo的『消费端线程池模型』官网也写错了。 (4)

image.png


image.png


image.png


长度是 16,和 header 的长度吻合,但是里面装的玩意还是没看出来。


但是这样一看,看前两个字节,你就明白了:


image.png


嘿,你说巧了吗,这不是巧了吗,这不是。


魔数也对上了。说明这是一个 Dubbo 的 header。


然后取出第 3 字节,进行位运算,判断这是什么报文:


image.png


前面,我们解决了怎么知道当前到底是响应还是请求报文这个问题。


接下来,进入分支里面就重点关注对响应报文的解析了:


image.png


image.png



从 Debug 的截图里面我们可以看出,当前的状态为 20,表示正常返回。


标记为③的地方,是对心跳包的解析,我们这里不关心。


标记为④的地方,是我们需要重点关注的地方,也是我们一直在寻找的代码。


这个地方就很关键了,大家集中注意力了。


image.png


首先,下面代码的截图是 2.7.5 版本的:


image.png


这里的 if 分支和分支里面的判断条件,就是我们前面说的:


你用脚指头想也知道了。首先肯定是有一个 if 判断的,判断到底在哪(IO线程/客户端线程池)进行响应解析。而这个分支判断的判断条件,按照 Dubbo 的尿性,肯定是可以配置的。


下面这张图片对 2.7.4.1 和 2.7.5 版本这个地方进行一个对比:


image.png


目录
相关文章
|
3月前
|
Java
网络 I/O:单 Selector 多线程(单线程模型)
网络 I/O:单 Selector 多线程(单线程模型)
|
2月前
|
人工智能 JSON 前端开发
【Spring boot实战】Springboot+对话ai模型整体框架+高并发线程机制处理优化+提示词工程效果展示(按照框架自己修改可对接市面上百分之99的模型)
【Spring boot实战】Springboot+对话ai模型整体框架+高并发线程机制处理优化+提示词工程效果展示(按照框架自己修改可对接市面上百分之99的模型)
|
4月前
|
存储 NoSQL Redis
单线程模型想象不到的高并发能力、多路复用是效率杠杆
单线程模型想象不到的高并发能力、多路复用是效率杠杆
|
8天前
|
NoSQL Redis
Redis 线程模型
Redis 线程模型
|
9天前
|
监控 安全 Java
【多线程学习】深入探究阻塞队列与生产者消费者模型和线程池常见面试题
【多线程学习】深入探究阻塞队列与生产者消费者模型和线程池常见面试题
|
15天前
|
Java Linux
【linux线程(三)】生产者消费者模型详解(多版本)
【linux线程(三)】生产者消费者模型详解(多版本)
|
3月前
|
消息中间件 安全 Java
多线程(初阶七:阻塞队列和生产者消费者模型)
多线程(初阶七:阻塞队列和生产者消费者模型)
32 0
|
4月前
|
缓存 NoSQL 安全
Redis 新特性篇:多线程模型解读
Redis 新特性篇:多线程模型解读
52 5
|
4月前
|
存储 缓存 NoSQL
Redis 数据结构+线程模型+持久化+内存淘汰+分布式
Redis 数据结构+线程模型+持久化+内存淘汰+分布式
311 0
|
4月前
|
存储 缓存 NoSQL
《吊打面试官》系列-Redis双写一致性、并发竞争、线程模型
《吊打面试官》系列-Redis双写一致性、并发竞争、线程模型
42 0