在 CentOS/RHEL/Scientific Linux 6 和 7 上安装 Telnet
声明
在安装和使用 Telnet 之前,需要记住以下几点。
- 在公网(WAN) 中使用 Telnet 是非常不好的想法。它会以明文的格式传输登入数据。每个人都可以看到明文。
- 如果你还是需要 Telnet,强烈建议你只在局域网内部使用。
- 你可以使用 SSH 作为替代方法。但是确保不要用 root 用户登录。
Telnet 是什么?
Telnet 是用于通过 TCP/IP 网络远程登录计算机的协议。一旦与远程计算机建立了连接,它就会成为一个虚拟终端且允许你与远程计算机通信。
在本篇教程中,我们会展示如何安装 Telnet 并且如何通过 Telnet 访问远程系统。
安装
打开终端并输入下面的命令来安装 telnet:
yum install telnet telnet-server -y
现在 telnet 已经安装在你的服务器上了。接下来编辑文件 /etc/xinetd.d/telnet :
vi /etc/xinetd.d/telnet
设置 disable = no :
# default: on # description: The telnet server serves telnet sessions; it uses \ # unencrypted username/password pairs for authentication. service telnet { flags = REUSE socket_type = stream wait = no user = root server = /usr/sbin/in.telnetd log_on_failure += USERID disable = no }
保存并退出文件。记住我们不必在 CentOS 7 做这步。
接下来使用下面的命令重启 telnet 服务:
在 CentOS 6.x 系统中:
service xinetd start
让这个服务在每次重启时都会启动:
在 CentOS 6 上:
chkconfig telnet on chkconfig xinetd on
在 CentOS 7 上:
systemctl start telnet.socket systemctl enable telnet.socket
让 telnet 的默认端口 23 可以通过防火墙和路由器。要让 telnet 端口可以通过防火墙,在 CentOS 6.x 系统中编辑下面的文件:
vi /etc/sysconfig/iptables
加入如下行“-A INPUT -p tcp -m state --state NEW --dport 23 -j ACCEPT”:
# Firewall configuration written by system-config-firewall # Manual customization of this file is not recommended. *filter :INPUT ACCEPT [0:0] :FORWARD ACCEPT [0:0] :OUTPUT ACCEPT [0:0] -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT -A INPUT -p icmp -j ACCEPT -A INPUT -i lo -j ACCEPT -A INPUT -p tcp -m state --state NEW --dport 23 -j ACCEPT -A INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT -A INPUT -j REJECT --reject-with icmp-host-prohibited -A FORWARD -j REJECT --reject-with icmp-host-prohibited COMMIT
保存并退出文件。重启 iptables 服务:
service iptables restart
在 CentOS 7 中,运行下面的命令让 telnet 服务可以通过防火墙。
firewall-cmd --permanent --add-port=23/tcp firewall-cmd --reload
就是这样。现在 telnet 服务就可以使用了。
创建用户
创建一个测试用户,比如用户名是“ sk ”,密码是“ centos “:
useradd sk passwd sk
客户端配置
安装 telnet 包:
yum install telnet
在基于 DEB 的系统中:
sudo apt-get install telnet
现在,打开终端,尝试访问你的服务器(远程主机)。
如果你的客户端是 Linux 系统,打开终端并输入下面的命令来连接到 telnet 服务器上。
telnet 192.168.1.150
输入服务器上已经创建的用户名和密码:
示例输出:
Trying 192.168.1.150... Connected to 192.168.1.150. Escape character is '^]'. Kernel 3.10.0-123.13.2.el7.x86_64 on an x86_64 server1 login: sk Password: [sk@server1 ~]$
如你所见,已经成功从本地访问远程主机了。
如果你的系统是 windows,进入 开始 -> 运行 -> 命令提示符 。
在命令提示符中,输入命令:
telnet 192.168.1.150
192.168.1.150 是远程主机 IP 地址。
现在你就可以连接到你的服务器上了。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论