Skip to main content

Comprehensive health monitoring for Streamlit apps: system, dependencies, custom checks, and page errors.

Project description

Streamlit HealthCheck

Python | PyPI | codecov | On Pull Request

Monitor, visualize, and manage the health of your Streamlit multi-page applications with ease.


Overview

Streamlit HealthCheck is a comprehensive health monitoring solution for Streamlit apps. It tracks system resources, external dependencies, and custom application checks, providing a real-time dashboard for operational insights and troubleshooting.

  • System Resource Monitoring: CPU, memory, disk usage with configurable thresholds
  • Dependency Checks: API endpoints and database connectivity status
  • Custom Health Checks: Easily register and visualize custom checks for your app
  • Streamlit Page Error Tracking: Detects exceptions and st.error calls across pages
  • Live Dashboard: Interactive Streamlit UI with tabs for system, dependencies, custom checks, and page errors
  • Configurable: All checks and thresholds are managed via a simple JSON config file

How to Set Up & Run

Follow these steps to set up and launch the Streamlit HealthCheck dashboard using the status_page app:

1. Install Dependencies

Make sure you have Python 3.11+ and Streamlit installed. You can install all required packages using:

pip install -r requirements.txt

Or, to install just the healthcheck package:

pip install streamlit_healthcheck

2. Configure Health Checks

Edit config/health_check_config.json to customize system thresholds, endpoints, and custom checks. Example config:

{
  "system": { "cpu": 80, "memory": 75 },
  "dependencies": ["https://api.example.com", "postgresql://..."],
  "custom_checks": ["my_custom_check"]
}

3. Run the Streamlit Dashboard

Launch the main dashboard app:

streamlit run status_page/Home.py

This will open the healthcheck dashboard in your browser. Use the sidebar to navigate between system, dependency, and custom check tabs.

4. Add More Pages (Optional)

You can extend the dashboard by adding new pages to the status_page/pages/ directory. Each .py file will appear as a tab in the Streamlit app.

5. Troubleshooting

If you encounter issues:

  • Ensure your config file is valid JSON
  • Check that all dependencies are reachable
  • Review error messages in the dashboard tabs


Features

Feature Description
System Health Monitors CPU, memory, disk usage with warning/critical thresholds
Dependency Checks Verifies API endpoints and database connections
Custom Checks Register custom health checks for your app logic
Page Error Tracking Captures exceptions and Streamlit errors per page
Live Dashboard Interactive UI with tabs and status indicators
Configurable JSON-based config for checks and thresholds

Configuration

All health check settings are managed via config/health_check_config.json. You can customize:

  • Check intervals
  • System resource thresholds
  • API endpoints and database connections
  • Custom checks
  • Supports environment variables and optional YAML/JSON config for check registration.
  • Default timeouts and thresholds are overridable per-check.

[!TIP] Use the dashboard's configuration expander to adjust thresholds and save changes on the fly.


Project Structure

src/streamlit_healthcheck/      # Core healthcheck logic
status_page/                   # Streamlit UI pages
config/health_check_config.json # Health check configuration
requirements.txt               # Python dependencies
Makefile                       # Build and test commands
tests/                         # Unit tests

The project structure and control flow looks like below

Project Control Flow

  [System Metrics]    [Dependency Probes]    [Custom Checks]
         |                   |                      |
         +--------+----------+----------+-----------+
                  |                     |
               Collector (polls / hooks / events)
                          |
                      Checker Engine
                 (thresholds, retries, caching)
                          |
                      Aggregator
                (status rollup + history store)
                          |
                   Streamlit Dashboard
               (status panels, graphs, runbooks)
                          |
              Alerts / Notifications / Webhooks

HealthCheck Architecture

Figure: high-level architecture and control flow (image from assets/).


Key features

  • Run synchronous or async health checks with timeouts and recovery hints
  • Register custom checks (liveness, readiness, dependency checks)
  • Expose HTTP/Streamlit endpoints for machine-readable and human-readable status
  • Emit structured metrics/events suitable for scraping or CI validation
  • Simple integration helpers for common backends (Redis, Postgres, external APIs)

Quickstart


  1. Install:
pip install streamlit_healthcheck
  1. Basic usage:
from streamlit_healthcheck import healthcheck
report = healthcheck.run_all(timeout=5)
if not report:
   # handle degraded state (log, alert, fail pipeline)
   print(report.summary)

API (common surface)

  • healthcheck.run_all(timeout: float = 5) -> HealthReport Runs all registered checks and returns a HealthReport object with:

    • ok: bool
    • summary: str
    • details: dict
    • duration: float
  • healthcheck.register(name: str, fn: Callable, *, critical: bool = False) Register a custom check function. Critical checks mark the whole service unhealthy.

  • healthcheck.serve(endpoint: str = "/health", host: str = "0.0.0.0", port: int = 8000) Expose a simple HTTP endpoint (or embed in Streamlit) that returns JSON health status.

DevOps alignment

  • Reliable: Designed to reduce deployment failures and improve service uptime.
  • Automatable: Designed to be executed in CI/CD pipelines (pre-deploy checks, post-deploy smoke tests).
  • Observable: Emits structured outputs and metrics for dashboards and alerting.
  • Lean: Small, focused checks to enable frequent, low-risk deployments.
  • Measurable: Integrates with monitoring to improve MTTR and change failure rate.
  • Shareable: Clear APIs, runbooks examples, and integration docs for teams.

Integration tips

  • Use canary deployments or blue-green deployments to minimize impact during rollouts.
  • Use feature flags or conditional checks to avoid noisy alerts during rollouts.
  • Run healthcheck.run_all in CI as a gating step for deployments.
  • Expose metrics to Prometheus or your metrics backend for SLA tracking.

Contributing

  • Tests, type hints, and small, focused PRs welcome.
  • Follow the repository's CONTRIBUTING.md and code-of-conduct.
  • Add unit tests for new checks and integrations; CI runs linting and tests.
  • Use GitHub issues for bugs, feature requests, and discussions.

To publish to PyPI run the GitHub Action release.yml

License

GNU GENERAL PUBLIC LICENSE v3

Troubleshooting

[!WARNING] If the dashboard reports a "critical" status, check the error details in the relevant tab. For API/database issues, verify connectivity and credentials. For system resource alerts, consider scaling your infrastructure.


Getting Help


Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

streamlit_healthcheck-0.1.6.tar.gz (386.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

streamlit_healthcheck-0.1.6-py3-none-any.whl (44.1 kB view details)

Uploaded Python 3

File details

Details for the file streamlit_healthcheck-0.1.6.tar.gz.

File metadata

  • Download URL: streamlit_healthcheck-0.1.6.tar.gz
  • Upload date:
  • Size: 386.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for streamlit_healthcheck-0.1.6.tar.gz
Algorithm Hash digest
SHA256 1cf7697b4ad48e859dbc8d3fa3316679525d04c4e561468cb12cb912e30d179f
MD5 220405e9467271d3b6a01d1ce6658bea
BLAKE2b-256 479ea05fb3fc7313986ba6515ede8d42550b2d896ac75ab0717f8f34e0d03619

See more details on using hashes here.

Provenance

The following attestation bundles were made for streamlit_healthcheck-0.1.6.tar.gz:

Publisher: release.yml on saradindusengupta/streamlit-healthcheck

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file streamlit_healthcheck-0.1.6-py3-none-any.whl.

File metadata

File hashes

Hashes for streamlit_healthcheck-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 36c851c56595a3a68755ffa83583cdbf6ab195d95b8f3fbd158c5d90bf53ac49
MD5 829b2f433940ce739eb741a72e7ce8c5
BLAKE2b-256 1ef5c386df071850216fdb13254ad49754daaea95bf41542bf8df4ad99e876d0

See more details on using hashes here.

Provenance

The following attestation bundles were made for streamlit_healthcheck-0.1.6-py3-none-any.whl:

Publisher: release.yml on saradindusengupta/streamlit-healthcheck

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page