Skip to main content

A Python wrapper for Ansys platform instancemanagement

Project description

PyAnsys PyPI Code Coverage GitHub Workflow Status (branch) MIT License black

PyPIM exposes a Pythonic interface to communicate with the Product Instance Management (PIM) API.

What is the PIM API?

The PIM API is a gRPC API, enabling both library and app developers to start a product in a remote environment and communicate with its API.

The PIM API is intended to be as simple as possible to be adaptable in a variety of network and software infrastructures. Using this API does not require any knowledge of its infrastructure. You need only know which product to start and which API the product exposes. The PIM API itself exposes very few features and assumes that all the configuration is set on a server.

The PIM API is not intended to manage stateless services, to be a job management system, or a fully featured service orchestration API. Its purpose is to expose a minimum feature set for managing service-oriented apps.

Getting started

To use PyPIM, you must have access to the PIM API.

PyPIM itself is pure Python and relies on gRPC.

Installation

The ansys-platform-instancemanagement package is tested for Python 3.7 through Python 3.10 on Windows and Linux.

pip install ansys-platform-instancemanagement

Configuration

By default, PyPIM is configured externally instead of via code. Anywhere in the local storage, create a configuration file with this format:

{
    "version": 1,
    "pim": {
        "uri": "dns:pim.svc.com:80",
        "headers": {
            "metadata-info": "value"
        },
        "tls": false
    }
}

Then, define the environment variable ANSYS_PLATFORM_INSTANCEMANAGEMENT_CONFIG to point to this configuration file.

Usage

PyPIM is a single module called ansys.platform.instancemanagement, shortened to pypim.

To start MAPDL and communicate with PyPIM, use this code:

import ansys.platform.instancemanagement as pypim
from ansys.mapdl.core import Mapdl

if pypim.is_configured():
    with pypim.connect() as pim:
        with pim.create_instance(product_name="mapdl", product_version="221") as instance:
            instance.wait_for_ready()
            channel = instance.build_grpc_channel(options=[("grpc.max_receive_message_length", 8*1024**2)])
            mapdl = Mapdl(channel=channel)
            mapdl.prep7()
            ...

You can also use PyPIM without the with statement, as shown in this code:

import ansys.platform.instancemanagement as pypim
from ansys.mapdl.core import Mapdl

if pypim.is_configured():
    pim = pypim.connect()
    instance = pim.create_instance(product_name="mapdl", product_version="221")
    channel = instance.build_grpc_channel(options=[("grpc.max_receive_message_length", 8*1024**2)])
    mapdl = Mapdl(channel=channel)
    mapdl.prep7()
    ...
    instance.delete()
    pim.close()

Integration

PyPIM can be integrated in PyAnsys libraries to transparently switch to a remote instance in a suitable environment. This process is described in Integration in the PyPIM documentation.

For example, starting MAPDL with PyPIM is as simple as using this code:

from ansys.mapdl.core import launch_mapdl
mapdl = launch_mapdl()

Project details


Download files

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

Source Distribution

ansys-platform-instancemanagement-1.1.0.tar.gz (33.4 kB view details)

Uploaded Source

Built Distribution

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

File details

Details for the file ansys-platform-instancemanagement-1.1.0.tar.gz.

File metadata

File hashes

Hashes for ansys-platform-instancemanagement-1.1.0.tar.gz
Algorithm Hash digest
SHA256 a0fff1415c447025bf6182880b591013e4b51a14358fa4de040ad10e1f7213db
MD5 b3c21d9dfa5e39b4452fe082cab25d55
BLAKE2b-256 2c19d2b34401dfc3615372610f9385b44e78e8992334b24f44fbe4d2dcad5d39

See more details on using hashes here.

File details

Details for the file ansys_platform_instancemanagement-1.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for ansys_platform_instancemanagement-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6c1c7ff6e1c9d5c88138b3d18c82d2d121dd0460d39628e6c4ebe7c471f78379
MD5 d6f713209c2659361cf5b603c94ad55b
BLAKE2b-256 9abd0291da1ef78d9108c1384d1349f3905fa920b928264eabdf47a3483eede7

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