Skip to main content

A plugin for nodestream that manages k8s resources.

Project description

Nodestream Kubernetes Plugin

NOTE: This plugin is still in development and is not ready for production use.

Overview

This plugin allows you to deploy nodestream on a Kubernete cluster. As your project evolves by adding more data pipelines, nodstream-plugin-k8s will be able to manage your kubernetes resources for you.

Installation

pip install nodestream-plugin-k8s

Usage

1. Create a nodestream.yaml file and project.

# nodestream.yaml
scopes:
   crons: 
      pipelines:
        - path: pipelines/crons/my_scheduled_pipeline.yaml
  perpetual:
      pipelines:
        - path: pipelines/perpetual/my_kafka_pipeline.yaml

2. Annotate your pipeline with nodestream-plugin-k8s annotations.

# nodestream.yaml
scopes:
   crons:
      pipelines:
        - path: pipelines/crons/my_scheduled_pipeline.yaml
          annotations:
            nodestream_plugin_k8s_schedule: "0 0 * * *"
    perpetual:
       pipelines:
          - path: pipelines/perpetual/my_kafka_pipeline.yaml
            annotations:
              nodestream_plugin_k8s_conccurency: 1

3. Run nodestream-plugin-k8s to deploy your pipelines.

nodestream k8s sync --namespace my-nodestream-app-namespace 

4. Check your kubernetes cluster for your deployed pipelines.

kubectl get cronjobs -n my-nodestream-app-namespace
kubectl get deployments -n my-nodestream-app-namespace

5. Update your nodestream.yaml file and re-run nodestream-plugin-k8s to update your pipelines.

# nodestream.yaml
scopes:
   crons:
      pipelines:
        - path: pipelines/crons/my_scheduled_pipeline.yaml
          annotations:
            nodestream_plugin_k8s_schedule: "30 0 * * *"
    perpetual:
       pipelines:
          - path: pipelines/perpetual/my_kafka_pipeline.yaml
            annotations:
              nodestream_plugin_k8s_conccurency: 100
nodestream k8s sync --namespace my-nodestream-app-namespace 

6. Check your kubernetes cluster for your updated pipelines.

kubectl get cronjobs -n my-nodestream-app-namespace
kubectl get deployments -n my-nodestream-app-namespace

7. Delete your pipelines.

nodestream k8s destroy --namespace my-nodestream-app-namespace 

Annotations

nodestream_plugin_k8s_schedule

This annotation is used to schedule a cronjob. The value of this annotation should be a cron expression.

nodestream_plugin_k8s_concurrency

This annotation is used to set the concurrency of a deployment. The value of this annotation should be an integer.

nodestream_plugin_k8s_image

This annotation is used to set the image of a deployment or job. The value of this annotation should be a valid docker image.

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

nodestream_plugin_k8s-0.15.0a0.tar.gz (6.8 kB view details)

Uploaded Source

Built Distribution

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

nodestream_plugin_k8s-0.15.0a0-py3-none-any.whl (9.6 kB view details)

Uploaded Python 3

File details

Details for the file nodestream_plugin_k8s-0.15.0a0.tar.gz.

File metadata

  • Download URL: nodestream_plugin_k8s-0.15.0a0.tar.gz
  • Upload date:
  • Size: 6.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for nodestream_plugin_k8s-0.15.0a0.tar.gz
Algorithm Hash digest
SHA256 5377ac42c40b5b2445fe0e7701806db87def0cf69d3267e6db8688e541c7faf6
MD5 31de496d75fb51de4172fa4809e3133f
BLAKE2b-256 4fdddefb2d1ca8c8c431b3d8730e8fefbbd97ea112322ec66b76fc1ecf3b003d

See more details on using hashes here.

Provenance

The following attestation bundles were made for nodestream_plugin_k8s-0.15.0a0.tar.gz:

Publisher: release.yaml on nodestream-proj/nodestream-plugin-k8s

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

File details

Details for the file nodestream_plugin_k8s-0.15.0a0-py3-none-any.whl.

File metadata

File hashes

Hashes for nodestream_plugin_k8s-0.15.0a0-py3-none-any.whl
Algorithm Hash digest
SHA256 ad4ee26b46f1277b1daf173e04ab5882acde4f7f11985c639dd2184133b52da0
MD5 fd2d7579442735a7fa815009f7caaa12
BLAKE2b-256 8554ab698b3ee587b0444469f5caf675bdc73ef55232ba6e172dd771a4521fab

See more details on using hashes here.

Provenance

The following attestation bundles were made for nodestream_plugin_k8s-0.15.0a0-py3-none-any.whl:

Publisher: release.yaml on nodestream-proj/nodestream-plugin-k8s

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