🐍 | Python library for RunPod API and serverless worker SDK.
Project description
Welcome to the official Python library for RunPod API & SDK.
Table of Contents
- Table of Contents
- 💻 | Installation
- ⚡ | Serverless Worker (SDK)
- 📚 | API Language Library (GraphQL Wrapper)
- 📁 | Directory
- 🤝 | Community and Contributing
💻 | Installation
# Install the latest release version
pip install runpod
# or
# Install the latest development version (main branch)
pip install git+https://github.com/runpod/runpod-python.git
Python 3.8 or higher is required to use the latest version of this package.
⚡ | Serverless Worker (SDK)
This python package can also be used to create a serverless worker that can be deployed to RunPod as a custom endpoint API.
Quick Start
Create a python script in your project that contains your model definition and the RunPod worker start code. Run this python code as your default container start command:
# my_worker.py
import runpod
def is_even(job):
job_input = job["input"]
the_number = job_input["number"]
if not isinstance(the_number, int):
return {"error": "Silly human, you need to pass an integer."}
if the_number % 2 == 0:
return True
return False
runpod.serverless.start({"handler": is_even})
Make sure that this file is ran when your container starts. This can be accomplished by calling it in the docker command when you set up a template at runpod.io/console/serverless/user/templates or by setting it as the default command in your Dockerfile.
See our blog post for creating a basic Serverless API, or view the details docs for more information.
Local Test Worker
You can also test your worker locally before deploying it to RunPod. This is useful for debugging and testing.
python my_worker.py --rp_serve_api
📚 | API Language Library (GraphQL Wrapper)
When interacting with the RunPod API you can use this library to make requests to the API.
import runpod
runpod.api_key = "your_runpod_api_key_found_under_settings"
Endpoints
You can interact with RunPod endpoints via a run
or run_sync
method.
endpoint = runpod.Endpoint("ENDPOINT_ID")
run_request = endpoint.run(
{"your_model_input_key": "your_model_input_value"}
)
# Check the status of the endpoint run request
print(run_request.status())
# Get the output of the endpoint run request, blocking until the endpoint run is complete.
print(run_request.output())
endpoint = runpod.Endpoint("ENDPOINT_ID")
run_request = endpoint.run_sync(
{"your_model_input_key": "your_model_input_value"}
)
# Returns the job results if completed within 90 seconds, otherwise, returns the job status.
print(run_request )
GPU Cloud (Pods)
import runpod
runpod.api_key = "your_runpod_api_key_found_under_settings"
# Get all my pods
pods = runpod.get_pods()
# Get a specific pod
pod = runpod.get_pod(pod.id)
# Create a pod
pod = runpod.create_pod("test", "runpod/stack", "NVIDIA GeForce RTX 3070")
# Stop the pod
runpod.stop_pod(pod.id)
# Resume the pod
runpod.resume_pod(pod.id)
# Terminate the pod
runpod.terminate_pod(pod.id)
📁 | Directory
.
├── docs # Documentation
├── examples # Examples
├── runpod # Package source code
│ ├── api_wrapper # Language library - API (GraphQL)
│ ├── cli # Command Line Interface Functions
│ ├── endpoint # Language library - Endpoints
│ └── serverless # SDK - Serverless Worker
└── tests # Package tests
🤝 | Community and Contributing
We welcome both pull requests and issues on GitHub. Bug fixes and new features are encouraged, but please read our contributing guide first.
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
Built Distribution
File details
Details for the file runpod-1.7.4.tar.gz
.
File metadata
- Download URL: runpod-1.7.4.tar.gz
- Upload date:
- Size: 4.1 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b76f94e4ef66ad8dc7ba8c0ae476133ff78efcbcc7dc54d535e190445d5ffb34 |
|
MD5 | 30d19c261a413838c03a6f6171a8ce8e |
|
BLAKE2b-256 | 49e8c8c18eecf66562cbc7b11edc5ae119b9e3bad30de058a271334bd13c08d8 |
File details
Details for the file runpod-1.7.4-py3-none-any.whl
.
File metadata
- Download URL: runpod-1.7.4-py3-none-any.whl
- Upload date:
- Size: 4.0 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9da2651e37dfccc3485b328de60a839f2b5fbd5003dd65e4fd49f552d8a6cee4 |
|
MD5 | ae98ad670d7cb6d3db2e6eada9cad285 |
|
BLAKE2b-256 | 4b6fd78f1611b94b9ab76cbe047d3987600ed651a6aa7f6a98bac5ca60ac8b0b |