CWL runner for Kubernetes
Project description
calrissian
CWL on Kubernetes
Overview
Calrissian is a CWL implementation designed to run individual steps as Pods in a kubernetes cluster
It is in development and includes a simple workflow (revsort single / array) to reverse and sort the contents of text files.
Preparing Openshift
The openshift/
directory contains YAML files that demonstrate the basic functionality. To configure Openshift, do the following:
-
Create a project in openshift (e.g.
calrissian
). Note that namespaces must be unique, so ifcalrissian
is already in use on the cluster, you will need to choose a different name here and other places where the namespace is referenced.oc new-project calrissian
-
Create a role in your project to allow managing
Pod
s:oc create role pod-manager-role --verb=create,delete,list,watch --resource=pods
-
Bind your project's default service account access to these roles. Calrissian running inside the cluster will use this service account to make Kubernetes API calls.
oc create rolebinding pod-manager-default-binding --role=pod-manager-role --serviceaccount=calrissian:default
-
Create the BuildConfig - this allows Openshift to build the source code into a Docker image and starts a build automatically. If you wish to build a different branch or repo, edit this file.
oc create -f openshift/BuildConfig.yaml
-
Create the VolumeClaims - these are the storage locations that will be shared between pods, and must support read-write many access.
oc create -f openshift/VolumeClaims.yaml
Running the example
With the VolumeClaims and Build processes in place, you can run the example with 2 jobs. These jobs use the docker image built by the BuildConfig, so they cannot be run until the build completes.
-
Stage the input data and workflow onto the
input-data
volume with the StageInputDataJob.oc create -f openshift/StageInputDataJob.yaml
-
Run the workflow engine with the CalrissianJob
oc create -f openshift/CalrissianJob-revsort.yaml
-
Job pods can be monitored from the openshift web interface or via command-line
oc logs -f job/calrissian-revsort-array
Notes
- Calrissian will delete completed jobs for individual steps, but you may want to delete the
calrissian-revsort-array
job manually after running it.
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 Distributions
Built Distributions
Hashes for calrissian-0.2.1-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | e5e168af1d90404506178d3e6dcf39607862362f41eaa031d62963f22911e2b6 |
|
MD5 | 6a09f6748a97ba37a2605f399a53a0ee |
|
BLAKE2b-256 | bff009c1a7affbcab4dd1c0647e68a15f23d2e1919e82aa97c7df8928be1d578 |