{
  "id": "bbg-p0419-messaging-events-and-streaming-messaging",
  "title": "Kafka Log vs RabbitMQ Broker",
  "chapter": "messaging-events-and-streaming",
  "batch": "17",
  "rank": 166,
  "sourcePage": 419,
  "sourcePointer": "p. 419",
  "status": "accepted",
  "reviewerStatus": "reviewed",
  "fidelityScore": 0.9,
  "canvas": {
    "width": 960,
    "height": 640
  },
  "fireworksTechGraph": {
    "style": "style-1-flat-icon",
    "diagramType": "comparison",
    "topologyNotes": [
      "source page render inspected",
      "extracted page text inspected",
      "source page render inspected",
      "preserve comparison: Kafka producers append to retained partitions and consumers pull by offset; RabbitMQ producers publish to exchanges routed into queues and consumers acknowledge work",
      "omit source branding and copied feature microtext"
    ],
    "publicBoundary": [
      "original vector output",
      "no source pixels",
      "no source mark or long wording"
    ]
  },
  "callouts": [],
  "sourceReview": {
    "conceptAnchors": [
      "concept: Kafka distributed log",
      "concept: retained partitions",
      "concept: consumer offsets",
      "concept: RabbitMQ exchange",
      "concept: queue acknowledgements"
    ],
    "labelSource": "curated",
    "semanticStatus": "reviewed"
  },
  "groups": [
    {
      "id": "kafka",
      "label": "Kafka: retained event log",
      "x": 58,
      "y": 118,
      "w": 392,
      "h": 384
    },
    {
      "id": "rabbit",
      "label": "RabbitMQ: routed work queues",
      "x": 510,
      "y": 118,
      "w": 392,
      "h": 384
    }
  ],
  "shapes": [
    {
      "id": "kProducer",
      "kind": "rect",
      "label": "Producers",
      "detail": "append events",
      "x": 100,
      "y": 160,
      "w": 120,
      "h": 58,
      "tone": "blue"
    },
    {
      "id": "topic",
      "kind": "queue",
      "label": "Topic partitions",
      "detail": "retained log",
      "x": 278,
      "y": 164,
      "w": 130,
      "h": 52,
      "tone": "purple"
    },
    {
      "id": "offsets",
      "kind": "table",
      "label": "Offsets",
      "detail": "per group",
      "x": 150,
      "y": 302,
      "w": 132,
      "h": 82,
      "tone": "teal"
    },
    {
      "id": "kConsumers",
      "kind": "rect",
      "label": "Consumers",
      "detail": "pull replay",
      "x": 300,
      "y": 314,
      "w": 112,
      "h": 58,
      "tone": "green"
    },
    {
      "id": "rProducer",
      "kind": "rect",
      "label": "Producers",
      "detail": "publish",
      "x": 552,
      "y": 160,
      "w": 120,
      "h": 58,
      "tone": "blue"
    },
    {
      "id": "exchange",
      "kind": "diamond",
      "label": "Exchange",
      "detail": "route",
      "x": 718,
      "y": 146,
      "w": 118,
      "h": 86,
      "tone": "orange"
    },
    {
      "id": "queue",
      "kind": "queue",
      "label": "Queues",
      "detail": "work items",
      "x": 590,
      "y": 314,
      "w": 126,
      "h": 52,
      "tone": "purple"
    },
    {
      "id": "ack",
      "kind": "rect",
      "label": "Consumers",
      "detail": "ack delete",
      "x": 762,
      "y": 306,
      "w": 112,
      "h": 58,
      "tone": "green"
    }
  ],
  "connectors": [
    {
      "from": "kProducer",
      "to": "topic",
      "label": "append",
      "flow": "async"
    },
    {
      "from": "topic",
      "to": "kConsumers",
      "label": "pull",
      "flow": "main"
    },
    {
      "from": "kConsumers",
      "to": "offsets",
      "label": "commit",
      "flow": "data"
    },
    {
      "from": "offsets",
      "to": "topic",
      "label": "replay",
      "flow": "control",
      "dashed": true
    },
    {
      "from": "rProducer",
      "to": "exchange",
      "label": "publish",
      "flow": "async"
    },
    {
      "from": "exchange",
      "to": "queue",
      "label": "bind key",
      "flow": "control"
    },
    {
      "from": "queue",
      "to": "ack",
      "label": "deliver",
      "flow": "main"
    },
    {
      "from": "ack",
      "to": "queue",
      "label": "ack",
      "flow": "data",
      "dashed": true
    }
  ]
}
