feat(agent): Agent updates/SIEM #1071
Open
opened 2026-03-28 04:31:23 +00:00 by mfreeman451
·
2 comments
No Branch/Tag specified
staging
demo/prod-release
add-dashboard-srql-service-views
enhance-dashboard-creator-visual-builder
fix-release-1-2-78-ci-failures
refactor-agent-plugin-runtime
add-dashboard-creator
update/plugin-system
add-service-monitoring-foundation
fix/cli-auth-settings-navigation
fix/device-unknown-facet
fix-plugin-assignment-upgrades
fix/sweep-profile-mode-status
fix/armis-northbound-fixes
fix-proxmox-console-react-client-render
fix-openbao-signing-job-token-mount
fix-services-plugin-status-read-model
fix-stream-status-final-chunk
codex/fix-prod-armis-sync-icmp
fix-demo-cnpg-operator-networkpolicy
update/docs-cleanup
fix-armis-northbound-raw-token-auth
fix-armis-northbound-stuck-running
update-manual-device-hostname-readd
fix/observability-severity-card-links
renovate/debian_testing_slim-testing-slim
docs/kubernetes-ingestion-gateway
fix/flow-collector-external-network-policy
fix/armis-availability-and-stream-config
refactor-fast-fresh-db-bootstrap
fix/cnpg-not-found
fix/docker-update/cnpg
renovate/debian_bookworm_slim-bookworm-slim
add-socket-firewall-ci
add-ipv6-sweep-scanners
fix-armis-northbound
add-streamed-agent-config
fix/sweep-ip-family-routing
codex/fix-core-migration-hook-upgrade
renovate/arc_runner
renovate/actions_runner
codex/remote-access-desktop-rdp
updates/missing-fixes
fix/batched-sweep-targets
fix/agent-sysmon-memory-growth
fix/armis-northbound-single-run-and-timestamps
release/1.2.67
fix/wasm-plugin-service-status
fix/armis-names-string
codex/harden-remote-access-app-tcp-followup
codex/harden-remote-access-app-tcp
codex/harden-gateway-proxy-auth
codex/harden-remote-access-destroy-rbac
codex/harden-ssh-ca-remote-access
codex/harden-remote-access-broker-registry
codex/harden-remote-access-approval-policy
codex/harden-remote-access-file-transfer
codex/harden-remote-access-attach-ticket
fix-release-plugin-list-cleanup
codex/harden-grpc-logger-payloads
propose-interface-action-target-context
add-signed-northbound-action-callbacks
fix/reap-stale-self-scheduled-oban-jobs
fix/device-logs-tab-async
fix/device-metadata-summary
fix/northbound-launch-target-auth
fix/northbound-provider-atomic-read
proposal/add-sample-northbound-wasm-plugin
proposal/northbound-action-integrations
fix/ansible-run-job-device-launch
codex/fix-audit-events-shell-theme
codex/fix-sweep-tcp-availability
codex/fix-armis-names-string
fix/update-nats-2-14
fix/elixir-quality-release-blockers
fix/latest-release-device-ingest-ui-bugs
fix/release-1.2.61-ci-failures
fix/web-ng-precommit-format
fix/wasm-tinygo-go125
fix/agent-file-transfer-bazel-src
fix/release-key-stamp-root
fix/release-1.2.59-staging
main
fix/agent-accept-deprecated-remote-access-config
fix/device-results-count-facets
fix/bazelisk-installer-retries
fix/tinygo-host-toolchain-fetch
add-per-agent-availability
fix/forgejo-release-multipart-assets
fix/agent-config-stale-session
fix/mtr-hop-dns-resolution
fix/hostname-only-device-create
fix/otlp-log-metadata-sanitization
fix/sweep-icmp-legacy-mode-classification
add-nats-object-store-retention
fix/helm-serviceradar-state-pvc
harden/forgejo-ci-nonroot
codex/expand-remote-access-teleport-parity
fix/sweep-port-history-consistency
fix/remote-access-ssh-feature-flag
fix/devices-refresh-artifacts
fix/identity-ingestion-sweep-availability
spec/identity-cache-ingestion-correctness
fix/sweep-mapper-promotion-stale-cache
fix/sweep-provisional-duplicate-ip
fix/sweep-target-invalid-ip-order
fix/armis-large-sync-streaming
fix/docusaurus-blog-build-date
fix/armis-sync-compat-deep-dive
fix/awx-controller-credential-secret
fix/demo-release-source-branch
demo/release-v1.2.44-source-fix
codex/teleport-agent-routed-remote-access
feature/agent-config-dependency-catalog
proposal/agent-config-dependency-catalog
bugfix/armis-credentials-save-display
bugfix/armis-integration-credentials
fix/web-ng-precommit-formatting
bugfix/armis-secret-config-push
feature/close-controllers-to-pipelines
carverauto/extract-palisade
feature/migrate-dashboard-cli-to-plugs
feature/audit-history-page
feature/migrate-controllers-to-security-pipelines
fix/security-events-test-and-retention-worker
feature/add-platform-security-hardening
demo-rollout-proxmox-bazel-fix
bug/armis-sync-issues
add-virtualization-srql-queries
add-proxmox-ingestion-hardening-tests
add-ssh-private-key-credential-rules
redact-plugin-credential-material
add-credential-rules-settings-entry
add-credential-rules-settings-flows
require-network-credential-broker-grants
preview-credential-rule-target-scope
add-proxmox-credential-secret-preset
harden-credential-rules-live-tests
clarify-proxmox-plugin-credential-modes
docs-proxmox-credential-operations
fingerprint-proxmox-candidates
proxmox-resource-efficiency-dashboard
proxmox-console-security-docs
proxmox-focused-quality-validation
proxmox-metric-baseline-alerts
proxmox-device-scoped-logs
proxmox-defer-vector-log-forwarding
proxmox-console-session-tickets
proxmox-console-xterm-shell
proxmox-console-websocket-broker
proxmox-console-control-frames
proxmox-console-agent-session-manager
proxmox-console-plugin-pty-bridge
proxmox-console-assignment-materializer
proxmox-console-ssh-connector
proxmox-console-agent-local-broker
proxmox-console-device-actions
proxmox-console-stream-timeouts
proxmox-console-guest-mode-gating
proxmox-console-ci-race-fix
fix/falco-alert-routing-datasvc-channel
fix-agent-release-page-bugs
add-proxmox-device-details-summary
add-proxmox-virtualization-ingestor
add-virtualization-inventory-schema
add-proxmox-infrastructure-inventory
add-proxmox-plugin-live-smoke
add-proxmox-local-api-smoke
add-proxmox-credential-test-dispatch
add-proxmox-credential-test-plan
add-network-credential-rule-preview
add-proxmox-plugin-inventory-details
add-proxmox-credential-reconcile-worker
add-proxmox-credential-assignment-materializer
add-plugin-input-template-secret-refs
add-proxmox-plugin-policy-inputs
add-proxmox-wasm-plugin-scaffold
add-network-credential-rules-model
add-proxmox-plugin-credential-rules
fix/rperf-rustls-provider-demo
fix/dashboard-template-sdk-014
fix/tinygo-go126-release
fix/reqsign-provider-bazel-deps
fix/release-bazel-rust-crates
fix/core-coordinator-connection-leak
chore/security-updates
update/readme-versions-update
docs/readme-dashboard-sdk
chore/cli-0.1.5
fix/dashboard-cli-local-map-dev
fix/dashboard-cli-hmr-map-libraries
chore/bump-serviceradar-cli-0.1.2
fix/dashboard-cli-hmr-harness
fix/helm-contour-liveview-websocket
fix/helm-cnpg-pooler-defaults
updates/helm-fixes
update/fix-light-mode-analytics
ual/dashboard-sdk-dx
security/postgres-update
update-falco-alert-diagnostics
ual/react-dashboard-sdk
fix/cnpg-saturation-fk-and-bootstrap
ual/wifi-site-map
fix-coraza-log-db-writer
fix-log-viewer-syslog-processed
plan-fieldsurvey-spatial-selection
plan-envoy-coraza-waf
plan-alienvault-otx-integration
plan-fieldsurvey-sidekick-daemon
cleanup-openspec-archive-closed-proposals
bug-core-elx-ip-enrichment-reap
fix-release-libcap2-pin-v125
fix-camera-stream-gateway-route
add-core-elx-prometheus-metrics
add-serviceradar-observability-dashboards
add-pgbouncer-helm-cnpg
renovate/ghcr.io-actions-actions-runner
feat/cluster-agent-runtime-metadata-stability
feat/observability-shell-standardization
feat/observability-live-log-toggle
fix/mtr-bulk-queue-and-srql-targets
fix/mtr-profile-protocol-keyerror
fix/mtr-diagnostics-keyerror
add-demo-rollout-skills
fix-web-ng-test-support-dialyzer
fix-web-ng-dialyzer-findings
add-bulk-queued-mtr-diagnostics
fix-serviceradar-core-integration-failures
harden-agent-updater-exec-arguments
harden-agent-release-trust-boundaries
fix-compose-hermetic-nats-datasvc-bootstrap
fix/openbao-release-issues
elixir/formatting-updates
codex/demo-cnpg-signing-release-fixes
chore/lint-fixes
fix/bazel-alpine-bump-and-cosign-skip
update-event-alert-dedup-and-suppression
armis-northbound-events
armis-northbound-availability-updates
push-owvypksrmooo
codex/topology-endpoint-evidence-investigation
codex/topology-bootstrap-and-layout-simplification
codex/remove-ingress-nginx-edge
fix/forgejo-ci-snmp-cache-and-ubuntu24
bug/cnpg-mtls-failure
bug/log-collector
fix/forgejo-runner-labels
fix/cargo-lock-sync
remove-arc-runner-from-push-all
fix-push-all-cosign-preflight
fix-go-ci
add-versioned-openapi-publish
chore/forgejo-hardening
security/k8s-hardening
update/cluster-page-agents
updates/helm-security-updates
2406-feat-agent-fleet-management-secure-self-update-system
bug/k8s-helm-deployments
chore/k8s-arc-update
rust-fix
2371-analytics-stats-cards-should-abbreviate-numbers
chore/perl-cleanup
2942-featweb-ng-add-logs-tab-to-device-details-page
192-feat-tftp-server
mikemiles-dev/feature/netflow_collection
testing
dependabot/cargo/hostname-0.4.1
dependabot/cargo/redis-1.0.1
dependabot/cargo/bb8-0.9.0
dependabot/cargo/rcgen-0.14.6
dependabot/cargo/hyper-1.8.1
dependabot/cargo/hyper-util-0.1.19
dependabot/cargo/clap-4.5.51
dependabot/cargo/thiserror-2.0.17
dependabot/cargo/time-tz-2.0.0
dependabot/cargo/tonic-build-0.14.2
backup/main-pre-staging-sync-2026-04-02
dependabot/npm_and_yarn/docs/mdast-util-to-hast-13.2.1
815-feat-support-win32-for-agentpoller
gh-pages
v1.2.79
v1.2.78
v1.2.77
v1.2.76
v1.2.75
v1.2.74
v1.2.73
v1.2.72
v1.2.71
v1.2.70
v1.2.69
v1.2.68
v1.2.67
v1.2.66
v1.2.65
v1.2.64
v1.2.63
v1.2.62
v1.2.61
v1.2.60
v1.2.59
v1.2.58
v1.2.57
v1.2.54
v1.2.53
v1.2.52
v1.2.51
v1.2.50
v1.2.49
v1.2.48
v1.2.47
v1.2.46
v1.2.45
v1.2.44
v1.2.43
v1.2.42
v1.2.41
v1.2.40
v1.2.39
v1.2.38
sha-de6d1025d59f039188754b895ff7fe65db9b306b
sha-8006b6105635acf43060fab2613eab3bccb1efcf
v1.2.37
v1.2.36
v1.2.35
v1.2.34
v1.2.33
v1.2.32
v1.2.31
v1.2.30
v1.2.29
v1.2.28
v1.2.27
v1.2.26
v1.2.25
v1.2.24
v1.2.23
v1.2.22
v1.2.21
v1.2.20
v1.2.19
v1.2.18
v1.2.17
v1.2.16
v1.2.15
v1.2.14
v1.2.13
v1.2.12
v1.2.11
v1.2.6
v1.2.10
v1.2.9
v1.2.8
v1.2.7
v1.2.5
v1.2.4
v1.2.3
v1.2.2
v1.2.1
v1.2.0
v1.1.2
v1.1.0
v1.0.92
v1.0.91
v1.0.90
v1.0.89
v1.0.88
v1.0.87
v1.0.86
v1.0.85
v1.0.84
v1.0.83
v1.0.82
v1.0.81
v1.0.78
v1.0.77
v1.0.76
v1.0.70
v1.0.69
v1.0.68
v1.0.67
v1.0.66
v1.0.65
v1.0.64
v1.0.63
v1.0.62
v1.0.61
v1.0.60
v1.0.59
v1.0.58
1.0.57
v1.0.56
v1.0.55
v1.0.54-pre5
v1.0.53
v1.0.53-pre19
v1.0.53-pre18
v1.0.53-pre17
v1.0.53-pre15
1.0.53-pre10
1.0.53-pre9
1.0.53-pre8
1.0.53-pre7
1.0.53-pre6
1.0.53-pre5
1.0.53-pre4
1.0.53-pre3
1.0.53-pre2
1.0.53-pre1
1.0.52
1.0.51
1.0.50
1.0.49
1.0.49-pre5
1.0.49-pre4
1.0.49-pre3
1.0.49-pre2
1.0.48
1.0.48-rc2
1.0.48-rc1
1.0.48-pre8
1.0.48-pre7
1.0.48-pre6
1.0.48-pre5
1.0.48-pre4
1.0.48-pre3
1.0.48-pre2
1.0.48-pre1
1.0.47
1.0.47-pre8
1.0.47-pre7
1.0.47-pre6
1.0.47-pre5
1.0.47-pre4
1.0.47-pre3
1.0.47-pre2
1.0.47-pre1
1.0.46
1.0.46-pre9
1.0.46-pre8
1.0.46-pre7
1.0.46-pre6
1.0.46-pre5
1.0.46-pre4
1.0.46-pre3
1.0.46-pre2
1.0.46-pre1
1.0.45
1.0.44
1.0.44-pre12
1.0.44-pre11
1.0.44-pre10
1.0.44-pre9
1.0.44-pre8
1.0.44-pre7
1.0.44-pre6
1.0.44-pre5
1.0.44-pre4
1.0.44-pre3
1.0.44-pre2
1.0.44-pre1
1.0.43
1.0.42
1.0.41
1.0.41-pre1
1.0.40
1.0.40-pre11
1.0.40-pre10
1.0.40-pre9
1.0.40-pre8
1.0.40-pre7
1.0.40-pre6
1.0.40-pre5
1.0.40-pre4
1.0.40-pre3
1.0.40-pre2
1.0.40-pre1
1.0.39
1.0.38
1.0.37
1.0.36
1.0.36-pre5
1.0.36-pre4
1.0.36-pre3
1.0.36-pre2
1.0.35
1.0.35-pre3
1.0.35-pre2
1.0.35-pre
1.0.34-pre3
1.0.34-pre2
1.0.34-pre1
1.0.33
1.0.33-pre2
1.0.33-pre
1.0.32
1.0.31
1.0.30
1.0.29
1.0.28
1.0.27
1.0.26
1.0.25
1.0.24
1.0.23
1.0.22
1.0.21
1.0.20
1.0.19
1.0.18
1.0.17
1.0.16
1.0.15
1.0.14
1.0.13
1.0.11
1.0.10
1.0.9
1.0.8
1.0.7
1.0.6
1.0.5
1.0.4
1.0.3
1.0.2
1.0.1
1.0.0
Labels
Clear labels
1week
2weeks
Failed compliance check
IP cameras
NATS
NATS JetStream
Possible security concern
Review effort 1/5
Review effort 2/5
Review effort 3/5
Review effort 4/5
Review effort 5/5
UI
aardvark
accessibility
amd64
api
arm64
auth
back-end
bgp
blog
bug
Something isn't working
build
checkers
ci-cd
continuous integration-continuous deployments
cleanup
cnpg
cloud-native postgres
codex
core
core service
dependencies
Pull requests that update a dependency file
device-management
documentation
Improvements or additions to documentation
duplicate
This issue or pull request already exists
dusk
ebpf
enhancement
New feature or request
eta 1d
eta 1hr
eta 3d
eta 3hr
feature
fieldsurvey
github_actions
Pull requests that update GitHub Actions code
go
Pull requests that update Go code
good first issue
Good for newcomers
help wanted
Extra attention is needed
invalid
This doesn't seem right
javascript
Pull requests that update Javascript code
k8s
log-collector
mapper
mtr
multi traceroute
needs-triage
netflow
network-sweep
observability
oracle
Oracle Linux related issues
otel
opentelemetry logs, traces, metrics
plug-in
proton
timeplus proton streaming database
python
question
Further information is requested
reddit
redhat
research
rperf
rperf-checker
rust
Pull requests that update rust code
sdk
security
serviceradar-agent
serviceradar-agent-gateway
serviceradar-web
serviceradar-web-ng
siem
snmp
sysmon
topology
ubiquiti
wasm
wontfix
This will not be worked on
zen-engine
No labels
1week
2weeks
Failed compliance check
IP cameras
NATS
Possible security concern
Review effort 1/5
Review effort 2/5
Review effort 3/5
Review effort 4/5
Review effort 5/5
UI
aardvark
accessibility
amd64
api
arm64
auth
back-end
bgp
blog
bug
build
checkers
ci-cd
cleanup
cnpg
codex
core
dependencies
device-management
documentation
duplicate
dusk
ebpf
enhancement
eta 1d
eta 1hr
eta 3d
eta 3hr
feature
fieldsurvey
github_actions
go
good first issue
help wanted
invalid
javascript
k8s
log-collector
mapper
mtr
needs-triage
netflow
network-sweep
observability
oracle
otel
plug-in
proton
python
question
reddit
redhat
research
rperf
rperf-checker
rust
sdk
security
serviceradar-agent
serviceradar-agent-gateway
serviceradar-web
serviceradar-web-ng
siem
snmp
sysmon
topology
ubiquiti
wasm
wontfix
zen-engine
Milestone
Clear milestone
No items
No milestone
Projects
Clear projects
No items
No project
Assignees
Clear assignees
No assignees
1 participant
Notifications
Due date
The due date is invalid or out of range. Please use the format "yyyy-mm-dd".
No due date set.
Dependencies
No dependencies set.
Reference
carverauto/serviceradar#1071
Loading…
Add table
Add a link
Reference in a new issue
No description provided.
Delete branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Imported from GitHub.
Original GitHub issue: #2936
Original author: @mfreeman451
Original URL: https://github.com/carverauto/serviceradar/issues/2936
Original created: 2026-02-27T21:15:40Z
Product Requirements Document: ServiceRadar Next-Gen SIEM & Observability Platform
Version: 2.0
Author: Carver Automation Corporation
Date: February 2026
Status: Draft
1. Executive Summary
ServiceRadar is evolving from a network visibility tool into a true Single Pane of Glass (SPOG) for automated datacenter management, observability, and next-generation SIEM. Target environments include bare metal servers, Proxmox (VMs/LXCs), and Kubernetes clusters.
By utilizing a pure-Golang single-binary agent, a high-speed gRPC/NATS data plane, an Elixir/BEAM backend, and a heavily extended CloudNativePG (CNPG) database, ServiceRadar will provide Datadog/CrowdStrike-tier capabilities—entirely open-source and natively within our own infrastructure.
1.1 Design Principles
serviceradar-agent). No Wazuh, no Fleet/osquery, no legacy C/C++ agents on endpoints.2. Architectural Overview
The platform is divided into four strictly controlled layers, with one specific exception for Kubernetes-native security telemetry.
2.1 Layer Diagram
2.2 Data Flow Summary
gopsutil)telemetry.metrics.edgesecurity.falco.alertsscan.trivy.resultssecurity.xdp.dropstopology.connectionscommands.agent.{id}3. Core Epics & Feature Requirements
Epic 1: The Edge Go Agent (
serviceradar-agent)Goal: Eliminate agent fatigue at the edge with one highly optimized Go binary. No Wazuh, no Fleet/osquery—deploy one binary that does everything.
1.1 Native Telemetry (
gopsutil+ Container SDKs)shirou/gopsutil.github.com/docker/docker/client) and LXC Go SDK (github.com/lxc/go-lxc) to map raw Linux PIDs to specific container names, image tags, and Proxmox LXC IDs.gopsutil/net.Connections()to map active network connections for topology discovery.1.2 Embedded Vulnerability Scanner (Trivy)
dpkg/rpmparsing—itsrootfsscan mode outputs structured JSON of all installed OS packages, Python packages, Node modules, etc.1.3 eBPF / XDP Network Security (Edge Firewalling)
cilium/ebpfto drop malicious packets at wire-speed on bare metal and Proxmox hosts.1.4 Kubernetes Runtime Security (The Falco Exception)
security.falco.alertsJetStream subject.agent-gatewaywould be an unnecessary bottleneck.Epic 2: The Data Plane (gRPC + NATS JetStream)
Goal: Create a massively scalable, back-pressure-resistant pipeline. Edge agents are strictly proxied through the gateway, while trusted K8s workloads get direct NATS access.
2.1 Command & Control (Bi-Directional gRPC Streaming)
agent-gateway.commands.agent.{agent_id}.2.2 Edge Telemetry Firehose (Client-Side gRPC Streaming)
gopsutilmetrics, Trivy results, and XDP drop events, streaming them to the gateway via client-side gRPC streaming.telemetry.metrics.edge,scan.trivy.results,security.xdp.drops).2.3 The Kubernetes Exception (Direct NATS Ingestion)
agent-gatewayentirely.security.falco.alerts.2.4 Air-Gapped Trivy DB Distribution (Server-Side gRPC Streaming)
The Trivy CVE database can be 50–100MB+. This pipeline ensures agents can scan offline without hitting GitHub rate limits.
{"event": "trivy_db_update", "version": "v2.1.0"}.Epic 3: Smart Execution & Remediation (AWX Engine)
Goal: ServiceRadar acts as the brain, AWX acts as the hands. AWX is already deployed in the K8s cluster and provides a robust REST API over Ansible.
3.1 Event-Driven Patching
POST /api/v2/job_templates/{id}/launch/), passing the target Proxmox LXC/VM hostname as an extra-var.apt,yum,win_updatesmodules), and sends a webhook back to ServiceRadar when the job completes.3.2 Running vs. Dormant Vulnerability Correlation
This is the key differentiator—correlating static vulnerability data with live runtime state.
gopsutilprocess data shows which binaries are currently executing in memory.3.3 AWX Integration Setup
patch_server.yml,isolate_host.yml).community.general.proxmox) to manage VMs/LXCs, andkubernetes.corefor K8s cluster state.Epic 4: Next-Gen SIEM & Observability Datastore (CNPG)
Goal: Replace Elasticsearch, OpenSearch, and Neo4j by pushing all advanced analytics directly into heavily optimized PostgreSQL extensions within CloudNativePG.
4.1 Time-Series Metrics & Logs (TimescaleDB)
gopsutilsystem metrics (CPU, RAM, disk, network I/O), XDP firewall drop logs, and structured log streams.4.2 Relational Tables (Standard PostgreSQL)
has_manypackages, a packagebelongs_to_manyCVEs. Standard Postgres handles this naturally with Ash Framework resources.4.3 Network Graphing & Blast Radius (Apache AGE)
gopsutil/net.Connections()and sends connection data to core-elx over NATS.(Process A on Host 1) -[CONNECTS_TO]-> (Port 5432 on Host 2).4.4 Full-Text Search (ParadeDB / BM25)
bm25index within CNPG.4.5 Semantic & AI Search (pgvector / HNSW)
tail -n 10 /etc/shadowinstead ofcat /etc/shadow). Keywords miss this; vector similarity catches it.all-MiniLM-L6-v2, 22–90MB) entirely within the BEAM VM on CPU.4. Feature Deep-Dive: SRQL (ServiceRadar Query Language)
To provide a world-class threat hunting experience, ServiceRadar introduces SRQL, a custom DSL parsed by Elixir that compiles down to highly optimized Postgres queries leveraging ParadeDB (BM25) and pgvector (semantic search).
4.1 SRQL Syntax & Compilation
SRQL allows analysts to pipe (
|) exact keyword matches into semantic filters natively in the UI search bar.Example 1: Pure ParadeDB Search (Keyword)
Elixir compiles this to a ParadeDB
paradedb.search()query using BM25 scoring. Extremely fast exact matches.Example 2: Semantic Threat Hunting (pgvector)
Elixir uses Bumblebee to vectorize the string, then compiles to:
Example 3: Hybrid Query (Keyword → Semantic Pipeline)
Compilation:
host:proxmox-node-01ANDseverity:high(reducing 50M rows to ~5,000).Result: AI-driven threat hunting with minimal latency, entirely on-premise.
4.2 Automated Semantic Deduplication ("Smart Alert Grouping")
Instead of overwhelming the UI with 10,000 Falco syscall alerts or XDP drop logs, core-elx runs a vector clustering algorithm. The UI displays: "10,000 events occurred, but they represent only 3 semantically unique attack patterns."
5. Embedding Strategy: CPU-First, GPU-Optional
A GPU must not be a hard requirement for deployment. Embedding models are small mathematical functions, not LLMs.
5.1 Model Selection
Use micro-models only:
all-MiniLM-L6-v2orbge-micro-v2(22–90MB). These fit entirely in L3 cache and generate an embedding for a log line in under 5–10ms on CPU.5.2 EXLA + CPU SIMD Optimization
Nx uses EXLA (Google's XLA compiler) under the hood. At application boot, EXLA JIT-compiles the Bumblebee embedding model to native machine code targeting AVX-512 and SIMD instructions on the host CPU, enabling multiple vector operations per clock cycle.
5.3 Broadway Batching (Never Embed 1-by-1)
Broadway pulls messages from NATS JetStream and groups them. Configure Broadway to batch 256 logs or wait 500ms (whichever comes first). Pass the entire batch to Bumblebee at once—the CPU vectorizes all 256 logs simultaneously via matrix multiplication, increasing throughput by orders of magnitude over sequential processing.
5.4 Selective Vectorization
Not all logs warrant embedding. The Elixir pipeline applies a fast pattern-match filter before the embedding stage.
Route to Bumblebee (embed):
level: warning,error, orcriticalBypass Bumblebee (keyword-only via ParadeDB):
5.5 Auto-Detect GPU (Progressive Enhancement)
At application boot in
runtime.exs, check for NVIDIA/CUDA drivers viaSystem.cmd("nvidia-smi", ...). If present, configure Nx to use the CUDA backend for dramatically faster embedding throughput. If absent, fall back to CPU EXLA—still performant for the micro-models used.6. Deployment & Tech Stack Summary
gopsutil,lxc/go-lxc, Trivy,cilium/ebpf7. Rejected Alternatives & Rationale
gopsutil+ Docker/LXC Go SDKs + Trivy SBOMs already provide equivalent system state natively in the Go agent.8. Phase 1 Deliverables & Next Steps
Phase 1A: Core Infrastructure
security.falco.alerts.gopsutil→ agent → gRPC → gateway → NATS → Broadway (Elixir) → TimescaleDB hypertable.Phase 1B: Vulnerability Pipeline
gopsutilrunning processes to auto-classify vulnerability severity.Phase 1C: SIEM Search
all-MiniLM-L6-v2via Bumblebee. Implement selective vectorization in the Broadway pipeline. Validate "Find Similar" queries against test security events.Phase 1D: Topology & Visualization
gopsutil/net.Connections()data into Apache AGE via Cypher. Build initial blast radius query and visualization in the ServiceRadar UI.Imported GitHub comment.
Original author: @mfreeman451
Original URL: https://github.com/carverauto/serviceradar/issues/2936#issuecomment-3975186653
Original created: 2026-02-27T21:32:09Z
might want to include this as part of the update as well https://github.com/carverauto/serviceradar/issues/2787
Imported GitHub comment.
Original author: @mfreeman451
Original URL: https://github.com/carverauto/serviceradar/issues/2936#issuecomment-4018075164
Original created: 2026-03-08T03:16:22Z
https://awesomeagents.ai/news/claude-code-sandbox-escape-denylist/