Skip to main content

Workflow orchestration and management.

Project description

PyPI

prefect-client

The prefect-client package is a minimal-installation of prefect which is designed for interacting with Prefect Cloud or remote any prefect server. It sheds some functionality and dependencies in exchange for a smaller installation size, making it ideal for use in lightweight or ephemeral environments. These characteristics make it ideal for use in lambdas or other resource-constrained environments.

Getting started

prefect-client shares the same installation requirements as prefect. To install, make sure you are on Python 3.10 or later and run the following command:

pip install prefect-client

Next, ensure that your prefect-client has access to a remote prefect server by exporting the PREFECT_API_KEY (if using Prefect Cloud) and PREFECT_API_URL environment variables. Once those are set, use the package in your code as you would normally use prefect!

For example, to remotely trigger a run a deployment:

from prefect.deployments import run_deployment


def my_lambda(event):
    ...
    run_deployment(
        name="my-flow/my-deployment",
        parameters={"foo": "bar"},
        timeout=0,
    )

my_lambda({})

To emit events in an event driven system:

from prefect.events import emit_event


def something_happened():
    emit_event("my-event", resource={"prefect.resource.id": "foo.bar"})

something_happened()

Or just interact with a prefect API:

from prefect.client.orchestration import get_client


async def query_api():
    async with get_client() as client:
        limits = await client.read_concurrency_limits(limit=10, offset=0)
        print(limits)


query_api()

Known limitations

By design, prefect-client omits all CLI and server components. This means that the CLI is not available for use and attempts to access server objects will fail. Furthermore, some classes, methods, and objects may be available for import in prefect-client but may not be "runnable" if they tap into server-oriented functionality. If you encounter such a limitation, feel free to open an issue describing the functionality you are interested in using and we will do our best to make it available.

Next steps

There's lots more you can do to orchestrate and observe your workflows with Prefect! Start with our friendly tutorial or explore the core concepts of Prefect workflows.

Join the community

Prefect is made possible by the fastest growing community of thousands of friendly data engineers. Join us in building a new kind of workflow system. The Prefect Slack community is a fantastic place to learn more about Prefect, ask questions, or get help with workflow design. All community forums, including code contributions, issue discussions, and Slack messages are subject to our Code of Conduct.

Contribute

See our documentation on contributing to Prefect.

Thanks for being part of the mission to build a new kind of workflow system and, of course, happy engineering!

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

prefect_client-3.7.6.dev4.tar.gz (913.0 kB view details)

Uploaded Source

Built Distribution

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

prefect_client-3.7.6.dev4-py3-none-any.whl (1.1 MB view details)

Uploaded Python 3

File details

Details for the file prefect_client-3.7.6.dev4.tar.gz.

File metadata

  • Download URL: prefect_client-3.7.6.dev4.tar.gz
  • Upload date:
  • Size: 913.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for prefect_client-3.7.6.dev4.tar.gz
Algorithm Hash digest
SHA256 0f8ae98c92ebc2ae84df3b27d62852cab62f00de44febb2aef721380d004f2ad
MD5 537c00e49ab5355ee593fdfed20b436b
BLAKE2b-256 db99d2a1c343ae5de554004d94a5d6619a5c45c687cf0aac6fb65cf061197a3e

See more details on using hashes here.

Provenance

The following attestation bundles were made for prefect_client-3.7.6.dev4.tar.gz:

Publisher: prefect-client-publish.yaml on PrefectHQ/prefect

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file prefect_client-3.7.6.dev4-py3-none-any.whl.

File metadata

File hashes

Hashes for prefect_client-3.7.6.dev4-py3-none-any.whl
Algorithm Hash digest
SHA256 9b75e771f4f8eb1ea65d2b3e5ca58972e6cc088b6bf8b341180b5e4b7bcd4e6a
MD5 fc5d4d10ff65fdc8a2b2902ddd36b0cf
BLAKE2b-256 032a4a6adca35ae87b088907272cb0d25a41f757ac499204b4ba1b8354c11721

See more details on using hashes here.

Provenance

The following attestation bundles were made for prefect_client-3.7.6.dev4-py3-none-any.whl:

Publisher: prefect-client-publish.yaml on PrefectHQ/prefect

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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