telnet连接端口转发的服务被远程主机关闭

89次阅读
没有评论

问题描述

在进行telnet连接时,针对一个经过端口转发的服务,发现在60秒后收到“连接被远程主机关闭”的提示。他怀疑是 Kubernetes 1.22 引起的问题。在最新的1.22版本中,如果他从IDE远程调试Kubernetes中的应用,也会出现“连接被对等方重置”的问题。他尝试过用telnet进行连接,但仍然遇到了类似的问题。用户正在使用Amazon的EKS服务,问题似乎是在最新的cni/proxy版本后出现的,可能与此有关。

解决方案

以下解决方案可能因版本差异而略有不同,请根据你的具体情况进行调整。

方案1:检查服务配置

  1. 首先,确保你的服务的端口转发配置正确。如果配置有误,可能会导致连接无法建立或在一定时间后被关闭。
  2. 检查 Kubernetes Service 和 Ingress 配置,确保端口转发规则正确设置。

方案2:调整连接超时时间

  1. 默认情况下,telnet 的连接超时时间是60秒。你可以尝试调整连接超时时间,以便更好地排除问题。
  2. 在进行 telnet 连接时,使用 -t 参数指定较长的连接超时时间,例如:
    shell
    telnet -t 120 <your_server> <port>

    这将把连接超时时间延长到120秒,以便更好地观察问题。

方案3:检查网络策略

  1. 在 Kubernetes 中,网络策略可能会影响到连接的建立和维持。确保你的网络策略不会阻止连接的建立。
  2. 检查 Pod、Service 或其他网络资源的网络策略,确保它们没有不必要的限制。

方案4:查看日志和事件

  1. 在 Kubernetes 集群中,查看相关服务和 Pod 的日志,以及事件记录,以便获取更多的问题信息。
  2. 使用以下命令查看 Pod 日志:
    shell
    kubectl logs <pod_name> -n <namespace>
  3. 使用以下命令查看事件记录:
    shell
    kubectl get events -n <namespace>

方案5:回滚版本或等待修复

  1. 如果问题确实是在最新的 cni/proxy 版本后出现的,考虑回滚到之前的版本,看看问题是否得以解决。
  2. 同时,你也可以等待 Kubernetes 社区发布针对该问题的修复版本,然后升级到修复版。

总结

在进行telnet连接时遇到“连接被远程主机关闭”的问题可能由多种因素引起,包括配置错误、连接超时、网络策略等。根据上述解决方案逐一排查,以找到并解决问题。如果问题仍然存在,考虑寻求社区的帮助,或等待相关修复版本的发布。

正文完