Skip to main content

RCABench - A comprehensive root cause analysis benchmarking platform for microservices

Project description

RCABench SDK

A Python SDK for interacting with RCABench services.

Installation

From PyPI

pip install rcabench

From Source

# Clone the repository
git clone https://github.com/your-username/rcabench.git
cd rcabench/sdk/python

# Install the package
pip install -e .

Building the Package

To build the package for distribution:

# Install build dependencies
pip install build

# Build the package
python -m build

# This will create distribution files in the dist/ directory

Usage

from rcabench import RCABenchSDK

# Initialize the SDK
sdk = RCABenchSDK("http://localhost:8082")

# Get available algorithms
algorithms = sdk.algorithm.list()
print(algorithms)

# Submit an injection task
injection_payload = [{
    "duration": 1,
    "faultType": 5,
    "injectNamespace": "ts",
    "injectPod": "ts-preserve-service",
    "spec": {"CPULoad": 1, "CPUWorker": 3},
    "benchmark": "clickhouse",
}]
response = sdk.injection.execute(injection_payload)
print(response)

# Run an algorithm
algorithm_payload = [{
    "benchmark": "clickhouse",
    "algorithm": "e-diagnose", 
    "dataset": "dataset-name",
}]
response = sdk.algorithm.execute(algorithm_payload)
print(response)

API Reference

The SDK provides the following main components:

  • RCABenchSDK: The main entry point for the SDK
    • algorithm: For interacting with algorithm endpoints
    • evaluation: For interacting with evaluation endpoints
    • injection: For interacting with injection endpoints

For detailed API documentation, please refer to the code docstrings.

Requirements

  • Python 3.8 or higher
  • requests and aiohttp libraries

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

rcabench-1.1.55.tar.gz (69.3 kB view details)

Uploaded Source

Built Distribution

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

rcabench-1.1.55-py3-none-any.whl (298.1 kB view details)

Uploaded Python 3

File details

Details for the file rcabench-1.1.55.tar.gz.

File metadata

  • Download URL: rcabench-1.1.55.tar.gz
  • Upload date:
  • Size: 69.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.21 {"installer":{"name":"uv","version":"0.9.21","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for rcabench-1.1.55.tar.gz
Algorithm Hash digest
SHA256 18bc694c64cc636cf5bbe819bcd6ae1a92aae7f3b10ff8902651f6e18c49b44c
MD5 98c260b2b5d0d289c336dabbbfa2e470
BLAKE2b-256 f3a5d60260a5a2188cb5ea5645c79fd1111bf1f666bba3d0b53501c9c5ea3d3c

See more details on using hashes here.

File details

Details for the file rcabench-1.1.55-py3-none-any.whl.

File metadata

  • Download URL: rcabench-1.1.55-py3-none-any.whl
  • Upload date:
  • Size: 298.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.21 {"installer":{"name":"uv","version":"0.9.21","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for rcabench-1.1.55-py3-none-any.whl
Algorithm Hash digest
SHA256 f7f490a0c42ee1e460bcd37b694254f395fbe70352c00b4f5de2282429f76ca8
MD5 fadf8d302854a8a6d9cb4649a556e8ab
BLAKE2b-256 c26c0df61ef0f3e0205f53a4ee4780b61ec622ca4faa4e89507451b3b26cd7f3

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