如何从REST API创建Pod

时间:2018-07-04 14:46:09

标签: kubernetes kubernetes-pod kubernetes-apiserver

如何使用REST API创建Pod?

我检查了Kubernetes API文档:
https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.10/#-strong-write-operations-strong--54

他们正在撰写需要使用POST请求的内容:
POST /api/v1/namespaces/{namespace}/pods

我有这个简单的Nginx Pod的YAML:

cat > nginx-pod.yaml <<EOF
apiVersion: v1
kind: Pod
metadata:
  name: nginx1
spec:
  containers:
  - name: nginx
    image: nginx:1.7.9
    ports:
    - containerPort: 80
EOF

2 个答案:

答案 0 :(得分:2)

需要将YAML文件转换为JSON文件:

"hello"

像这样使用curl命令:

cat > nginx-pod.json <<EOF
{
    "apiVersion": "v1",
    "kind": "Pod",
    "metadata": {
        "name": "nginx1"
    },
    "spec": {
        "containers": [
            {
                "name": "nginx",
                "image": "nginx:1.7.9",
                "ports": [
                    {
                        "containerPort": 80
                    }
                ]
            }
        ]
    }
}
EOF

当然,您使用的令牌应该具有创建pod的权限。

如果有人可以做到而无需转换为JSON,请分享。

答案 1 :(得分:1)

根据作者的要求添加答案。

我们可以直接使用Yaml文件,如下所示。

curl -k -X POST -H 'Content-Type: application/yaml' \
-H "Authorization: Bearer <JWT_TOKEN>" --data '
apiVersion: v1
kind: Pod
metadata:
  name: nginx1
spec:
  containers:
  - name: nginx
    image: nginx:1.7.9
    ports:
    - containerPort: 80
' "https://127.0.0.1:6443/api/v1/namespaces/default/pods"

一件奇怪的事情是,如果我尝试在curl的数据中传递YAML文件(@ file.yaml),则会引发错误。似乎YAML内容类型不接受二进制文件,因此我使用cat传递内容。 因此,以下内容也将起作用。

curl -k -X POST -H 'Content-Type: application/yaml' -H "Authorization: Bearer <JWT_TOKEN>"\
 --data "$(cat nginx-pod.yaml)" "https://127.0.0.1:6443/api/v1/namespaces/default/pods"

参考:

  1. Kubernetes API reference
  2. Kubernetes Deployment curl example-基于此示例1。