我在AWS上设置了Rancher k8s环境。
Rancher服务器位于具有ssl终止的经典ELB后面,可通过例如https://my.rancher.server
访问。
我已通过命令行运行
部署了一个简单的podkubectl create -f <podfilename.yml>
然后我可以get
和describe
播放。
但是,以下命令失败:
$ 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侦听器,并配置了代理协议。
答案 0 :(得分:0)
ELB的HTTP不支持websockets;你需要使用SSL监听器 - &gt; TCP后端并配置代理协议支持。 http://rancher.com/docs/rancher/v1.6/en/installing-rancher/installing-server/basic-ssl-config/#elb