kubectl exec命令失败:需要升级请求

时间:2017-12-19 10:16:21

标签: amazon-web-services kubernetes kubectl rancher

我在AWS上设置了Rancher k8s环境。

Rancher服务器位于具有ssl终止的经典ELB后面,可通过例如https://my.rancher.server访问。

我已通过命令行运行

部署了一个简单的pod
kubectl create -f <podfilename.yml>

然后我可以getdescribe播放。

但是,以下命令失败:

$ kubectl exec my.pod.name -- ls /app
W1219 12:13:12.053543   16174 http.go:363] Error reading backend response: unexpected EOF
error: error sending request: Post https://my.rancher.server/r/projects/1a1043/kubernetes:6443/api/v1/namespaces/default/pods/my.pod.name/exec?command=ls&command=%2Fapp&container=k8s-demo&container=k8s-demo&stderr=true&stdout=true: unexpected EOF

编辑:这是json返回的:

{
  "kind": "Status",
  "apiVersion": "v1",
  "metadata": {

  },
  "status": "Failure",
  "message": "Upgrade request required",
  "reason": "BadRequest",
  "code": 400
}

我已将elb配置为使用ssl侦听器,并配置了代理协议。

enter image description here

1 个答案:

答案 0 :(得分:0)

ELB的HTTP不支持websockets;你需要使用SSL监听器 - &gt; TCP后端并配置代理协议支持。 http://rancher.com/docs/rancher/v1.6/en/installing-rancher/installing-server/basic-ssl-config/#elb