Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kelproject/pykube
Python client library for Kubernetes
https://github.com/kelproject/pykube
Last synced: 6 days ago
JSON representation
Python client library for Kubernetes
- Host: GitHub
- URL: https://github.com/kelproject/pykube
- Owner: kelproject
- License: apache-2.0
- Archived: true
- Created: 2015-07-26T20:14:28.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2018-09-12T04:33:53.000Z (about 6 years ago)
- Last Synced: 2024-07-08T21:43:26.393Z (4 months ago)
- Language: Python
- Homepage:
- Size: 246 KB
- Stars: 349
- Watchers: 15
- Forks: 183
- Open Issues: 55
-
Metadata Files:
- Readme: README.rst
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
pykube
======.. image:: http://slack.kelproject.com/badge.svg
:target: http://slack.kelproject.com/.. image:: https://img.shields.io/travis/kelproject/pykube.svg
:target: https://travis-ci.org/kelproject/pykube.. image:: https://img.shields.io/pypi/dm/pykube.svg
:target: https://pypi.python.org/pypi/pykube/.. image:: https://img.shields.io/pypi/v/pykube.svg
:target: https://pypi.python.org/pypi/pykube/.. image:: https://img.shields.io/badge/license-apache-blue.svg
:target: https://pypi.python.org/pypi/pykube/Python client library for Kubernetes
.. image:: https://storage.googleapis.com/kel-assets/kel_full-02_200.jpg
:target: http://kelproject.com/Kel is an open source Platform as a Service (PaaS) from Eldarion, Inc. that
makes it easy to manage web application deployment and hosting through the
entire lifecycle from development through testing to production. It adds
components and tools on top of Kubernetes that help developers manage their
application infrastructure. Kel builds on Eldarion's 7+ years experience running
one of the leading Python and Django PaaSes.For more information about Kel, see `kelproject.com`_, follow us on Twitter
`@projectkel`_, and join our `Slack team`_... _kelproject.com: http://kelproject.com/
.. _@projectkel: https://twitter.com/projectkel
.. _Slack team: http://slack.kelproject.com/Features
--------* HTTP interface using requests using kubeconfig for authentication
* Python native querying of Kubernetes API objectsInstallation
------------To install pykube, use pip::
pip install pykube
Usage
-----Query for all ready pods in a custom namespace:
.. code:: python
import operator
import pykubeapi = pykube.HTTPClient(pykube.KubeConfig.from_file("/Users//.kube/config"))
pods = pykube.Pod.objects(api).filter(namespace="gondor-system")
ready_pods = filter(operator.attrgetter("ready"), pods)Access any attribute of the Kubernetes object:
.. code:: python
pod = pykube.Pod.objects(api).filter(namespace="gondor-system").get(name="my-pod")
pod.obj["spec"]["containers"][0]["image"]Selector query:
.. code:: python
pods = pykube.Pod.objects(api).filter(
namespace="gondor-system",
selector={"gondor.io/name__in": {"api-web", "api-worker"}},
)
pending_pods = pykube.objects.Pod.objects(api).filter(
field_selector={"status.phase": "Pending"}
)Watch query:
.. code:: python
watch = pykube.Job.objects(api, namespace="gondor-system")
watch = watch.filter(field_selector={"metadata.name": "my-job"}).watch()# watch is a generator:
for watch_event in watch:
print(watch_event.type) # 'ADDED', 'DELETED', 'MODIFIED'
print(watch_event.object) # pykube.Job objectCreate a ReplicationController:
.. code:: python
obj = {
"apiVersion": "v1",
"kind": "ReplicationController",
"metadata": {
"name": "my-rc",
"namespace": "gondor-system"
},
"spec": {
"replicas": 3,
"selector": {
"app": "nginx"
},
"template": {
"metadata": {
"labels": {
"app": "nginx"
}
},
"spec": {
"containers": [
{
"name": "nginx",
"image": "nginx",
"ports": [
{"containerPort": 80}
]
}
]
}
}
}
}
pykube.ReplicationController(api, obj).create()Delete a ReplicationController:
.. code:: python
obj = {
"apiVersion": "v1",
"kind": "ReplicationController",
"metadata": {
"name": "my-rc",
"namespace": "gondor-system"
}
}
pykube.ReplicationController(api, obj).delete()Check server version:
.. code:: python
api = pykube.HTTPClient(pykube.KubeConfig.from_file("/Users//.kube/config"))
api.versionHTTPie
------pykube can be used together with HTTPie for Kubernetes command line querying goodness. For example:
.. code:: shell
pip install httpie
http pykube://minikube/api/v1/servicesThe above example will construct an HTTP request to the cluster behind the ``minikube`` context and
show you the response containing all services.Requirements
------------* Python 2.7 or 3.3+
* requests (included in ``install_requires``)
* PyYAML (included in ``install_requires``)License
-------The code in this project is licensed under the Apache License, version 2.0
(included in this repository under LICENSE).Contributing
------------By making a contribution to this project, you are agreeing to the `Developer
Certificate of Origin v1.1`_ (also included in this repository under DCO.txt)... _Developer Certificate of Origin v1.1: http://developercertificate.org
Code of Conduct
----------------In order to foster a kind, inclusive, and harassment-free community, the Kel
Project follows the `Contributor Covenant Code of Conduct`_... _Contributor Covenant Code of Conduct: http://contributor-covenant.org/version/1/4/
Commercial Support
------------------Commercial support for Kel is available through Eldarion, please contact
[email protected].