通过sshpass命令执行从本地A服务器复制数据库文件到B服务器上。
# sshpass -p 'a@123456' scp -P 22 /home/data.sql.gz root@10.0.0.2:/home/data/db
注意事项:使用sshpass -p 'a@123456' 其中密码是B服务器上系统root用户的密码,密码中有特殊符号需要用单引号引起来。
使用sshpass进行scp跨机器拷贝文件时总是报错:
报错信息:
Host key verification failed.
解决方法:
由于该远程机器从未连接过,
检查known_hosts文件:vi ~/.ssh/known_hosts ,看有没有该IP(10.0.0.2)的信息,
如果有known_hosts文件您可以手动编辑该文本文件并删除旧密钥IP10.0.0.2相关的内容,没有known_hosts文件,则说明没有连接过该机器,这时需要用ssh命令建立一次连接,再使用sshpass命令。
需要先用ssh命令连接一下:
# ssh -p 22 -o StrictHostKeyChecking=no root@10.0.0.2
# password:输入密码确认
# exit
再次检查known_hosts文件:vi ~/.ssh/known_hosts ,发现有该机器的地址sha2记录了
10.0.0.2 ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBOGd5x+zjZurh1mtaRgv8RtGKUy9WloYpGSz55GHGHmLGfnYYVh0LKDwapUgfTRdAa5gXZNY0Uv2d+M7HR2xHrQ=
然后再用sshpass 即可
sshpass -p 'a@123456' scp -P 22 /home/data.sql.gz root@10.0.0.2:/home/data/db
~/.ssh/known_hosts 文件的作用?
ssh会把你所有访问过的电脑的公钥(public key)都记录在~/.ssh/known_hosts文件。
当下次访问相同计算机时,OpenSSH会核对公钥。由于某些原因导致公钥不同,OpenSSH会发出警告,避免你受到DNS Hijack之类的攻击。