如何使用scp将文件夹从远程主机复制到本地主机?
我使用ssh登录到我的服务器。然后,我想将远程文件夹foo复制到local/home/user/Desktop。
我如何做到这一点?
如何使用scp将文件夹从远程主机复制到本地主机?
我使用ssh登录到我的服务器。然后,我想将远程文件夹foo复制到local/home/user/Desktop。
我如何做到这一点?
当前回答
如果您有一个地狱般的文件要从远程位置下载,如果您不太关心安全性,请尝试将scp默认加密(三重DES)更改为类似“blowfish”的格式。
这将大大减少文件复制时间。
scp -c blowfish -r user@your.server.example.com:/path/to/foo /home/user/Desktop/
其他回答
最好先压缩远程服务器上的目录:
tar czfP backup.tar.gz /path/to/catalog
其次,从远程下载:
scp user@your.server.example.com:/path/to/backup.tar.gz .
最后,提取文件:
tar -xzvf backup.tar.gz
将所有本地位置复制到远程位置(上载)
scp -r /path/from/local username@hostname:/path/to/remote
将所有远程位置复制到本地位置(下载)
scp -r username@hostname:/path/from/remote /path/to/local
自定义端口,其中xxxx是自定义端口号
scp -r -P xxxx username@hostname:/path/from/remote /path/to/local
在当前目录上从远程复制到本地
scp -r username@hostname:/path/from/remote .
帮助:
-r递归复制所有目录和文件始终使用/中的完整位置,通过pwd获取完整位置/路径scp将替换所有现有文件主机名将是主机名或IP地址如果需要自定义端口(除了端口22),请使用-P端口号.(dot)-表示当前工作目录,因此只能从服务器下载/复制并粘贴到此处。
注意:有时由于防火墙中不允许该端口,自定义端口无法工作,因此请确保防火墙中允许自定义端口用于传入和传出连接
要使用scp的全部功能,您需要执行以下步骤:
公钥授权创建SSH别名
然后,例如,如果您有这个~/.ssh/config:
Host test
User testuser
HostName test-site.example
Port 22022
Host prod
User produser
HostName production-site.example
Port 22022
您将省去密码输入,并简化scp语法,如下所示:
scp -r prod:/path/foo /home/user/Desktop # copy to local
scp -r prod:/path/foo test:/tmp # copy from remote prod to remote test
此外,您还可以使用远程路径完成:
scp test:/var/log/ # press tab twice
Display all 151 possibilities? (y or n)
为了实现远程bash完成,您需要在<source>和<target>主机上都有bash shell,并正确地运行bash完成。有关更多信息,请参阅相关问题:
使用scp时如何启用远程路径的自动完成?SCP文件名选项卡完成
典型场景,
scp -r -P port username@ip:/path-to-folder .
用样品解释,
scp-r-P 27000abc@10.70.12.12:/tmp/hotel_dump。
哪里
port = 27000
username = "abc" , remote server username
path-to-folder = tmp/hotel_dump
. = current local directory
如果您有一个地狱般的文件要从远程位置下载,如果您不太关心安全性,请尝试将scp默认加密(三重DES)更改为类似“blowfish”的格式。
这将大大减少文件复制时间。
scp -c blowfish -r user@your.server.example.com:/path/to/foo /home/user/Desktop/