3. Aeron发布与订阅

回顾

上一篇文章主要带大家一起阅读了MediaDriver.launch以及Aeron.connect相关源码,今天就带大家一起看下sub和pub相关的源码设计

Demo

ini 复制代码
public static void main(String[] args)
{
    final String channel = "aeron:ipc";
    final String message = "my message";
    final IdleStrategy idle = new SleepingIdleStrategy();
    final UnsafeBuffer unsafeBuffer = new UnsafeBuffer(ByteBuffer.allocate(256));
    try (MediaDriver driver = MediaDriver.launch();
        Aeron aeron = Aeron.connect();
        Subscription sub = aeron.addSubscription(channel, 10);
        Publication pub = aeron.addPublication(channel, 10))
    {
        while (!pub.isConnected())
        {
            idle.idle(); // 简单理解为阻塞即可
        }
        unsafeBuffer.putStringAscii(0, message);
        System.out.println("sending:" + message);
        while (pub.offer(unsafeBuffer) < 0)
        {
            idle.idle();
        }
        FragmentHandler handler = (buffer, offset, length, header) ->
            System.out.println("received:" + buffer.getStringAscii(offset));
        while (sub.poll(handler, 1) <= 0)
        {
            idle.idle();
        }
    }
}

Sub流程

通过上述流程图可以看到,addSub方法其实会把对应的指令写入到cncBytBuffer里,关于cncFile前一篇文章也介绍了,有不懂的可以再去回顾下。

这里把数据写入到cncFile里后,对应的命令又是谁来处理的呢?答案是:DriverConductor。 DriverConductor通过clientCommandAdapter来处理具体的命令,对应的流程如图:

这里sub有三种类型,ipcSub,spySub,netSub,分别对应进程间sub,本地mock,以及网络sub。 这里可以看到,sub通过完成后,会发送"ON_SUBSCRIPTION_READY"消息,表示当前订阅动作已经完成,ready消息在哪里接受的呢?答案是在awaitRespons方法里,会阻塞等待对应的ready消息 awaitRespons处理流程如下:

最终是在DriverEventsAdapter的onMessage方法里处理ready消息。

这其实就是aeron源码读起来比较困难的地方,并不是传统的a调用b,b调用c,很多地方都是异步的,因此,大家在阅读相关源码的时候,一定不要着急。

Pub流程

addPub方法最终也是把对应的pub指令写入到对应的cncFile里,同样,也是DriverConductor来处理对应的pub指令,对应的流程图如下: 这里pub有两种类型,ipcPub,netPub,分别对应进程间pub和网络pub,对应的ready消息处理和sub一样,也是在DriverEventsAdapter里来处理

小结

本篇文章依然是从最开始的Demo入口,分别分析了sub和pub相关流程,下一篇将会带大家一起看下aeron是如何发送以及接受数据的。

相关推荐
日火3 分钟前
阅读学习:Disruptor技术文档
架构
tiger从容淡定是人生8 分钟前
AI替代软件战略(一):从 CCleaner 到 MCP 架构重构 —— TigerCleaner 的工程实践
人工智能·重构·架构·c#·mcp
一切皆是因缘际会26 分钟前
下一代 AI 架构:基于记忆演化与单向投影的安全智能系统
大数据·人工智能·深度学习·算法·安全·架构
falldeep33 分钟前
五分钟了解OpenClaw底层架构
人工智能·算法·机器学习·架构
Agent产品评测局38 分钟前
流程型制造业生产节拍智能调整,落地方法与案例 | 2026工业AI Agent架构全景解析
人工智能·ai·chatgpt·架构
灰阳阳1 小时前
MySQL的基本架构
数据库·mysql·架构
程序员老邢1 小时前
【产品底稿 11】架构规整收官:从混乱到清晰,工程结构、表命名、模块分层一次性定型
后端·架构·springboot·产品底稿·架构规整·模块分层·数据库规范
大江东去浪淘尽千古风流人物2 小时前
【MASt3R-SLAM】端到端密集SLAM系统:三进程架构与10大核心创新点深度解析
架构
byoass2 小时前
企业云盘高可用架构:主备切换、负载均衡与健康检查实战
运维·网络·安全·架构·云计算·负载均衡
大江东去浪淘尽千古风流人物2 小时前
【cuVSLAM】NVIDIA开源视觉惯性SLAM:GPU全程流水线与创新架构深度梳理
架构·开源