为什么Telnet依旧很流行!

译文 精选
服务器 服务器产品
客户端应用程序无法连接到服务器的原因有很多。确切的原因可能很难确定,尤其是当客户端是提供很少或不提供错误信息的GUI​时。使用telnet和观察输出将能够非常迅速地缩小问题所在范围并节省大量时间。


点击参加51CTO网站内容调查问卷

策划 | 言征

Telnet、协议和命令行工具是系统管理员用来登录远程服务器的方式。然而,由于没有加密,包括密码在内的所有通信都以明文形式发送,这意味着几乎在 SSH 创建后就放弃了 Telnet,转而使用 SSH。

出于登录远程服务器的目的,你永远不应该也可能从未考虑过它。这并不意味着该telnet命令在用于调试远程连接问题时不是一个非常有用的工具。

在本指南中,我们将探索如何使用telnet来回答这个太常见的问题——“为什么我不能 ###### 连接?”。

这个令人沮丧的问题通常在安装应用程序服务器(如 Web 服务器、电子邮件服务器、ssh 服务器、Samba 服务器等)后遇到,并且由于某种原因,客户端无法连接到服务器。

telnet不会解决问题,但它会很快缩小你需要开始寻找解决问题的范围。

telnet是用于调试网络相关问题的非常简单的命令,语法如下:

telnet <hostname or IP> <port>

因为telnet最初会简单地建立到端口的连接而不发送任何数据,所以它可以用于几乎任何协议,包括加密协议。

尝试连接到有问题的服务器时,会遇到四种主要错误。我们将研究这四个问题,探索它们的含义并了解你应该如何修复它们。

对于本指南,我们将假设我们刚刚在 上安装了一个Samba服务器samba.example.com,并且我们无法让本地客户端连接到该服务器。

1、错误 1 - 永远挂起的连接

首先,我们需要尝试连接到Samba服务器telnet。这是通过以下命令完成的(Samba 侦听端口 445):

telnet samba.example.com 445

有时,连接会到达这一点停止并无限期挂起:

telnet samba.example.com 445
Trying 172.31.25.31...

这意味着telnet尚未收到对其建立连接请求的任何响应。这可能有两个原因:

(1)你和服务器之间存在路由器故障;(2)有防火墙丢弃你的请求。

为了排除,快速运行mtr samba.example.com服务器。如果服务器是可访问的,那么它就是一个防火墙。

首先,使用以下命令检查服务器本身是否有任何防火墙规则iptables -L -v -n,如果没有,那么将获得以下输出:

iptables -L -v -n
Chain INPUT (policy ACCEPT 0 packets, 0 bytes)
pkts bytes target     prot opt in     out     source               destination
Chain FORWARD (policy ACCEPT 0 packets, 0 bytes)
pkts bytes target     prot opt in     out     source               destination
Chain OUTPUT (policy ACCEPT 0 packets, 0 bytes)
pkts bytes target     prot opt in     out     source               destination

如果你看到其他任何内容,则可能是问题所在。为了检查,先iptables一下,再跑telnet samba.example.com 445,看看能不能连上。如果仍然无法连接,请查看你的提供商和/或办公室是否设置了阻止防火墙。

2、错误 2 - DNS 问题

如果使用的主机名未解析为 IP 地址,则会出现 DNS 问题。你将看到的错误如下:

telnet samba.example.com 445
Server lookup failure:  samba.example.com:445, Name or service not known

这里的第一步是用服务器的 IP 地址代替主机名。如果你可以连接到 IP 但不能连接到主机名,则问题出在主机名上。

发生这种情况的原因有很多(我已经看到了以下所有原因):

(1)域名是否已注册?使用whois以查明是否。

(2)域名过期了吗?使用whois以查明是否。

(3)使用的主机名是否正确?使用digorhost确保使用的主机名解析为正确的 IP。

(4)你的A记录正确吗?检查是否不小心为诸如 Asmaba.example.com 之类的内容创建了A记录。

始终仔细检查拼写和正确的主机名(是 itsamba.example.com还是samba1.example.com),因为这通常会让你感到困惑,尤其是长的、复杂的或外国的主机名。

3、错误 3 - 服务器未在该端口上侦听

telnet当能够访问服务器但没有任何内容在你指定的端口上侦听时,会发生此错误。错误如下所示:

telnet samba.example.com 445
Trying 172.31.25.31...
telnet: Unable to connect to remote host: Connection refused

发生这种情况可能有以下几个原因:

(1)你确定要连接到正确的服务器吗?

(2)你的应用程序服务器没有在你认为是的端口上侦听。通过在服务器上运行来检查它到底在做什么netstat -plunt,看看它实际上在监听什么端口。

(3)应用程序服务器未运行。当应用程序服务器在你启动后立即安静地退出时,就会发生这种情况。启动服务器并运行ps auxf或systemctl status application.service检查它是否正在运行。

4、错误 4 - 连接被服务器关闭

当连接成功时会发生此错误,但应用程序服务器具有内置的安全措施,会在连接建立后立即终止连接。这个错误看起来像:

telnet samba.example.com 445
Trying 172.31.25.31...
Connected to samba.example.com.
Escape character is '^]'.
Connection closed by foreign host.

最后一行Connection closed by foreign host.表示:连接已被服务器主动终止。为了解决这个问题,需要查看应用服务器的安全配置,以确保 IP 或用户可以连接到它。

5、连接成功

这是成功的telnet连接尝试的样子:

telnet samba.example.com 445
Trying 172.31.25.31...
Connected to samba.example.com.
Escape character is '^]'.

连接将保持打开状态一段时间,具体取决于所连接的应用程序服务器的超时时间。

通过键入关闭telnet连接CTRL+],然后当看到telnet>提示时,键入“quit”并按ENTER 键,即:

telnet samba.example.com 445
Trying 172.31.25.31...
Connected to samba.example.com.
Escape character is '^]'.
^]
telnet> quit
Connection closed.

6、结论

客户端应用程序无法连接到服务器的原因有很多。确切的原因可能很难确定,尤其是当客户端是提供很少或不提供错误信息的GUI时。使用telnet和观察输出将能够非常迅速地缩小问题所在范围并节省大量时间。

原文链接:https://bash-prompt.net/guides/telnet/

责任编辑:武晓燕 来源: 51CTO技术栈
相关推荐

2021-07-28 09:29:01

C++编程语言TIOBE

2020-09-27 08:12:09

Nginx反向代理负载均衡

2012-04-09 13:35:10

Instagram

2013-03-18 09:30:18

Lisp

2021-01-04 10:21:27

Java开发编程语言

2019-10-28 15:10:31

懒人剪辑运动相机移动应用

2021-07-26 14:50:03

人工智能算法云计算

2015-11-23 13:07:14

资本寒冬创业投融资

2024-02-05 22:51:49

AGIRustPython

2014-12-23 09:34:47

动态语言

2020-05-21 09:56:54

语音技术新冠病毒人工智能

2022-04-06 07:51:21

数据库Web连接池

2009-11-06 10:48:14

函数式编程Scala

2023-08-28 09:05:46

LinuxJVM开源

2020-08-19 10:22:45

CIOIT试点项目技术

2019-04-03 15:46:55

中国编程语言

2022-04-01 15:23:06

人工智能AI换脸数据

2013-08-13 10:10:49

Chrome浏览器

2020-04-14 09:44:20

Python区块链开发

2013-12-24 09:30:44

点赞
收藏

51CTO技术栈公众号