refactor(graph): absorb Cartographer into graph-api + wire Graph Indexer
- Wire Graph Indexer library + Persistence into graph-api (csproj refs + DI) - Add build/overlay endpoints matching Scheduler HTTP contracts (POST/GET /api/graphs/builds, POST/GET /api/graphs/overlays) - Add PostgresGraphRepository for reading from graph.graph_nodes/edges - Register SBOM ingest, analytics, change-stream, and inspector pipelines - Comment out Cartographer container in compose (empty shell, Slot 21) - Add cartographer.stella-ops.local as backwards-compat alias on graph-api - Update Scheduler config to target graph.stella-ops.local - Update services-matrix.env, hosts file, port-registry, module-matrix - Update component-map, architecture docs, Scanner/Graph READMEs - Eliminates 1 container (stellaops-cartographer) All 133 existing tests pass (77 Api + 37 Indexer + 19 Core). Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -272,7 +272,8 @@ services:
|
||||
# STELLAOPS_TASKRUNNER_URL removed: TaskRunner service deleted
|
||||
STELLAOPS_SCHEDULER_URL: "http://scheduler.stella-ops.local"
|
||||
STELLAOPS_GRAPH_URL: "http://graph.stella-ops.local"
|
||||
STELLAOPS_CARTOGRAPHER_URL: "http://cartographer.stella-ops.local"
|
||||
# STELLAOPS_CARTOGRAPHER_URL: merged into graph-api; use STELLAOPS_GRAPH_URL instead
|
||||
STELLAOPS_CARTOGRAPHER_URL: "http://graph.stella-ops.local"
|
||||
STELLAOPS_REACHGRAPH_URL: "http://reachgraph.stella-ops.local"
|
||||
STELLAOPS_TIMELINEINDEXER_URL: "http://timelineindexer.stella-ops.local"
|
||||
STELLAOPS_TIMELINE_URL: "http://timeline.stella-ops.local"
|
||||
@@ -1009,7 +1010,7 @@ services:
|
||||
Scheduler__Storage__Postgres__Scheduler__ConnectionString: "${STELLAOPS_POSTGRES_CONNECTION}"
|
||||
Scheduler__Storage__Postgres__Scheduler__SchemaName: "scheduler"
|
||||
Scheduler__Worker__Runner__Scanner__BaseAddress: "http://scanner.stella-ops.local"
|
||||
Scheduler__Worker__Graph__Cartographer__BaseAddress: "http://cartographer.stella-ops.local"
|
||||
Scheduler__Worker__Graph__Cartographer__BaseAddress: "http://graph.stella-ops.local"
|
||||
Scheduler__Worker__Graph__SchedulerApi__BaseAddress: "http://scheduler.stella-ops.local"
|
||||
Scheduler__Worker__Policy__Api__BaseAddress: "http://policy.stella-ops.local"
|
||||
Router__Enabled: "${SCHEDULER_ROUTER_ENABLED:-true}"
|
||||
@@ -1045,7 +1046,7 @@ services:
|
||||
Scheduler__Storage__Postgres__Scheduler__SchemaName: "scheduler"
|
||||
# Worker config
|
||||
Scheduler__Worker__Runner__Scanner__BaseAddress: "${SCHEDULER_SCANNER_BASEADDRESS:-http://scanner.stella-ops.local}"
|
||||
Scheduler__Worker__Graph__Cartographer__BaseAddress: "http://cartographer.stella-ops.local"
|
||||
Scheduler__Worker__Graph__Cartographer__BaseAddress: "http://graph.stella-ops.local"
|
||||
Scheduler__Worker__Graph__SchedulerApi__BaseAddress: "http://scheduler.stella-ops.local"
|
||||
Scheduler__Worker__Policy__Api__BaseAddress: "http://policy.stella-ops.local"
|
||||
# Surface environment
|
||||
@@ -1083,32 +1084,7 @@ services:
|
||||
stellaops:
|
||||
aliases:
|
||||
- graph.stella-ops.local
|
||||
frontdoor: {}
|
||||
healthcheck:
|
||||
test: ["CMD-SHELL", "bash -c 'echo > /dev/tcp/$(hostname)/80'"]
|
||||
<<: *healthcheck-tcp
|
||||
labels: *release-labels
|
||||
|
||||
# --- Slot 21: Cartographer -------------------------------------------------
|
||||
cartographer:
|
||||
<<: *resources-light
|
||||
image: stellaops/cartographer:dev
|
||||
container_name: stellaops-cartographer
|
||||
restart: unless-stopped
|
||||
environment:
|
||||
ASPNETCORE_URLS: "http://+:8080"
|
||||
<<: [*kestrel-cert, *router-microservice-defaults, *gc-light]
|
||||
ConnectionStrings__Default: "${STELLAOPS_POSTGRES_CONNECTION}"
|
||||
ConnectionStrings__Redis: "cache.stella-ops.local:6379"
|
||||
Router__Enabled: "${CARTOGRAPHER_ROUTER_ENABLED:-true}"
|
||||
Router__Messaging__ConsumerGroup: "cartographer"
|
||||
volumes:
|
||||
- ${STELLAOPS_CERT_VOLUME}
|
||||
ports:
|
||||
- "127.1.0.21:80:80"
|
||||
networks:
|
||||
stellaops:
|
||||
aliases:
|
||||
# Backwards-compat: absorb Cartographer traffic (Slot 21 merged into graph-api)
|
||||
- cartographer.stella-ops.local
|
||||
frontdoor: {}
|
||||
healthcheck:
|
||||
@@ -1116,6 +1092,33 @@ services:
|
||||
<<: *healthcheck-tcp
|
||||
labels: *release-labels
|
||||
|
||||
# --- Slot 21: Cartographer (RETIRED -- merged into graph-api Slot 20) ------
|
||||
# cartographer:
|
||||
# <<: *resources-light
|
||||
# image: stellaops/cartographer:dev
|
||||
# container_name: stellaops-cartographer
|
||||
# restart: unless-stopped
|
||||
# environment:
|
||||
# ASPNETCORE_URLS: "http://+:8080"
|
||||
# <<: [*kestrel-cert, *router-microservice-defaults, *gc-light]
|
||||
# ConnectionStrings__Default: "${STELLAOPS_POSTGRES_CONNECTION}"
|
||||
# ConnectionStrings__Redis: "cache.stella-ops.local:6379"
|
||||
# Router__Enabled: "${CARTOGRAPHER_ROUTER_ENABLED:-true}"
|
||||
# Router__Messaging__ConsumerGroup: "cartographer"
|
||||
# volumes:
|
||||
# - ${STELLAOPS_CERT_VOLUME}
|
||||
# ports:
|
||||
# - "127.1.0.21:80:80"
|
||||
# networks:
|
||||
# stellaops:
|
||||
# aliases:
|
||||
# - cartographer.stella-ops.local
|
||||
# frontdoor: {}
|
||||
# healthcheck:
|
||||
# test: ["CMD-SHELL", "bash -c 'echo > /dev/tcp/$(hostname)/80'"]
|
||||
# <<: *healthcheck-tcp
|
||||
# labels: *release-labels
|
||||
|
||||
# --- Slot 22: ReachGraph ---------------------------------------------------
|
||||
reachgraph-web:
|
||||
<<: *resources-light
|
||||
@@ -1272,28 +1275,33 @@ services:
|
||||
<<: *healthcheck-tcp
|
||||
labels: *release-labels
|
||||
|
||||
doctor-scheduler:
|
||||
<<: *resources-light
|
||||
image: stellaops/doctor-scheduler:dev
|
||||
container_name: stellaops-doctor-scheduler
|
||||
restart: unless-stopped
|
||||
environment:
|
||||
ASPNETCORE_URLS: "http://+:80"
|
||||
<<: [*kestrel-cert, *router-microservice-defaults, *gc-light]
|
||||
ConnectionStrings__Default: "${STELLAOPS_POSTGRES_CONNECTION}"
|
||||
ConnectionStrings__Redis: "cache.stella-ops.local:6379"
|
||||
Router__Enabled: "${DOCTOR_SCHEDULER_ROUTER_ENABLED:-true}"
|
||||
Router__Messaging__ConsumerGroup: "doctor-scheduler"
|
||||
volumes:
|
||||
- ${STELLAOPS_CERT_VOLUME}
|
||||
healthcheck:
|
||||
test: ["CMD-SHELL", "bash -c 'echo > /dev/tcp/$(hostname)/80'"]
|
||||
<<: *healthcheck-tcp
|
||||
networks:
|
||||
stellaops:
|
||||
aliases:
|
||||
- doctor-scheduler.stella-ops.local
|
||||
labels: *release-labels
|
||||
# doctor-scheduler: DEPRECATED -- replaced by DoctorJobPlugin in the Scheduler service.
|
||||
# Doctor health check scheduling is now handled by scheduler-web via the plugin architecture.
|
||||
# This service will be removed in a future release. See:
|
||||
# docs/implplan/SPRINT_20260408_003_JobEngine_scheduler_plugin_architecture.md
|
||||
#
|
||||
# doctor-scheduler:
|
||||
# <<: *resources-light
|
||||
# image: stellaops/doctor-scheduler:dev
|
||||
# container_name: stellaops-doctor-scheduler
|
||||
# restart: unless-stopped
|
||||
# environment:
|
||||
# ASPNETCORE_URLS: "http://+:80"
|
||||
# <<: [*kestrel-cert, *router-microservice-defaults, *gc-light]
|
||||
# ConnectionStrings__Default: "${STELLAOPS_POSTGRES_CONNECTION}"
|
||||
# ConnectionStrings__Redis: "cache.stella-ops.local:6379"
|
||||
# Router__Enabled: "${DOCTOR_SCHEDULER_ROUTER_ENABLED:-true}"
|
||||
# Router__Messaging__ConsumerGroup: "doctor-scheduler"
|
||||
# volumes:
|
||||
# - ${STELLAOPS_CERT_VOLUME}
|
||||
# healthcheck:
|
||||
# test: ["CMD-SHELL", "bash -c 'echo > /dev/tcp/$(hostname)/80'"]
|
||||
# <<: *healthcheck-tcp
|
||||
# networks:
|
||||
# stellaops:
|
||||
# aliases:
|
||||
# - doctor-scheduler.stella-ops.local
|
||||
# labels: *release-labels
|
||||
|
||||
# --- Slot 27: OpsMemory (src/AdvisoryAI/StellaOps.OpsMemory.WebService) ---
|
||||
opsmemory-web:
|
||||
|
||||
Reference in New Issue
Block a user