Skip to main content

Framework to create containers for DataCybernetic's PineXQ computing platform

Project description

PineXQ ProCon Framework

Computations in DC-Cloud are done by Workers running inside a ProcessingContainer, or short "ProCon", which is also the name of the framework. ProCon provides an unobtrusive wrapper around function definitions without introducing new semantics, allowing for a clean definition of the computational task, while handling all cloud-related communication and data-management transparently in the background. This removes the code and configuration required from the function implementation.

Installation

To install the package use the pip command, to either install from a package feed:

pip install pinexq-procon

Creating a container

To publish a function in a container it has to be a method of a class inheriting from the Step class.

from pinexq.procon.step import Step # import package

class MyStepCollection(Step):  # define the container class
    def calculate_square(self, x: float) -> float:  # define a step function
        """Calculate the square of x

        :param x: a float number
        :returns: the square of x
        """
        return x ** 2

    # More step functions can go in the same class    

if __name__ == '__main__':  # add script guard
    MyStepCollection()  # run the container - this will spawn the cli

It is mandatory to annotate the types of parameters and return value. Docstrings are optional, but highly recommended.

The documentation has a detailed section about implementing processing-steps.

Running a Step-function locally

The Python file with the container is itself a cli-tool. You get a list of all available commands with the --help parameter.

python ./my_step_file.py --help

With the run option you can call a function in the container directly and the result is written to the console.

python ./my_step_file.py run --function calculate_square --parameters "{'x': 5}"
25

You can find full list of available commands in the cli documentation. All possible parameters and environment variables are listed here.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pinexq_procon-2.1.0.dev3-py3-none-any.whl (56.3 kB view details)

Uploaded Python 3

File details

Details for the file pinexq_procon-2.1.0.dev3-py3-none-any.whl.

File metadata

File hashes

Hashes for pinexq_procon-2.1.0.dev3-py3-none-any.whl
Algorithm Hash digest
SHA256 799acb623723c52055109ff5fa4217f4de2af3d25c3be6ee37844f6a131be19c
MD5 d8afba00feef9a16c1440b275bea7ae3
BLAKE2b-256 4ffd64ea762908bc27c8cfa579b1467a2c9d873cb9d02729ff189a43f11b6b03

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