我们注意到当exec -it
连接到一个pod时,在某个空闲时间之后连接被破坏了。有没有选择让连接打开更长时间?
我看到有一个开放的PR,但想知道这个问题是否有解决办法。
答案 0 :(得分:1)
简短的回答是否定的。这就是原因:
Enabling TCP keepalive for console connections
TCP keepalive是一个TCP选项,可以交换数据包 即使没有交通工具也可以连接。它应该是 在连接的两端启用。必须启用TCP keepalive 在应用程序/程序的操作系统级别和 打开TCP连接。
在Linux上,编辑“/etc/sysctl.conf”文件并添加以下行:
net.ipv4.tcp_keepalive_time = 200 net.ipv4.tcp_keepalive_probes = 9 net.ipv4.tcp_keepalive_intvl = 50
(随意根据您的需要调整值)。完成编辑后,你 必须使内核知道新值:
# sysctl --load=/etc/sysctl.conf
Custom Configuration of TCP Socket Keep-Alive Timeouts
这些属性的默认值为:
tcp_keepalive_time = 7200 seconds tcp_keepalive_probes = 9 tcp_keepalive_intvl = 75 seconds
另一种可能的方法是在客户端启动某种代理服务器并通过它连接到Kubernetes apiserver。 我自己没有测试它,它可能很棘手,但here是如何为Nginx启用Keepalive后端的示例。
答案 1 :(得分:0)
我还没有找到更改超时的方法,但是一种解决方法可能是重新附加:
$ kubectl run psql --image postgres \
--env PGHOST=<HOST> \
--env PGUSER=<USER>
--env PGPASSWORD=<PWD> \
--restart Never -- \
bash -c 'while true; do echo -n "."; sleep 1; done'
pod/psql created
$ kubectl attach psql
Defaulting container name to psql.
Use 'kubectl describe pod/psql -n default' to see all of the containers in this pod.
If you don't see a command prompt, try pressing enter.
............