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.35.tar.gz (260.8 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.35-py3-none-any.whl (706.4 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for rcabench-1.1.35.tar.gz
Algorithm Hash digest
SHA256 b77382e74d71fa429e51efe0a0b8615aea3edd4be4c94f8907a5d36d0053fc1c
MD5 0f14fb0e3cad83093a3ac6db6c238b0b
BLAKE2b-256 044da7115f0df9208b362b0643c8ed71e1e52b6d6cd6870e525c18f98158dba4

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for rcabench-1.1.35-py3-none-any.whl
Algorithm Hash digest
SHA256 8a8b4e234557deda50ddeffe4405de58b9bcf93159d0f569d2c6ef65f7e3bd3d
MD5 a6514dd23e14a51d5c861b00bae7fafa
BLAKE2b-256 d4a8cb30a134879289a7b1a5529bf9694d50fbf0f4a54b48968054af3bd37fb2

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