Skip to main content

RCABench SDK

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.40.tar.gz (263.7 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.40-py3-none-any.whl (724.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: rcabench-1.1.40.tar.gz
  • Upload date:
  • Size: 263.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.8.22

File hashes

Hashes for rcabench-1.1.40.tar.gz
Algorithm Hash digest
SHA256 5e0f6961054d01e6f5ec88b7861f21ffca07b92ea4d57051daac8ceb30c67099
MD5 df6658d327345f8e1fa2e9981804e02e
BLAKE2b-256 c465618c292ef9b21d683f2b84a53d9d35f1e66b8ff05a4331a3d8460f6c4958

See more details on using hashes here.

File details

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

File metadata

  • Download URL: rcabench-1.1.40-py3-none-any.whl
  • Upload date:
  • Size: 724.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.8.22

File hashes

Hashes for rcabench-1.1.40-py3-none-any.whl
Algorithm Hash digest
SHA256 4af0f3a037a9acaadcb941e09d141ae40f2c457b6aee81067597e955df394d86
MD5 6066108747a332779c1ca5b32b9e62f0
BLAKE2b-256 8b48eee266a78f5be2a4c349c8a91435012c79db86b9ba46045b2cf40a3c85d3

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