宿主机和虚拟机可以ping通telnet不通问题排查

本文探讨了Windows 10宿主机无法连接到Ubuntu 20虚拟机上运行的数据库,通过Wireshark分析发现是由于宿主机防火墙策略导致的Destination Unreachable(主机管理员禁止)。文章指导如何关闭宿主机iptables防火墙以解决问题,并解释了iptables命令的作用。

问题描述

宿主机win10,虚拟机ubuntu20,可以互相ping通,在虚拟机起了一个数据库进程,端口号26257,从宿主机无法访问,telnet不通
wireshark抓包分析后,发现错误提示信息:Destination unreachable (Host administratively prohibited)
推断是防火墙问题。宿主机防火墙已经关闭,虚拟机需要关闭防火墙。

解决办法

关闭防火墙。

sudo iptables -P INPUT ACCEPT
sudo iptables -P FORWARD ACCEPT
sudo iptables -P OUTPUT ACCEPT
sudo iptables -F

iptables 命令

-N, --new-chain chain:新建一个自定义的规则链;

-X, --delete-chain [chain]:删除用户自定义的引用计数为0的空链;

-F, --flush [chain]:清空指定的规则链上的规则;

-E, --rename-chain old-chain new-chain:重命名链;

-Z, --zero [chain [rulenum]]:置零计数器;

-P, --policy chain target, 设置链路的默认策略

### Telnet连接虚拟机失败的原因分析 对于Telnet连接Linux虚拟机失败的情况,常涉及多个方面的问题。当尝试Telnet访问虚拟机时遇到连接被拒的现象,这可能是由于目标机器上的服务未启动、防火墙阻止了请求或是网络配置正确等原因造成的。 #### 1. 检查Telnet服务状态 确保在虚拟机内部已经启用了Telnet服务并正在监听相应的端口(常是23)。可以过命令`systemctl status telnet.socket`来验证这一点[^2]。如果没有启用,则需执行如下操作: ```bash sudo apt-get update && sudo apt-get install inetutils-inetd -y echo "telnet stream tcp nowait root /usr/sbin/tcpd /usr/sbin/in.telnetd" | sudo tee -a /etc/inetd.conf sudo service inetd restart ``` 上述脚本适用于基于Debian/Ubuntu系统的环境;如果是RedHat/CentOS系列,请替换对应的包管理工具路径。 #### 2. 防火墙设置调整 即使开启了Telnet服务,也可能因为本地或远程主机之间的防火墙策略而遭到拦截。因此建议临时禁用防火墙来进行排查: ```bash sudo ufw disable # Ubuntu/Debian环境下 # 或者 sudo systemctl stop firewalld.service # CentOS/RHEL环境中 ``` 请注意,在生产环境中应完全关闭防火墙,而是应该针对性地开放所需端口。 #### 3. 网络适配器模式的选择 确认虚拟机使用的网络适配器模式是否适合当前场景。例如采用NAT方式时,需要保证宿主机能够正常解析到虚拟机的IP地址,并且两者处于同一网段内[^3]。可过以下方法检验连性: - 使用Windows下的CMD窗口运行 `ping <虚拟机IP>` 测试响应情况; - 登录至虚拟机后利用 `ifconfig` 查看实际获得的IPv4地址。 #### 4. SELinux政策的影响 某些情况下SELinux的安全机制也会阻碍外部连接的成功建立。虽然简单粗暴的方法是将其设为permissive模式甚至彻底关闭,但这并是推荐的做法。更优解是在影响整体安全性的情况下允许特定类型的流量行: ```bash setsebool -P allow_ssh_login on # 对于SSH来说 # 类似地针对其他应用设定相应布尔值... ``` 过需要注意的是,默认安装后的大多数发行版并会默认开启严格的SELinux控制,除非特别指定了此项功能。
评论 3
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值