Find a file
2026-04-25 23:41:38 +01:00
.devcontainer Update pinned Go toolchain to 1.25.9 2026-04-18 10:04:34 +01:00
.github Harden release Docker key embedding cache 2026-04-24 17:21:04 +01:00
.husky feat: Pulse v6 release 2026-03-18 16:06:30 +00:00
cmd Harden hosted mobile proof setup 2026-04-24 13:13:36 +01:00
deploy/helm/pulse Prepare the v6 stable promotion candidate 2026-04-20 14:09:17 +01:00
dev/oidc feat: Pulse v6 release 2026-03-18 16:06:30 +00:00
docs Add fleet governance projection 2026-04-25 23:41:38 +01:00
frontend-modern Add fleet governance projection 2026-04-25 23:41:38 +01:00
internal Add fleet governance projection 2026-04-25 23:41:38 +01:00
pkg Improve Pulse Assistant approval continuity 2026-04-24 09:13:39 +01:00
scripts Add fleet governance projection 2026-04-25 23:41:38 +01:00
testing-tools test: add soak test with runtime instrumentation (Phase 2 Task 9d) 2025-10-20 15:13:38 +00:00
tests Keep self-hosted commercial copy opt-in 2026-04-25 15:26:11 +01:00
.air.toml chore: Add Air hot-reload configuration 2026-01-19 19:26:50 +00:00
.dockerignore Own Docker build context for shipped docs 2026-04-03 20:03:22 +01:00
.env.example docs: update API documentation and config file references 2026-02-01 23:26:42 +00:00
.gitattributes chore: optimize PNG images and add .gitattributes 2025-11-24 23:44:55 +00:00
.gitguardian.yaml Fix settings security tab navigation 2025-10-11 23:29:47 +00:00
.gitignore Harden dev agent deploy SSH host verification 2026-04-22 11:41:50 +01:00
.gitleaks.toml feat(security): add gitleaks secret scanning to pre-commit hook and CI 2026-02-04 09:52:54 +00:00
.golangci.yml feat: Pulse v6 release 2026-03-18 16:06:30 +00:00
.markdownlint-cli2.jsonc docs: standardize markdown syntax and remove deprecated sensor-proxy docs 2026-01-20 09:43:49 +00:00
.markdownlint.json docs: standardize markdown syntax and remove deprecated sensor-proxy docs 2026-01-20 09:43:49 +00:00
analyze_coverage.py docs: update AI evaluation matrix and approval workflow documentation 2026-01-30 19:00:40 +00:00
ARCHITECTURE.md Move operations tools into settings support 2026-04-17 20:03:54 +01:00
artifacthub-repo.yml Add Artifact Hub repository metadata for chart discoverability 2025-11-11 19:39:19 +00:00
audit_report.md Fix alert system reliability issues and update audit report 2026-02-04 12:50:36 +00:00
CONTRIBUTING.md Normalize hot-dev auth defaults 2026-04-22 16:28:52 +01:00
cr.yaml Add GitHub Pages Helm repository distribution (#686) 2025-11-11 19:26:18 +00:00
docker-compose.yml Pin deployment defaults and verify Helm docs downloads 2026-04-22 06:05:06 +01:00
docker-entrypoint.sh Avoid tenant runtime image copy-up 2026-04-24 09:21:42 +01:00
docker-healthcheck.sh feat: Pulse v6 release 2026-03-18 16:06:30 +00:00
Dockerfile Harden release Docker key embedding cache 2026-04-24 17:21:04 +01:00
go.mod Migrate Docker integrations to maintained Moby modules 2026-04-18 11:40:38 +01:00
go.sum Migrate Docker integrations to maintained Moby modules 2026-04-18 11:40:38 +01:00
install.sh Route operator updates through the local signed helper 2026-04-22 16:18:16 +01:00
LICENSE Fix settings security tab navigation 2025-10-11 23:29:47 +00:00
Makefile Route Makefile dev targets through npm wrappers 2026-03-24 21:37:28 +00:00
package-lock.json feat: Pulse v6 release 2026-03-18 16:06:30 +00:00
package.json Expose managed dev runtime entrypoint 2026-03-24 14:46:58 +00:00
playwright.config.ts fix(frontend): sync summary hover cursor and proof 2026-04-01 14:48:47 +01:00
README.md Align v6 Pro copy with operator value 2026-04-23 14:21:02 +01:00
SECURITY.md docs(security): localize shipped doc self-link 2026-03-28 19:48:32 +00:00
TERMS.md Align root TERMS.md with shipped docs copy 2026-04-17 15:47:15 +01:00
VERSION Prepare the v6 stable promotion candidate 2026-04-20 14:09:17 +01:00

Pulse

Pulse Logo

Real-time monitoring for Proxmox, Docker, Kubernetes, and TrueNAS infrastructure.

GitHub Stars GitHub release Docker Pulls License

Live DemoPulse ProDocumentationReport Bug


🚀 Overview

Pulse is a modern, unified dashboard for monitoring your infrastructure across Proxmox, Docker, Kubernetes, and TrueNAS. It consolidates metrics, alerts, and AI-powered insights from all your systems into a single, beautiful interface.

Designed for homelabs, sysadmins, and MSPs who need a "single pane of glass" without the complexity of enterprise monitoring stacks.

Pulse Dashboard

🧭 Unified Navigation

Pulse now groups everything by task instead of data source:

  • Infrastructure for hosts and nodes
  • Workloads for VMs, containers, and Kubernetes pods
  • Storage and Backups as top-level views
  • PMG now routes into Infrastructure (source filter), and Kubernetes routes into Workloads (K8s filter)
  • Legacy URLs are no longer routed as compatibility aliases; use canonical v6 routes.

Power-user shortcuts:

  • g i → Infrastructure, g w → Workloads, ? → shortcuts help
  • / or Cmd/Ctrl+K → global search

Features

Core Monitoring

  • Unified Monitoring: View health and metrics for PVE, PBS, PMG, Docker, Kubernetes, and TrueNAS in one place
  • Smart Alerts: Get notified via Discord, Slack, Telegram, Email, and more
  • Auto-Discovery: Automatically finds Proxmox nodes on your network
  • Metrics History: Persistent storage with configurable retention
  • Recovery Central: Unified backup/snapshot/replication timeline across PBS and TrueNAS

AI-Powered

  • Chat Assistant (BYOK): Ask questions about your infrastructure in natural language
  • Patrol: Background health checks that generate findings on a schedule. Activated or trial-backed installs can use 25 Patrol quickstart runs with no API key for initial Patrol setup; otherwise self-hosted use is BYOK.
  • Alert Analysis (Pro/Pro+/Cloud): Optional AI analysis when alerts fire
  • Cost Tracking: Track usage and costs per provider/model

Multi-Platform

  • Proxmox VE/PBS/PMG: Full monitoring and management
  • TrueNAS: Pools, datasets, disks, ZFS snapshots, replication tasks, and alerts
  • Kubernetes: Complete K8s cluster monitoring via agents
  • Docker/Podman: Container and Swarm service monitoring
  • OCI Containers: Proxmox 9.1+ native container support

Security & Operations

  • Secure by Design: Credentials encrypted at rest, strict API scoping, agent commands disabled by default
  • One-Click Updates: Easy upgrades for supported deployments
  • OIDC/SSO/SAML: Single sign-on with multi-provider support
  • Mobile Remote Access: Relay protocol with end-to-end encryption for supported Pulse Mobile clients (Relay and above)
  • Privacy Focused: Anonymous outbound telemetry is enabled by default and fully documented — no hostnames, credentials, or personal data is ever sent. Disable any time in Settings or via PULSE_TELEMETRY=false.

Quick Start

Replace vX.Y.Z with the exact release tag you want, verify the signed installer, then run it on your Proxmox host:

export PULSE_VERSION=vX.Y.Z
curl -fsSLO "https://github.com/rcourtman/Pulse/releases/download/${PULSE_VERSION}/install.sh"
curl -fsSLO "https://github.com/rcourtman/Pulse/releases/download/${PULSE_VERSION}/install.sh.sshsig"
ssh-keygen -Y verify \
  -f <(printf '%s\n' 'ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIDs21c5oPk2khrdHlsw1aZ9EJKoTsyalGzhb0hdwJrkV pulse-installer') \
  -I pulse-installer \
  -n pulse-install \
  -s install.sh.sshsig < install.sh
bash install.sh --version "${PULSE_VERSION}"
rm -f install.sh install.sh.sshsig

Note: this installs the Pulse server. Agent installs use the command generated in Settings → Unified Agents → Installation commands (served from /install.sh on your Pulse server).

Option 2: Docker

docker run -d \
  --name pulse \
  -p 7655:7655 \
  -v pulse_data:/data \
  --restart unless-stopped \
  rcourtman/pulse:vX.Y.Z

Access the dashboard at http://<your-ip>:7655.

Local Development

Use the managed dev runtime from the repo root:

npm run dev

Open http://127.0.0.1:5173 in the browser. 5173 is the frontend dev shell, and it proxies /api and /ws to the backend on 7655. 7655 is the backend dependency for API and websocket traffic, not the primary browser URL for local frontend development.

The managed dev runtime resets its local login to admin / adminadminadmin on startup unless you override it with HOT_DEV_AUTH_USER and HOT_DEV_AUTH_PASS.

Canonical local dev commands:

  • npm run dev — start the managed runtime and reclaim the canonical dev ports if an older unmanaged session is still using them
  • npm run dev:status — show frontend shell health, proxied API health, direct backend health, and listener ownership
  • npm run dev:verify — run the managed browser proof pack against the live dev runtime, including runtime recovery, the Patrol blocked-runtime page contract, and the desktop Recovery layout guard while the launcher suppresses unrelated backend rebuild churn for the duration of the proof pack
  • npm run dev:logs — tail the managed runtime log
  • npm run dev:backend-restart — bounce only the managed backend through the launcher contract
  • npm run dev:stop — stop the managed runtime
  • npm run dev:foreground — run the foreground hot-reload launcher intentionally if you need an attached shell

If npm run dev:verify passes, the managed dev shell, proxy path, backend health endpoint, browser recovery path, Patrol blocked-runtime page behavior, and Recovery desktop history-table layout are all aligned.

📚 Documentation

🌐 Community Integrations

Community-maintained integrations and addons:

💳 Plans (Community / Relay / Pro / Cloud)

Pulse is full-featured for core monitoring in every self-hosted tier. Self-hosted pricing no longer sells more room for monitoring volume; paid value comes from convenience, history, AI operations, and advanced administration. Cloud and MSP pricing are unchanged.

Self-hosted tiers:

Plan Price Core monitoring Metric history Key upgrade
Community Free Unlimited 7 days Full self-hosted monitoring
Relay $4.99/mo or $39/yr Unlimited 14 days Remote access, mobile, and push notifications
Pro $8.99/mo or $79/yr Unlimited 90 days Root-cause analysis, safe auto-fix, and operations tooling

Pulse still counts top-level monitored systems once no matter how they are collected. VMs, containers, pods, disks, backups, and other child resources under that system are included rather than counted separately, but that count is no longer the self-hosted paid gate.

Community keeps Patrol available with BYOK. Activated or trial-backed installs can also use Patrol quickstart for first-run activation: 25 Patrol runs with no API key on a server-verified install. Without activation, self-hosted Patrol continues with your configured provider. Relay remains the convenience tier, and Pro is the paid operations tier.

Runtime-aligned capability summary:

Capability Community Relay Pro Cloud
Pulse Patrol (Background Health Checks)
Remote Access / Mobile / Push
Alert-Triggered Root-Cause Analysis
Pulse Patrol Auto-Fix
Centralized Agent Profiles
Update Alerts (Container/Package Updates)
Basic SSO (OIDC)
Advanced SSO (SAML/Multi-Provider)
Role-Based Access Control (RBAC)
Enterprise Audit Logging
Advanced Infrastructure Reporting (PDF/CSV)
Extended Metric History 7 days 14 days 90 days 90 days

Pulse Patrol runs on your schedule (every 10 minutes to every 7 days, default 6 hours) and finds:

  • ZFS pools approaching capacity
  • Backup jobs that silently failed
  • VMs stuck in restart loops
  • Clock drift across cluster nodes
  • Container health check failures

On self-hosted installs, Pulse Patrol's steady-state path uses your configured provider (BYOK) from your Pulse server. The one hosted exception is Patrol quickstart: activated or trial-backed installs get 25 Patrol runs through the managed quickstart proxy so you can try Patrol before adding an API key. Unactivated Community installs should activate, start a trial, or use BYOK. Chat Assistant remains BYOK.

Technical highlights:

  • Cross-system context (nodes, VMs, backups, containers, and metrics history)
  • LLM analysis with your provider + alert-triggered root-cause investigations (Pro/Pro+/Cloud)
  • Optional auto-fix with command safety policies and audit trail
  • Centralized agent profiles for consistent fleet settings

Try the live demo → or learn more at pulserelay.pro

Pulse plan technical details: docs/PULSE_PRO.md

❤️ Support Pulse Development

Pulse is maintained by one person. Sponsorships help cover the costs of the demo server, development tools, and domains. If Pulse saves you time, please consider supporting the project!

GitHub Sponsors ko-fi

📄 License

MIT © Richard Courtman. Use of Pulse Pro is subject to the Terms of Service.