Hkube Python Wrapper
Project description
HKube Python Wrapper
Hkube python wrapper provides a simple interface for integrating algorithm in HKube
For general information on HKube see hkube.io
Installation
pip install hkube-python-wrapper
Download hkubectl latest version.
curl -Lo hkubectl https://github.com/kube-HPC/hkubectl/releases/download/$(curl -s https://api.github.com/repos/kube-HPC/hkubectl/releases/latest | grep -oP '"tag_name": "\K(.*)(?=")')/hkubectl-linux \
&& chmod +x hkubectl \
&& sudo mv hkubectl /usr/local/bin/
For mac replace with hkubectl-macos
For Windows download hkubectl-win.exe
Config hkubectl with your running Kubernetes.
hkubectl config # and follow the prompts
Basic Usage (using hkube build feature)
create a file for the algorithm entry-points (alg.py)
from typing import Dict
from hkube_python_wrapper import Algorunner, HKubeApi
def start(args: Dict, hkubeApi: HKubeApi):
return 1
build the algorithm with hkubectl
hkubectl algorithm apply algorithm-name --codePath ./folder_of_alg_py --codeEntryPoint alg.py --env python --setCurrent
Basic Usage (manual build)
from typing import Dict
from hkube_python_wrapper import Algorunner, HKubeApi
def start(args: Dict, hkubeApi: HKubeApi):
return 1
if __name__ == "__main__":
Algorunner.Run(start=start)
The start method accepts two arguments:
args: dict of invocation input
| key | type | description |
|---|---|---|
| input | Array | algorithm input as defined in the pipeline descriptor |
| jobId | string | The job ID of the pipeline run |
| taskId | string | The task ID of the algorithm invocation |
| nodeName | string | The name of the node in the pipeline descriptor |
| pipelineName | string | The name of the pipeline |
| batchIndex | int | For batch instance, the index in the batch array |
| parentNodeName | string | For child (code-api) algorithm. The name of the invoking node |
| info.rootJobId | string | for sub-pipeline, the jobId of the invoking pipeline |
hkubeApi: instance of HKubeApi for code-api operations
Class HKubeApi
Method start_algorithm
def start_algorithm( self, algorithmName, input=[], includeResult=True, blocking=False )
Starts an invocation of algorithm with input, and optionally waits for results
Args
algorithmName: string
: The name of the algorithm to start.
input :array
: Optional input for the algorithm.
includeResult :bool
: if True, returns the result of the algorithm execution.
default: True
blocking :bool
: if True, blocks until the algorithm finishes, and returns the results.
If False, returns an awaiter object, that can be awaited (blocking) at a later time
default: False
Returns
if blocking==False, returns an awaiter. If true, returns the result of the algorithm
Example:
hkubeApi.start_algorithm('some_algorithm',input=[3], blocking=True)
Method start_stored_subpipeline
def start_stored_subpipeline( self, name, flowInput={}, includeResult=True, blocking=False )
Starts an invocation of a sub-pipeline with input, and optionally waits for results
Args
name : string
: The name of the pipeline to start.
flowInput : dict
: Optional flowInput for the pipeline.
includeResult :bool
: if True, returns the result of the pipeline execution.
default: True
blocking : bool
: if True, blocks until the pipeline finishes, and returns the results.
If False, returns an awaiter object, that can be awaited (blocking) at a later time
default: False
Returns
if blocking==False, returns an awaiter. If true, returns the result of the pipeline
Example:
hkubeApi.start_stored_subpipeline('simple',flowInput={'foo':3},blocking=True)
Method start_raw_subpipeline
def start_raw_subpipeline( self, name, nodes, flowInput, options={}, webhooks={}, includeResult=True, blocking=False )
Starts an invocation of a sub-pipeline with input, nodes, options, and optionally waits for results
Args
name : string
: The name of the pipeline to start.
nodes : string
: Array of nodes. See example below.
flowInput : dict
: FlowInput for the pipeline.
options : dict
: pipeline options (like in the pipeline descriptor).
webhooks : dict
: webhook options (like in the pipeline descriptor).
includeResult :bool
: if True, returns the result of the pipeline execution.
default: True
blocking : bool
: if True, blocks until the pipeline finishes, and returns the results.
If False, returns an awaiter object, that can be awaited (blocking) at a later time
default: False
Returns
if blocking==False, returns an awaiter. If true, returns the result of the pipeline
Example:
nodes=[{'nodeName': 'd1', 'algorithmName': 'green-alg', 'input': ['@flowInput.foo']}]
flowInput={'foo':3}
hkubeApi.start_raw_subpipeline('ddd',nodes, flowInput,webhooks={}, options={}, blocking=True)
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
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 hkube_python_wrapper-2.5.0.dev10.tar.gz.
File metadata
- Download URL: hkube_python_wrapper-2.5.0.dev10.tar.gz
- Upload date:
- Size: 46.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
69784de2c8f1b23bdc460e0fa2231b237f73fb53e2c6e2140ec1acc84d5be0ed
|
|
| MD5 |
2e078e7131c11ad9e1f1f53110587c68
|
|
| BLAKE2b-256 |
143792cb4c3fd7e235f6b1904143c3066706b02a64cba4b1c45676d6b098a7a2
|
File details
Details for the file hkube_python_wrapper-2.5.0.dev10-py2.py3-none-any.whl.
File metadata
- Download URL: hkube_python_wrapper-2.5.0.dev10-py2.py3-none-any.whl
- Upload date:
- Size: 70.1 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b928f2059246b211609eb6ff3163332e3ba1575c7bd94c09fc18c96c098deabf
|
|
| MD5 |
14eb150a35b53debeb5182a65d6cddb5
|
|
| BLAKE2b-256 |
81dad8eb1b51e2cca9c47178f14f67f769b42f7c0cfbc05e611d97da4d48c92a
|