sshpass传输文件提示Host key verification failed.

1. sshpass功能简述

sshpass指令可用于A服务器向B服务器传输文件或执行某些指令。

2. 传输文件指令

基本传输命令:sshpass -p 远程服务器登录密码 scp 本地路径文件 远程服务器登录用户名@远程服务器IP地址:远程服务器文件保存路径

示例:

bash 复制代码
sshpass -p '123' scp /mnt/files/1.tar.gz root@20.99.5.7:/mnt/upload/files

3. 补充描述

当A服务器首次连接B服务器时,会在本地服务器缓存服务器B返回的密钥,用于下次进行连接校验。

该密钥存储在 ~/.ssh/known_hosts 文件中。

4. 问题

连接传输文件时,首次连接或服务器重启,有可能导致原先的密钥失效,需要重新配置。

此时若发起连接,会报错:

Host key verification failed.

5. 解决方案

  1. 查看 ~/.ssh/known_hosts 文件中,是否存在远程服务器IP的密钥信息,若没有,则说明从未建立连接;若有,则手动编辑删除与当前远程服务器IP(20.99.5.7)相关的密钥信息。

  2. 执行操作指令重新建立连接

建立连接:ssh -p 22 -o StrictHostKeyChecking=no 远程服务器登录用户名@远程服务器IP地址

示例:

bash 复制代码
ssh -p 22 -o StrictHostKeyChecking=no root@20.99.5.7

会提示输入密码,输入密码之后即可完成建立连接,如下图:

然后可以输入 exit 完成退出连接远程服务器

bash 复制代码
exit

再次检查 当前服务器 的 ~/.ssh/known_hosts 文件,发现增加了 远程服务器的密钥信息。

  1. 执行传输文件操作
    至此再次执行向远程服务器传输文件的指令即可完成操作。
相关推荐
黑猫学长呀1 小时前
存储宝典第2篇:盲封TT wafer是什么意思?
linux·嵌入式硬件·项目·芯片·ufs·晶圆·产测
Strugglingler1 小时前
【Linux 用户态操作 UART】
linux·uart
代码熬夜敲Q1 小时前
ENSP 网络工程实验
linux·运维·服务器
csdn_life182 小时前
OpenClaw v2026.5.12+ 高级密钥管理:使用SecretRef实现真正的隐蔽存储
linux·openclaw
Terrence Shen2 小时前
Claude Code Harness 源码学习讲义
linux·学习·ubuntu
赵药师2 小时前
dpkg: warning: files list file for package ‘libselinux1:amd64‘ missing;
linux·运维·服务器
STDD2 小时前
Samba 文件共享:Linux 服务器与 Windows/Mac 共享文件夹
linux·服务器·windows
liudanzhengxi3 小时前
CRM系统技术文章
linux·服务器·网络·人工智能·新人首发
南境十里·墨染春水3 小时前
守护进程编程流程
linux·学习
eggrall4 小时前
Linux进程信号——像收快递一样理解 Linux 信号
linux·开发语言·c++