有效地测试Linux上的端口是否打开?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了有效地测试Linux上的端口是否打开?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含901字,纯文字阅读大概需要2分钟。
内容图文
![有效地测试Linux上的端口是否打开?](/upload/InfoBanner/zyjiaocheng/952/392d7a581a3848548938a2c934808350.jpg)
从bash脚本中,如何快速查明端口445是否在服务器上打开/侦听.
我尝试了几种选择,但我想要一些快速的东西:
1. lsof -i:445(需要几秒钟)
2. netstat -an | grep 445 | grep LISTEN(需要几秒钟)
3. telnet(它不会返回)
4. nmap,netcat在服务器上不可用
知道一种不首先枚举的方法和之后的greps会很高兴.
解决方法:
我最近发现的一个惊喜是Bash本身支持tcp connections as file descriptors.使用:
exec 6<>/dev/tcp/ip.addr.of.server/445
echo -e "GET / HTTP/1.0\n" >&6
cat <&6
我使用6作为文件描述符,因为0,1,2是stdin,stdout和stderr.有时在Bash for child processes使用5,所以3,4,6,7,8和9应该是安全的.
根据下面的注释,测试在脚本中侦听本地服务器:
exec 6<>/dev/tcp/127.0.0.1/445 || echo "No one is listening!"
exec 6>&- # close output connection
exec 6<&- # close input connection
要确定某人是否正在侦听,请尝试通过环回进行连接.如果失败,则关闭端口或不允许访问.然后,关闭连接.
根据您的使用情况对此进行修改,例如发送电子邮件,在失败时退出脚本或启动所需服务.
内容总结
以上是互联网集市为您收集整理的有效地测试Linux上的端口是否打开?全部内容,希望文章能够帮你解决有效地测试Linux上的端口是否打开?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。