如何使用scp命令在两个远程服务器之间从本地PC复制文件?
远程服务器1: IP=67.12.21.133和port=6774
远程服务器2: IP=67.129.242.40和port=6774
在输入密码67.12.21.133后出现错误,
发布于 2012-06-21 14:10:33
您可以使用~/.ssh/config来指定主机使用的端口(以及设置许多其他好东西;查看手册页man ssh_config):
# ~/.ssh/config
Host 67.12.21.133
Port 6774
Host 67.129.242.40
Port 6774在执行此操作时,您必须使用选项-3来scp,该选项通过本地计算机复制文件。否则,scp通过第一个主机上的ssh发出scp命令,因此它实际运行。
ssh -p 6774 denny@67.12.21.133 scp -rp /home/denny/testapp1.txt denny@67.129.242.40:然后使用第一个远程主机(67.12.21.133)的~/..ssh/config,而不是本地主机。
当您正确地设置了您的~/.ssh/config时,应该可以这样做:
scp -rp3 denny@67.12.21.133:/home/denny/testapp1.txt denny@67.129.242.40:当然,您也可以将~/..ssh/config文件的内容复制到第一个远程主机上,然后可以使用scp而不使用-3选项,这可能会加快传输速度。
或者您可以使用scp使用的技巧并使用这样的命令行:
ssh -p 6774 denny@67.12.21.133 scp -rp -P 6774 /home/denny/testapp1.txt denny@67.129.242.40:(请注意ssh和scp的端口参数的不同情况:ssh -p 6774和scp -P 6774)
PS:我从OpenSSH bugzilla获得了这个信息,在那里我输入了一个bug:https://bugzilla.mindrot.org/show_bug.cgi?id=2020
发布于 2012-06-21 07:07:11
我没有找到简单的解决方案,但您可以尝试以以下方式使用sshfs:
mkdir /tmp/h1
mkdir /tmp/h2
sshfs -p 6774 user1@host1:/public /tmp/h1
sshfs -p 2211 user2@host2:/data/src /tmp/h2
cp /tmp/h1/files.* /tmp/h2
fusermount -u /tmp/h1
fusermount -u /tmp/h2另一种方法可以是使用ssh (实际上没有经过成功测试):
ssh user1@host1 "cat /public/file.bin" | ssh user2@host2 "cat >/data/file.bin"目前我还没有找到正确的方法输入这两个密码。它要求几次这两个密码,但不接受任何人。也许,如果您在主机之间交换ssh密钥,它就能工作。因为你不需要密码。
我希望这能帮到你?托马斯
发布于 2013-06-12 01:08:17
根据Linux博客上的此页,您只需在第二个远程路径之前使用-P 6774选项:
scp -rp -P 6774 denny@67.12.21.133:/home/denny/testapp1.txt -P 6774 denny@67.129.242.40:每次使用-P标志都只适用于命令行的下一个位置,而不是整个命令。在它和前面的路径(或命令名scp)之间没有-P的任何位置都默认为标准端口(22)。
https://askubuntu.com/questions/153960
复制相似问题