Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Official Python client library for kubernetes

License

NotificationsYou must be signed in to change notification settings

kubernetes-client/python

 
 

Repository files navigation

Build StatusPyPI versioncodecovpypi supported versionsClient CapabilitiesClient Support Level

Python client for thekubernetes API.

Installation

From source:

git clone --recursive https://github.com/kubernetes-client/python.gitcd pythonpython setup.py install

FromPyPi directly:

pip install kubernetes

Example

list all pods:

fromkubernetesimportclient,config# Configs can be set in Configuration class directly or using helper utilityconfig.load_kube_config()v1=client.CoreV1Api()print("Listing pods with their IPs:")ret=v1.list_pod_for_all_namespaces(watch=False)foriinret.items:print("%s\t%s\t%s"% (i.status.pod_ip,i.metadata.namespace,i.metadata.name))

watch on namespace object:

fromkubernetesimportclient,config,watch# Configs can be set in Configuration class directly or using helper utilityconfig.load_kube_config()v1=client.CoreV1Api()count=10w=watch.Watch()foreventinw.stream(v1.list_namespace,_request_timeout=60):print("Event: %s %s"% (event['type'],event['object'].metadata.name))count-=1ifnotcount:w.stop()print("Ended.")

More examples can be found inexamples folder. To run examples, run this command:

python -m examples.example1

(replace example1 with the example base filename)

Documentation

All APIs and Models' documentation can be found at theGenerated client's README file

Compatibility

client-python followssemver, so until the major version ofclient-python gets increased, your code will continue to work with explicitlysupported versions of Kubernetes clusters.

Compatibility matrix

Kubernetes 1.5Kubernetes 1.6Kubernetes 1.7Kubernetes 1.8Kubernetes 1.9Kubernetes 1.10Kubernetes 1.11Kubernetes 1.12Kubernetes 1.13Kubernetes 1.14
client-python 1.0---------
client-python 2.0+--------
client-python 3.0++-------
client-python 4.0+++------
client-python 5.0++++-----
client-python 6.0+++++----
client-python 7.0++++++---
client-python 8.0+++++++--
client-python 9.0++++++++-
client-python 10.0+++++++++
client-python HEAD+++++++++

Key:

  • Exactly the same features / API objects in both client-python and the Kubernetesversion.
  • + client-python has features or api objects that may not be present in theKubernetes cluster, but everything they have in common will work.
  • - The Kubernetes cluster has features the client-python library can't use(additional API objects, etc).

See theCHANGELOG for a detailed description of changesbetween client-python versions.

Client versionCanonical source for OpenAPI specMaintenance status
1.0 Alpha/BetaKubernetes main repo, 1.5 branch
1.0.xKubernetes main repo, 1.5 branch
2.0 Alpha/BetaKubernetes main repo, 1.6 branch
2.0.xKubernetes main repo, 1.6 branch
3.0 Alpha/BetaKubernetes main repo, 1.7 branch
3.0Kubernetes main repo, 1.7 branch
4.0 Alpha/BetaKubernetes main repo, 1.8 branch
4.0Kubernetes main repo, 1.8 branch
5.0 Alpha/BetaKubernetes main repo, 1.9 branch
5.0Kubernetes main repo, 1.9 branch
6.0 Alpha/BetaKubernetes main repo, 1.10 branch
6.0Kubernetes main repo, 1.10 branch
7.0 Alpha/BetaKubernetes main repo, 1.11 branch
7.0Kubernetes main repo, 1.11 branch
8.0 Alpha/BetaKubernetes main repo, 1.12 branch
8.0Kubernetes main repo, 1.12 branch
9.0 Alpha/BetaKubernetes main repo, 1.13 branch
9.0Kubernetes main repo, 1.13 branch
10.0 Alpha/BetaKubernetes main repo, 1.14 branch
10.0Kubernetes main repo, 1.14 branch

Key:

  • Changes in main Kubernetes repo are manually (should be automated) published to client-python when they are available.
  • No longer maintained; please upgrade.

Kubernetes supportsthree minor releases at a time. "Support" means we expect users to be running that version in production, though we may not port fixes back before the latest minor version. For example, when v1.3 comes out, v1.0 will no longer be supported. In consistent with Kubernetes support policy, we expect to supportthree GA major releases (corresponding to three Kubernetes minor releases) at a time.

Note: There would be no maintenance for alpha/beta releases except the latest one.

Community, Support, Discussion

If you have any problem on using the package or any suggestions, please start with reaching theKubernetes clients slack channel, or filing anissue to let us know. You can also reach the maintainers of this project atSIG API Machinery.

Code of Conduct

Participation in the Kubernetes community is governed by theCNCF Code of Conduct.

Kubernetes Incubator

This is aKubernetes Incubator project.

Troubleshooting

SSLError on macOS

If you get an SSLError, you likely need to update your version of python. Theversion that ships with macOS may not be supported.

Install the latest version of python withbrew:

brew install python

Once installed, you can query the version of OpenSSL like so:

python -c "import ssl; print ssl.OPENSSL_VERSION"

You'll need a version with OpenSSL version 1.0.0 or later.

Hostname doesn't match

If you get anssl.CertificateError complaining about hostname match, your installed packages does not meet versionrequirements.Specifically checkipaddress andurllib3 package versions to make sure they met requirements inrequirements.txt file.

Why Exec/Attach calls doesn't work

Starting from 4.0 release, we do not support directly calling exec or attach calls. you should use stream module to call them. so insteadofresp = api.connect_get_namespaced_pod_exec(name, ... you should callresp = stream(api.connect_get_namespaced_pod_exec, name, ....See more atexec example.


[8]ページ先頭

©2009-2025 Movatter.jp