-o StrictHostKeyChecking=no用法

文章讨论了使用bash脚本通过SSH执行远程机器操作时,由于未添加认证导致的看似成功但实际失败的问题。作者指出,虽然在交互式SSH中会显示认证警告,但在后台执行时这些警告被忽略。解决方法是在命令中加入oStrictHostKeyChecking=no以明确处理认证。

通过bash脚本后台执行对远程机器的操作时, 执行过程没有报错和其他提示信息, 执行之后却发现根本没有成功执行。其中一个原因就是没有加认证。 最简单的解决办法就是忽略认证, 做法是添加"-o StrictHostKeyChecking=no"
如以下命令:

  sshpass -p "$password"  scp  -o StrictHostKeyChecking=no  xxx    user_name@ip:xxx

其实进一步挖掘一下, 不用脚本执行, 在前台单独执行的时候是有一些提示信息的, 如下:

root@test-performancetest-world-apigw-1:~# ssh pi@10.9.15.69
The authenticity of host '10.9.15.69 (10.9.15.69)' can't be established.
ECDSA key fingerprint is SHA256:puFquOIiGlYWUsoPQZaY+Dn6PPq46YtqrgJLQwsvdBY.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '10.9.15.69' (ECDSA) to the list of known hosts.
pi@10.9.15.69's password:

提示需要认证。 只不是脚本在后台执行的时候没有这个提示信息, 误认为没有问题, 其实脚本是没有执行成功的。

添加"o StrictHostKeyChecking=no"后再执行脚本, 会有如下提示信息:

Warning: Permanently added '10.9.15.69' (ECDSA) to the list of known hosts.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值