Lightweight asynchronous SLURM REST requests with proxy support.
Project description
slurm-requests
Lightweight asynchronous SLURM REST requests with proxy support.
Installation
pip install slurm-requests
Usage
import asyncio
import slurm_requests as slurm
async def main():
# set defaults to avoid repetition
slurm.init_defaults(
url="https://example.com/sapi",
api_version="v0.0.40",
user_name="example_user",
user_token="example_token",
partition="example_partition",
# constraints="GPU",
environment=["EXAMPLE_VAR=example_value"],
# headers={"X-Example-Header": "example_value"},
# proxy_url="socks5://localhost:8080",
)
# check connection + credentials
await slurm.ping()
await slurm.diagnose()
# submit
job_id, _ = await slurm.job_submit(
name="example_job",
working_directory="/home/example_user/slurm",
script="#!/usr/bin/bash\necho Hello, SLURM!",
# time_limit=60,
# dependency="afterok:123456",
)
assert job_id is not None
# check state
response = await slurm.job_current_state_and_reason(job_id=job_id)
assert response is not None
state, reason = response
print(f"Job {job_id} is currently in state '{state}' due to reason '{reason}'.")
# cancel
await slurm.job_cancel(job_id=job_id)
# advanced: overwrite a default (works for all functions)
await slurm.ping(user_name="dummy", dry_run=True)
if __name__ == "__main__":
asyncio.run(main())
License
slurm-requests is distributed under the terms of the CC-BY-SA-4.0 license.
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
slurm_requests-2.0.0.tar.gz
(14.4 kB
view details)
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file slurm_requests-2.0.0.tar.gz.
File metadata
- Download URL: slurm_requests-2.0.0.tar.gz
- Upload date:
- Size: 14.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: python-httpx/0.27.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
092da21f18bd2f7ebd200335e3f2b4479422510b24589d7139eea4521c4b8903
|
|
| MD5 |
b56d517d795c4181ede2c5c0a62ee3fe
|
|
| BLAKE2b-256 |
55dfe1197e8207f911a0cb3bb2a50f272733abe736abf2d617c4cf240fdaba50
|
File details
Details for the file slurm_requests-2.0.0-py3-none-any.whl.
File metadata
- Download URL: slurm_requests-2.0.0-py3-none-any.whl
- Upload date:
- Size: 12.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: python-httpx/0.27.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9c77536410ee0ea7013b894ef890b2cb697483fe22cea936699bd6436348bf30
|
|
| MD5 |
bec7887b8becad883329df7f59b4ef30
|
|
| BLAKE2b-256 |
5b4666b206d9ee86d557a0e1b7206ffe4978e9903251a5c7c8ed3b1f2a1b487f
|