本篇内容由Eagle整理,感谢他的辛勤付出
vi CreateServiceAccount.yaml
apiVersion: v1
kind: ServiceAccount
metadata:
name: admin-user
namespace: kube-system
kubectl create -f CreateServiceAccount.yaml
vi RoleBinding.yaml
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: ClusterRoleBinding
metadata:
name: admin-user
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: cluster-admin
subjects:
- kind: ServiceAccount
name: admin-user
namespace: kube-system
kubectl create -f RoleBinding.yaml
kubectl describe secret $(kubectl get secret -n kube-system | grep ^admin-user | awk '{print $1}') -n kube-system | grep -E '^token'| awk '{print $2}'
pip install kubernetes
from kubernetes import client, config
ApiToken = "xxxxx" #ApiToken
configuration = client.Configuration()
setattr(configuration, 'verify_ssl', False)
client.Configuration.set_default(configuration)
configuration.host = "https://xxxx:6443" #ApiHost
configuration.verify_ssl = False
configuration.debug = True
configuration.api_key = {"authorization": "Bearer " + ApiToken}
client.Configuration.set_default(configuration)
k8s_api_obj = client.CoreV1Api(client.ApiClient(configuration))
ret = k8s_api_obj.list_namespaced_pod("dev")
print(ret)
from kubernetes import client, config
ApiToken = "xxxxx" #ApiToken
configuration = client.Configuration()
setattr(configuration, 'verify_ssl', False)
client.Configuration.set_default(configuration)
configuration.host = "https://xxxx:6443" #ApiHost
configuration.verify_ssl = False
configuration.debug = True
configuration.api_key = {"authorization": "Bearer " + ApiToken}
client.Configuration.set_default(configuration)
k8s_api_obj = client.CoreV1Api(client.ApiClient(configuration))
body = {
"apiVersion": "v1",
"kind": "Namespace",
"metadata": {
"name": "test123",
}
}
ret = k8s_api_obj.create_namespace(body=body)
print (ret)
官方文档:https://github.com/kubernetes-client/python/blob/master/kubernetes/docs/CoreV1Api.md
from kubernetes import client, config
ApiToken = "xxxxx" #ApiToken
configuration = client.Configuration()
setattr(configuration, 'verify_ssl', False)
client.Configuration.set_default(configuration)
configuration.host = "https://xxxx:6443" #ApiHost
configuration.verify_ssl = False
configuration.debug = True
configuration.api_key = {"authorization": "Bearer " + ApiToken}
client.Configuration.set_default(configuration)
k8s_api_obj = client.CoreV1Api(client.ApiClient(configuration))
body = client.V1DeleteOptions()
body.api_version = "v1"
body.grace_period_seconds = 0
ret = k8s_api_obj.delete_namespace("test123", body=body)
print(ret)
官方文档:https://github.com/kubernetes-client/python/blob/master/kubernetes/docs/CoreV1Api.md#list_namespace
from kubernetes.client.rest import ApiException
ApiToken = "xxxxx" #ApiToken
configuration = client.Configuration()
setattr(configuration, 'verify_ssl', False)
client.Configuration.set_default(configuration)
configuration.host = "https://xxxx:6443" #ApiHost
configuration.verify_ssl = False
configuration.debug = True
configuration.api_key = {"authorization": "Bearer " + ApiToken}
client.Configuration.set_default(configuration)
k8s_api_obj = client.CoreV1Api()
limit = 56 #返回最大值,可选参数可以不写
timeout_seconds = 56 #超时时间可选参数
watch = False #监听资源,可选参数可以不填
try:
api_response = k8s_api_obj.list_namespace(limit=limit,timeout_seconds=timeout_seconds, watch=watch)
for namespace in api_response.items:
print(namespace.metadata.name)
except ApiException as e:
print("Exception when calling CoreV1Api->list_namespace: %s\n" % e)
官方文档:https://github.com/kubernetes-client/python/blob/master/kubernetes/docs/AppsV1beta2Api.md
from kubernetes import client, config
ApiToken = "xxxxx" #ApiToken
configuration = client.Configuration()
setattr(configuration, 'verify_ssl', False)
client.Configuration.set_default(configuration)
configuration.host = "https://xxxx:6443" #ApiHost
configuration.verify_ssl = False
configuration.debug = True
configuration.api_key = {"authorization": "Bearer " + ApiToken}
client.Configuration.set_default(configuration)
k8s_api_obj = client.AppsV1beta2Api(client.ApiClient(configuration))
body=eval("{'kind': 'Deployment', 'spec': {'replicas': 1, 'template': {'spec': {'containers': [{'image': 'nginx:1.7.9', 'name': 'nginx', 'ports': [{'contain
erPort': 80}]}]}, 'metadata': {'labels': {'app': 'nginx-deployment'}}}, 'selector': {'matchLabels': {'app': 'nginx-deployment'}}}, 'apiVersion': 'apps/v1beta2', 'metadata': {'labels': {'app': 'nginx-deployment'}, 'namespace': 'default', 'name': 'nginx-deployment'}}")
resp = k8s_api_obj.create_namespaced_deployment(body=body, namespace="default")
print(resp)
from kubernetes import client, config
ApiToken = "xxxxx" #ApiToken
configuration = client.Configuration()
setattr(configuration, 'verify_ssl', False)
client.Configuration.set_default(configuration)
configuration.host = "https://xxxx:6443" #ApiHost
configuration.verify_ssl = False
configuration.debug = True
configuration.api_key = {"authorization": "Bearer " + ApiToken}
client.Configuration.set_default(configuration)
k8s_api_obj = client.AppsV1beta2Api(client.ApiClient(configuration))
resp = k8s_api_obj.delete_namespaced_deployment(name="nginx-deployment",
namespace="default",
body=client.V1DeleteOptions(
propagation_policy='Foreground',
grace_period_seconds=0)
)
print(resp)
from kubernetes import client, config
ApiToken = "xxxxx" #ApiToken
configuration = client.Configuration()
setattr(configuration, 'verify_ssl', False)
client.Configuration.set_default(configuration)
configuration.host = "https://xxxx:6443" #ApiHost
configuration.verify_ssl = False
configuration.debug = True
configuration.api_key = {"authorization": "Bearer " + ApiToken}
client.Configuration.set_default(configuration)
k8s_api_obj = client.AppsV1beta2Api(client.ApiClient(configuration))
body=eval("{'kind': 'Deployment', 'spec': {'replicas': 1, 'template': {'spec': {'containers': [{'image': 'nginx', 'name': 'nginx', 'ports': [{'containerPort
': 80}]}]}, 'metadata': {'labels': {'app': 'nginx-deployment'}}}, 'selector': {'matchLabels': {'app': 'nginx-deployment'}}}, 'apiVersion': 'apps/v1beta2', 'metadata': {'labels': {'app': 'nginx-deployment'}, 'namespace': 'default', 'name': 'nginx-deployment'}}")
resp = k8s_api_obj.patch_namespaced_deployment(
name="nginx-deployment",
namespace="default",
body=body
)
print(resp)
from kubernetes import client, config
from kubernetes.client.rest import ApiException
ApiToken = "xxxxx" #ApiToken
configuration = client.Configuration()
setattr(configuration, 'verify_ssl', False)
client.Configuration.set_default(configuration)
configuration.host = "https://xxxx:6443" #ApiHost
configuration.verify_ssl = False
configuration.debug = True
configuration.api_key = {"authorization": "Bearer " + ApiToken}
client.Configuration.set_default(configuration)
k8s_api_obj = client.CoreV1Api()
resp = k8s_api_obj.list_namespaced_pod("default", label_selector="app=" + "nginx-deployment")
print(resp)
from kubernetes import client, config
from kubernetes.client.rest import ApiException
ApiToken = "xxxxx" #ApiToken
configuration = client.Configuration()
setattr(configuration, 'verify_ssl', False)
client.Configuration.set_default(configuration)
configuration.host = "https://xxxx:6443" #ApiHost
configuration.verify_ssl = False
configuration.debug = True
configuration.api_key = {"authorization": "Bearer " + ApiToken}
client.Configuration.set_default(configuration)
k8s_api_obj = client.CoreV1Api()
namespace = "default"
body = {'apiVersion': 'v1', 'kind': 'Service', 'metadata': {'name': 'nginx-service', 'labels': {'app': 'nginx'}}, 'spec': {'ports': [{'port': 80, 'targetPor
t': 80}], 'selector': {'app': 'nginx'}}}
try:
api_response = k8s_api_obj.create_namespaced_service(namespace , body)
print(api_response)
except ApiException as e:
print("Exception when calling CoreV1Api->create_namespaced_service: %s\n" % e)
from kubernetes import client, config
from kubernetes.client.rest import ApiException
ApiToken = "xxxxx" #ApiToken
configuration = client.Configuration()
setattr(configuration, 'verify_ssl', False)
client.Configuration.set_default(configuration)
configuration.host = "https://xxxx:6443" #ApiHost
configuration.verify_ssl = False
configuration.debug = True
configuration.api_key = {"authorization": "Bearer " + ApiToken}
client.Configuration.set_default(configuration)
k8s_api_obj = client.CoreV1Api()
name = 'nginx-service' #要删除svc名称
namespace = 'default' #命名空间
grace_period_seconds = 0 #延迟时间,0立即删除
body = client.V1DeleteOptions() #删除选项
try:
api_response = k8s_api_obj.delete_namespaced_service(name, namespace,body, grace_period_seconds=grace_period_seconds)
print(api_response)
except ApiException as e:
print("Exception when calling CoreV1Api->delete_namespaced_service: %s\n" % e)
from kubernetes import client, config
from kubernetes.client.rest import ApiException
ApiToken = "xxxxx" #ApiToken
configuration = client.Configuration()
setattr(configuration, 'verify_ssl', False)
client.Configuration.set_default(configuration)
configuration.host = "https://xxxx:6443" #ApiHost
configuration.verify_ssl = False
configuration.debug = True
configuration.api_key = {"authorization": "Bearer " + ApiToken}
client.Configuration.set_default(configuration)
k8s_api_obj = client.AppsV1beta2Api(client.ApiClient(configuration))
namespace = 'dev' #命名空间
try:
api_response = k8s_api_obj.list_namespaced_deployment(namespace)
for deployment in api_response.items:
print(deployment.metadata.name)
except ApiException as e:
print("Exception when calling AppsV1beta2Api->list_namespaced_deployment: %s\n" % e)
from kubernetes import client, config
ApiToken = "xxxxx" #ApiToken
configuration = client.Configuration()
setattr(configuration, 'verify_ssl', False)
client.Configuration.set_default(configuration)
configuration.host = "https://xxxx:6443" #ApiHost
configuration.verify_ssl = False
configuration.debug = True
configuration.api_key = {"authorization": "Bearer " + ApiToken}
client.Configuration.set_default(configuration)
k8s_api_obj = client.CoreV1Api()
body = {
'apiVersion': 'v1',
'kind': 'ConfigMap',
'metadata': {
'name': 'filebeat-configmap',
'namespace': 'default'
},
'data': {
'filebeat.yml': 'filebeat.prospectors: \n - input_type: log\ n paths: \n - "/mnt/*/logs/app/app.log"\n tags: ["json"]\ n json.keys_under_roo
t: true\ n json.overwrite_keys: true\ noutput.elasticsearch: \n hosts: ["xx.xx.xx.xx:9200"]\ n username: "elastic"\n password: "elastic"\n template.enabled: false\ n index: "dev_namespace_name_java_log-%{+yyyy.MM.dd}"\n '}
}
resp = k8s_api_obj.create_namespaced_config_map(
body=body, namespace="default")
print(resp)
from kubernetes import client, config
ApiToken = "xxxxx" #ApiToken
configuration = client.Configuration()
setattr(configuration, 'verify_ssl', False)
client.Configuration.set_default(configuration)
configuration.host = "https://xxxx:6443" #ApiHost
configuration.verify_ssl = False
configuration.debug = True
configuration.api_key = {"authorization": "Bearer " + ApiToken}
client.Configuration.set_default(configuration)
k8s_api_obj = client.CoreV1Api()
resp = k8s_api_obj.delete_namespaced_config_map(
name="filebeat-configmap",
namespace="default",
body=client.V1DeleteOptions()
)
print(resp)
from kubernetes import client, config
from kubernetes.client.rest import ApiException
ApiToken = "xxxxx" #ApiToken
configuration = client.Configuration()
setattr(configuration, 'verify_ssl', False)
client.Configuration.set_default(configuration)
configuration.host = "https://xxxx:6443" #ApiHost
configuration.verify_ssl = False
configuration.debug = True
configuration.api_key = {"authorization": "Bearer " + ApiToken}
client.Configuration.set_default(configuration)
k8s_api_obj = client.CoreV1Api()
namespace = 'default'
try:
api_response = k8s_api_obj.list_namespaced_config_map(namespace)
for config_map in api_response.items:
print(config_map.metadata.name)
except ApiException as e:
print("Exception when calling CoreV1Api->list_namespaced_config_map: %s\n" % e)
官方文档:https://github.com/kubernetes-client/python/blob/master/kubernetes/docs/CoreV1Api.md#read_node
from kubernetes import client, config
from kubernetes.client.rest import ApiException
ApiToken = "xxxxx" #ApiToken
configuration = client.Configuration()
setattr(configuration, 'verify_ssl', False)
client.Configuration.set_default(configuration)
configuration.host = "https://xxxx:6443" #ApiHost
configuration.verify_ssl = False
configuration.debug = True
configuration.api_key = {"authorization": "Bearer " + ApiToken}
client.Configuration.set_default(configuration)
k8s_api_obj = client.CoreV1Api()
exact = True
export = True
name = "192.168.1.50" #此处填写node名称
try:
api_response = k8s_api_obj.read_node(name, exact=exact, export=export)
print(api_response)
except ApiException as e:
print("Exception when calling CoreV1Api->read_node: %s\n" % e)
from kubernetes import client, config
from kubernetes.client.rest import ApiException
ApiToken = "xxxxx" #ApiToken
configuration = client.Configuration()
setattr(configuration, 'verify_ssl', False)
client.Configuration.set_default(configuration)
configuration.host = "https://xxxx:6443" #ApiHost
configuration.verify_ssl = False
configuration.debug = True
configuration.api_key = {"authorization": "Bearer " + ApiToken}
client.Configuration.set_default(configuration)
name = "192.168.1.50" #此处填写node名称
k8s_api_obj = client.CoreV1Api()
try:
api_response = k8s_api_obj.read_node_status(name, pretty=True)
print(api_response)
except ApiException as e:
print("Exception when calling CoreV1Api->read_node_status: %s\n" % e)
Kubernetes Python Api应用文章推荐阅读: