linux – 如何检查sshd是否在远程机器上运行
发布时间:2020-05-25 05:27:00 所属栏目:Linux 来源:互联网
导读:ssh -q -o BatchMode=yes user@host echo 21 echo OK || echo NOK 这种方法是合适的,但是当pub.key被复制到主机时它返回true. 我需要看看一个ssh是否可连接两台设备之间没有键. 只需要检查sshd是否远程运行. 如果您只想检查是否可以通过ssh连接到主机,则可以
ssh -q -o "BatchMode=yes" user@host "echo 2>&1" && echo "OK" || echo "NOK" 这种方法是合适的,但是当pub.key被复制到主机时它返回true. 只需要检查sshd是否远程运行. 解决方法如果您只想检查是否可以通过ssh连接到主机,则可以简单地检查端口22是否打开.有各种各样的方式来做到这一点.使用nmap(将localhost替换为目标主机): $nmap -p22 localhost Starting Nmap 5.21 ( http://nmap.org ) at 2012-08-15 13:18 BST Nmap scan report for localhost (127.0.0.1) Host is up (0.000044s latency). PORT STATE SERVICE 22/tcp open ssh Nmap done: 1 IP address (1 host up) scanned in 0.04 seconds 要在脚本中使用它: if nmap -p22 localhost -oG - | grep -q 22/open; then
echo "OK"
else
echo "NOK"
fi
您也可以使用netcat: $nc -zv localhost 22 Connection to localhost 22 port [tcp/ssh] succeeded! 要在脚本中使用它: if nc -zv localhost 80 2>&1 | grep -q succeeded; then
echo "OK"
else
echo "NOK"
fi
这是一个快速检查,这在大多数情况下是足够的,但这不是愚蠢的.不保证远程端口上的服务侦听实际上是SSH服务器. 您可以尝试虚拟连接并检查返回的标题,例如: $echo "dummy" | nc localhost 22 SSH-2.0-OpenSSH_5.9p1 Debian-5ubuntu1 Protocol mismatch. 然而,由于各种原因,这种方法是不期望的.唯一有保证的方式是建立一个实际的连接,如您在问题中所显示的. (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- linux – GRUB的第1阶段引导加载程序如何加载第2阶段引导加
- debian 6 preseeding一直在问“将更改写入磁盘并配置LVM?”
- linux – CentOS 6.2安装openldap后没有slapd.conf
- 从自定义系统调用生成段错误
- linux – 如果补丁跳过补丁,如何不破坏makefile?
- linux-networking – 如何从自定义Linux网络命名空间切换回
- linux – Logrotate创建长名称,不删除日志
- linux – UDP Packet drop – INErrors Vs .RcvbufErrors
- windows – 将Winsock移植到Linux套接字
- c – 如何读取nm输出?
