首先,需要在K8s集群获取一串用于认证的token。这里省略这个步骤。 以下命令中的所有如下格式的命令,均替换为完整的token才能够执行。
-H "Authorization: Bearer ey...Xg"
通过使用k8s-api接口,查询Pods的基本信息。返回一个json格式的长文件。
curl -k -v -X GET -H "Authorization: Bearer ey...Xg" -H "Content-Type: application/json" https://59.110.220.63:6443/api/v1/namespaces/default/pods/
在上一条命令中的最后,加入指定的Pod名,即可获得指定Pod的信息。
curl -k -v -X GET -H "Authorization: Bearer ey..Xg" -H "Content-Type: application/json" https://59.110.220.63:6443/api/v1/namespaces/default/pods/pod-jupyter-233
Pod中的各种信息由命令中的json所决定
curl -k -v -X POST -H "Authorization: Bearer ey..Xg" -H 'Content-Type: application/json' --data '
{
"apiVersion": "v1",
"kind": "Pod",
"metadata": {
"name": "pod-jupyter-233",
"namespace": "default",
"labels": {
"name": "jupyter"
}
},
"spec": {
"restartPolicy": "Always",
"containers": [
{
"name": "pod-jupyter-233",
"image": "tensorflow/tensorflow:latest",
"imagePullPolicy": "Never",
"ports": [
{
"containerPort": 8888
}
],
"command": [
"/run_jupyter.sh"
],
"args": [
"--allow-root",
"--NotebookApp.token=abcdef"
],
"volumeMounts": [
{
"mountPath": "/notebooks",
"name": "test-volume"
}
]
}
],
"volumes": [
{
"name": "test-volume",
"hostPath": {
"path": "/mnt/userid",
"type": "Directory"
}
}
]
}
}
' https://59.110.220.63:6443/api/v1/namespaces/default/pods
Service是K8s中,用于自动分配范围从30000至32767的端口号的一个服务类型。每一个Pod如果想获取一个公网IP和相应的port,都必须创建一个相应的Service。
【!】注意! 在k8s中,外网访问Pod的IP地址可以为任意一台连入集群的主机IP地址。
curl -k -v -X POST -H "Authorization: Bearer ey..Xg" -H 'Content-Type: application/json' --data '
{
"kind": "Service",
"apiVersion": "v1",
"metadata": {
"name": "pod-jupyter-233",
"namespace": "default",
"labels": {
"name": "jupyter"
}
},
"spec": {
"type":"NodePort",
"ports": [{
"protocol":"TCP",
"port": 8888
}],
"selector": {"name": "jupyter"}
}
}
' https://59.110.220.63:6443/api/v1/namespaces/default/services
通过查询Services的信息,可以获取K8s分配给Pod的外网端口号等信息。
curl -k -v -X GET -H "Authorization: Bearer ey..Xg" -H "Content-Type: application/json" https://59.110.220.63:6443/api/v1/namespaces/default/services
用于获取端口号的常用操作
curl -k -v -X GET -H "Authorization: Bearer ey..Xg" -H "Content-Type: application/json" https://59.110.220.63:6443/api/v1/namespaces/default/services/pod-jupyter-233
用于删除已经存在的Pod。请注意,发起这个HTTP请求后,相应的Pod还需要经历一段时间的Terminating后,才会真正被删除。
curl -k -v -X DELETE -H "Authorization: Bearer ey..Xg" -H "Content-Type: application/json" https://59.110.220.63:6443/api/v1/namespaces/default/pods/pod-jupyter-233
删除service与删除pod的不同之处在于:service可以立刻被删除。因此,在结束学员实验时,请先删除service,再删除Pod。
curl -k -v -X DELETE -H "Authorization: Bearer ey..Xg" -H "Content-Type: application/json" https://59.110.220.63:6443/api/v1/namespaces/default/services/pod-jupyter-233
以上,即为K8s的常用API操作。感谢您的阅读。