{
  "id": "bbg-p0063-architecture-source-map-architecture-source",
  "title": "PostgreSQL Process Architecture",
  "chapter": "database-foundations",
  "batch": "06",
  "rank": 52,
  "sourcePage": 63,
  "sourcePointer": "p. 63",
  "status": "accepted",
  "reviewerStatus": "reviewed",
  "fidelityScore": 0.9,
  "canvas": {
    "width": 960,
    "height": 640
  },
  "fireworksTechGraph": {
    "style": "style-1-flat-icon",
    "diagramType": "architecture",
    "topologyNotes": [
      "source page render inspected",
      "extracted page text inspected",
      "preserve coarse grouping, sequence, and hierarchy from the inspected candidate page",
      "short generic labels only"
    ],
    "publicBoundary": [
      "original vector output",
      "no source pixels",
      "no source mark or long wording"
    ]
  },
  "callouts": [],
  "sourceReview": {
    "conceptAnchors": [
      "concept: Database",
      "concept: Architecture",
      "concept: Architecture Source Map"
    ],
    "labelSource": "source-summary",
    "semanticStatus": "reviewed"
  },
  "groups": [
    {
      "id": "clients",
      "label": "Clients",
      "x": 48,
      "y": 142,
      "w": 174,
      "h": 276
    },
    {
      "id": "processes",
      "label": "Server processes",
      "x": 278,
      "y": 120,
      "w": 398,
      "h": 320
    },
    {
      "id": "storage",
      "label": "Memory and files",
      "x": 728,
      "y": 142,
      "w": 180,
      "h": 276
    }
  ],
  "shapes": [
    {
      "id": "client",
      "kind": "actor",
      "label": "Client",
      "x": 92,
      "y": 224,
      "w": 82,
      "h": 90,
      "tone": "blue"
    },
    {
      "id": "postmaster",
      "kind": "rect",
      "label": "Postmaster",
      "detail": "supervisor",
      "x": 324,
      "y": 154,
      "w": 126,
      "h": 62,
      "tone": "orange"
    },
    {
      "id": "backend",
      "kind": "rect",
      "label": "Backend process",
      "detail": "per connection",
      "x": 498,
      "y": 154,
      "w": 126,
      "h": 62,
      "tone": "green"
    },
    {
      "id": "workers",
      "kind": "rect",
      "label": "Background workers",
      "detail": "maintenance",
      "x": 324,
      "y": 312,
      "w": 146,
      "h": 62,
      "tone": "purple"
    },
    {
      "id": "wal",
      "kind": "rect",
      "label": "WAL writer",
      "detail": "durability",
      "x": 512,
      "y": 312,
      "w": 112,
      "h": 62,
      "tone": "red"
    },
    {
      "id": "memory",
      "kind": "cylinder",
      "label": "Shared memory",
      "detail": "buffers",
      "x": 762,
      "y": 174,
      "w": 112,
      "h": 82,
      "tone": "teal"
    },
    {
      "id": "files",
      "kind": "cylinder",
      "label": "Data and WAL",
      "detail": "files",
      "x": 762,
      "y": 330,
      "w": 112,
      "h": 82,
      "tone": "gray"
    }
  ],
  "connectors": [
    {
      "from": "client",
      "to": "postmaster",
      "label": "connect",
      "flow": "main"
    },
    {
      "from": "postmaster",
      "to": "backend",
      "label": "fork",
      "flow": "control"
    },
    {
      "from": "backend",
      "to": "memory",
      "label": "read write",
      "flow": "data"
    },
    {
      "from": "workers",
      "to": "memory",
      "label": "maintain",
      "flow": "data"
    },
    {
      "from": "wal",
      "to": "files",
      "label": "flush",
      "flow": "control"
    },
    {
      "from": "memory",
      "to": "files",
      "label": "persist",
      "flow": "data"
    }
  ]
}
