Prefect integrations for interacting with Kubernetes.
Project description
prefect-kubernetes
Welcome!
Prefect integrations for interacting with Kubernetes resources.
Getting Started
Python setup
Requires an installation of Python 3.7+.
We recommend using a Python virtual environment manager such as pipenv, conda or virtualenv.
These tasks are designed to work with Prefect 2.0. For more information about how to use Prefect, please refer to the Prefect documentation.
Installation
Install prefect-kubernetes
with pip
:
pip install prefect-kubernetes
Then, register to view the block on Prefect Cloud:
prefect block register -m prefect_kubernetes.credentials
Note, to use the load
method on Blocks, you must already have a block document saved through code or saved through the UI.
Write and run a flow
Generate a resource-specific client from KubernetesClusterConfig
from prefect.blocks.kubernetes import KubernetesClusterConfig
from prefect_kubernetes.credentials import KubernetesCredentials
k8s_config = KubernetesClusterConfig.from_file('~/.kube/config')
k8s_credentials = KubernetesCredentials(cluster_config=k8s_config)
with k8s_credentials.get_client("core") as v1_core_client:
for pod in v1_core_client.list_namespaced_pod('default').items:
print(pod.metadata.name)
List jobs in a specific namespace
from prefect import flow
from prefect_kubernetes.credentials import KubernetesCredentials
from prefect_kubernetes.jobs import list_namespaced_job
@flow
def kubernetes_orchestrator():
v1_job_list = list_namespaced_job(
kubernetes_credentials=KubernetesCredentials.load("k8s-creds"),
namespace="my-namespace",
)
Delete a pod using V1DeleteOptions
from kubernetes.client.models import V1DeleteOptions
from prefect import flow
from prefect_kubernetes.credentials import KubernetesCredentials
from prefect_kubernetes.pods import delete_namespaced_pod
@flow
def kubernetes_orchestrator():
v1_pod = delete_namespaced_pod(
kubernetes_credentials=KubernetesCredentials.load("k8s-creds"),
pod_name="my-pod-to-delete",
delete_options=V1DeleteOptions(grace_period_seconds=42),
namespace="my-namespace"
)
Patch an existing deployment
from kubernetes.client.models import V1Deployment
from prefect import flow
from prefect_kubernetes.credentials import KubernetesCredentials
from prefect_kubernetes.deployments import patch_namespaced_deployment
@flow
def kubernetes_orchestrator():
v1_deployment = patch_namespaced_deployment(
kubernetes_credentials=KubernetesCredentials.load("k8s-creds"),
deployment_name="my-deployment",
deployment_updates=V1Deployment(spec={"replicas": 2}),
namespace="my-namespace"
)
List services in a namespace
from prefect import flow
from prefect_kubernetes.credentials import KubernetesCredentials
from prefect_kubernetes.services import list_namespaced_service
@flow
def kubernetes_orchestrator():
v1_service_list = list_namespaced_service(
kubernetes_credentials=KubernetesCredentials.load("k8s-creds"),
namespace="my-namespace",
)
Resources
If you encounter any bugs while using prefect-kubernetes
, feel free to open an issue in the prefect-kubernetes repository.
If you have any questions or issues while using prefect-kubernetes
, you can find help in either the Prefect Discourse forum or the Prefect Slack community.
Feel free to ⭐️ or watch prefect-kubernetes
for updates too!
Development
If you'd like to install a version of prefect-kubernetes
for development, clone the repository and perform an editable install with pip
:
git clone https://github.com/PrefectHQ/prefect-kubernetes.git
cd prefect-kubernetes/
pip install -e ".[dev]"
# Install linting pre-commit hooks
pre-commit install
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
Built Distribution
Hashes for prefect_kubernetes-0.1.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | ec7cb7bfd8f94326604c592165d0d526843f62dc61b334fd7656835ffdbe14ef |
|
MD5 | 446f3d3b860eb8f6652010493e82e1a3 |
|
BLAKE2b-256 | 940c0c830b6e1d407ff137ac80c2e9fcbc22fc633fcda51910f551a546353b12 |