Skip to main content

Lightweight OS-agnostic observability UI for PyNinja

Project description

PyObservability

Python

Platform Supported

Platform

Deployments

pypi docker

Pypi Pypi-format Pypi-status

Kick off

Recommendations

Install PyObservability

python -m pip install pyobservability

Initiate - IDE

import pyobservability


if __name__ == '__main__':
    pyobservability.start()

Initiate - CLI

pyobservability start

Use pyobservability --help for usage instructions.

Containerized Deployment

docker pull thevickypedia/pyobservability:latest

docker run \
    --name observability \
    -p 8080:80 \
    -v /home/user/config:/config \
    --restart=no \
    thevickypedia/pyobservability

Environment Variables

Sourcing environment variables from an env file

By default, PyObservability will look for a .env file in the current working directory. Other file options (like JSON and YAML) are supported with a custom kwarg or env var env_file pointing to the filepath.

Mandatory

  • TARGETS - Target URLs running PyNinja in the following format.
    • TARGETS='[{"name":"node1","base_url":"http://192.168.1.10:8000","apikey":"token1"},{"name":"node2","base_url":"http://192.168.1.11:8000"}]'

Defaults

  • HOST - Host IP to run PyObservability. Defaults to 127.0.0.1 or 0.0.0.0
  • PORT - Port number to run PyObservability. Defaults to 8080
  • INTERVAL - Polling interval to retrieve server information.

Optional

  • USERNAME - Username to authenticate the monitoring page.
  • PASSWORD - Password to authenticate the monitoring page.
  • TIMEOUT - Timeout (in seconds) for UI authentication. Defaults to 5m.

Logging

PyObservability uses uvicorn logger by default. Following options can be used to override the default logger.

  • LOG - Lazy logger to use a custom log format. Can either be file or stdout.
  • DEBUG - Enables debug level logging. Defaults to False.
  • LOGS_PATH - Directory path to store log files if LOG is set to file.
  • LOG_CONFIG - Path to a custom logging configuration file.

License & copyright

© Vignesh Rao

Licensed under the MIT License

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

pyobservability-1.3.0-py3-none-any.whl (23.5 kB view details)

Uploaded Python 3

File details

Details for the file pyobservability-1.3.0-py3-none-any.whl.

File metadata

  • Download URL: pyobservability-1.3.0-py3-none-any.whl
  • Upload date:
  • Size: 23.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.0rc1

File hashes

Hashes for pyobservability-1.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 399e53e6d3032f44aab0e17c21b3aadaada33d706824cea18fd5448b2924c7d6
MD5 0a056d60ea3b9da0c8ecdad3a3dcf340
BLAKE2b-256 3050c07d0587822f399c9d61b12231721da993ebf11ba17812a7574cdd7633c5

See more details on using hashes here.

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