一、端口
ping通了目标机器,不等于能够访问目标机器的某个端口。这好比你可以顺利进入某条街道,但不等于你能进入街道里的某间房子(port)。
二、端口连通性检查
timeout 3 bash -c ">/dev/tcp/1.1.1.1/80" && echo ok || echo not ok
以上指令:本体是>/dev/tcp/{{IP}}/{{PORT}},前半部分执行成功,exit code 0,则输出ok。其中-c作用是让 bash 将一个字符串作为完整的命令来执行。
Linux中的一个特殊文件: /dev/tcp 打开这个文件就类似于发出了一个socket调用,建立一个socket连接,读写这个文件就相当于在这个socket连接中传输数据。
通过重定向实现基于tcp/udp协议的软件通讯,/dev/tcp/host/port 只要读取或者写入这个文件,相当于系统会尝试连接:host 这台机器,对应port端口。
再提供一种shell的写法:
if timeout 5 bash -c '</dev/tcp/1.1.1.1/80 &>/dev/null'
then
echo "Port is open"
else
echo "Port is closed"
fi
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之家整理,本文链接:https://www.bmabk.com/index.php/post/146202.html