Dapr pub/sub

lua 复制代码
graph TD
    %% 外部系统
    PubSub[(Pub/Sub: RabbitMQ / Kafka / Redis)]

    %% Dapr Sidecar
    subgraph DAPR["Dapr Sidecar"]
        DaprPubSub["Pub/Sub Adapter"]
        GRPCStream["gRPC Stream"]
    end

    %% 应用程序
    subgraph APP["Your App Service"]
        SDK["Dapr SDK Client"]
        GoroutineReceive["Subscribe goroutine (Receive loop)"]
        Listener["WorkflowEventListener"]
        Handler["processCreated / processStop / ..."]
    end

    %% Publish 流程
    AppPub["PublishEvent() 调用"]
    AppPub --> SDK
    SDK --> DaprPubSub
    DaprPubSub --> PubSub

    %% Subscribe 流程
    PubSub --> DaprPubSub
    DaprPubSub --> GRPCStream
    GRPCStream --> GoroutineReceive
    GoroutineReceive --> Listener
    Listener --> Handler
    Handler --> GoroutineReceive
    GoroutineReceive --> DaprPubSub
    DaprPubSub --> PubSub
js 复制代码
sequenceDiagram
    participant PubSub as 外部 Pub/Sub 系统
    participant Dapr as Dapr Sidecar
    participant SDK as Dapr Go SDK
    participant Goroutine as Subscribe goroutine
    participant Handler as 业务 Handler (e.g. processCreated)

    Note over PubSub,Handler: 🟢 消息从发布到消费的全过程

    PubSub->>Dapr: 推送消息 (topic)
    Dapr->>SDK: gRPC 推送事件流
    SDK->>Goroutine: 启动 goroutine (for { s.Receive() })
    Goroutine->>Handler: 为每条消息再启动新的 handler goroutine
    Handler-->>Goroutine: 处理完成 (成功 / 失败)
    Goroutine->>SDK: 调用 respondStatus()
    SDK->>Dapr: Ack 消息状态
    Dapr->>PubSub: 确认消费完成

    Note over SDK,Handler: SDK 内部常驻 goroutine 循环 Receive(),<br>每条消息再开新 goroutine 并发执行 handler。

🧩 流程说明

  1. Pub/Sub → Dapr Sidecar
    外部消息系统(如 RabbitMQ、Kafka、Redis Streams)把消息推给 Dapr sidecar。
  2. Dapr Sidecar → SDK (gRPC 流)
    Dapr 通过 gRPC 双向流,把消息推送到你的应用。
  3. SDK → goroutine (接收循环)
    SubscribeWithHandler() 内部启动一个 goroutine,循环执行 Receive()
  4. 每条消息再开 goroutine 调用 handler
    当消息到达时,SDK 再为该消息启动一个新的 goroutine 调用你的 handler(如 processCreated)。
  5. handler 执行完成后 ack
    handler 执行完,SDK 通过 respondStatus() 向 Dapr 返回 ack。
  6. Dapr 通知外部系统确认消费
    Dapr 发送 ack 给 Pub/Sub 确认这条消息被成功处理。

🔑 关键特征

阶段 并发模型 是否阻塞
SDK 启动订阅循环 goroutine 常驻 阻塞在 Receive()
handler 执行 每条消息独立 goroutine 不阻塞主循环
ack 流程 异步返回 非阻塞
相关推荐
人道领域9 分钟前
Day | 10【苍穹外卖:SpringTask 和WebSocket 案例】
java·数据库·后端
无籽西瓜a13 分钟前
WebSocket详解含图解:协议特性、握手流程
网络·后端·websocket·网络协议·http
计算机学姐20 分钟前
基于SpringBoot+Vue的家政服务预约系统【个性化推荐+数据可视化】
java·vue.js·spring boot·后端·mysql·信息可视化·java-ee
智能工业品检测-奇妙智能20 分钟前
Ubuntu24安装mysql8
人工智能·spring boot·后端·openclaw·奇妙智能
Dream_sky分享31 分钟前
Excel模板下载(Resources目录下)
java·spring boot·后端
羊小猪~~31 分钟前
算法/力扣--链表经典题目
数据结构·后端·考研·算法·leetcode·链表·面试
Anastasiozzzz32 分钟前
编程语言错误处理的清流:Go 错误处理
开发语言·后端·golang
木易 士心38 分钟前
自然语言转数据库操作语句原理架构图分析和实现
数据库·后端
jgbazsh40 分钟前
Spring中把一个bean对象交给Spring容器管理的三种方式
java·后端·spring
华仔啊1 小时前
前端不懂 Java?后端怕 CSS?这套AI全栈方案专治各种偏科
java·前端·后端