kubectl命令在几分钟的空闲时间后断开连接

时间:2018-06-05 02:18:26

标签: kubernetes kubectl

我们注意到当exec -it连接到一个pod时,在某个空闲时间之后连接被破坏了。有没有选择让连接打开更长时间?

我看到有一个开放的PR,但想知道这个问题是否有解决办法。

2 个答案:

答案 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.
............