15%

Alexhost 满足您的愿望

参与调查 并赢得奖品

28.10.2024
No categories

通过SSH复制文件

“`html
SSH (安全外壳) 是一种广泛使用的协议,用于通过加密连接安全地访问和管理 远程服务器。在使用 SSH 时,最常见的任务之一是复制本地计算机与远程服务器之间或两个远程服务器之间的文件。

在本文中,我们将探讨通过 SSH 复制文件的不同方法,包括使用 SCP(安全复制协议)、rsync 和其他方法。


为什么使用 SSH 进行文件传输?

使用 SSH 传输文件有几个优点:

  • 安全性:SSH 在传输过程中对命令和数据进行加密,确保敏感信息得到保护。
  • 效率:SSH 快速且可靠,允许您在系统之间直接传输文件,而无需单独登录。
  • 自动化:SSH 可以集成到脚本中,实现服务器或本地计算机之间的自动文件传输。

1. 使用 SCP(安全复制协议)复制文件

SCP 是通过 SSH 安全复制文件的最流行工具之一。它允许您将文件从本地计算机传输到远程服务器,从远程服务器传输到本地计算机,或在两个远程服务器之间传输文件。

基本 SCP 语法:

scp [选项] [源] [目标]

示例 1:从本地计算机复制文件到远程服务器

scp /path/to/local/file username@remote_host:/path/to/remote/destination

在此示例中:

  • /path/to/local/file 是您本地计算机上文件的路径。
  • username@remote_host 是远程服务器的 SSH 用户名和主机名或 IP 地址。
  • /path/to/remote/destination 是文件将在远程服务器上存储的路径。

示例 2:从远程服务器复制文件到本地计算机

scp username@remote_host:/path/to/remote/file /path/to/local/destination

在这种情况下,文件从远程服务器传输到本地计算机。

示例 3:递归复制目录

要复制整个目录,请使用 -r(递归)选项:

scp -r /path/to/local/directory username@remote_host:/path/to/remote/destination

这将把目录及其所有内容传输到远程服务器。

有用的 SCP 选项:

  • -P [端口]:如果 SSH 端口不同于默认端口(22),请指定 SSH 端口。
  • -C:在传输过程中启用压缩,以加快文件复制速度。
  • -i [身份文件]:使用特定的 SSH 私钥进行身份验证。

2. 使用 rsync 复制文件

rsync 是另一种强大的通过 SSH 进行文件传输的工具。由于它只复制源和目标之间的更改,因此通常更适合于大型或重复的文件传输,从而节省时间和带宽。

基本 rsync 语法:

rsync [选项] [源] [目标]

示例 1:从本地计算机复制文件到远程服务器

rsync -avz /path/to/local/file username@remote_host:/path/to/remote/destination

示例 2:使用 rsync 复制目录

rsync -avz /path/to/local/directory/ username@remote_host:/path/to/remote/destination/

有用的 rsync 选项:

  • -a:归档模式,保留符号链接、权限、时间戳和文件所有权。
  • -v:详细模式,在传输过程中显示进度。
  • -z:启用压缩以加快传输速度。
  • –delete:删除目标中不再存在于源中的文件。
  • -e “ssh -p [端口]”:指定自定义 SSH 端口。

3. 在两个远程服务器之间复制文件

使用 SSH,您还可以直接在两个远程服务器之间复制文件。SCP 和 rsync 都支持这一点。

示例 1:使用 SCP 在两个远程服务器之间复制文件

scp username1@remote_host1:/path/to/file username2@remote_host2:/path/to/destination

示例 2:使用 rsync 在两个远程服务器之间复制文件

rsync -avz username1@remote_host1:/path/to/file username2@remote_host2:/path/to/destination

这对于在服务器之间传输文件而不必先将其下载到本地计算机特别有用。


4. 使用 SFTP(SSH 文件传输协议)复制文件

SFTP 是另一种通过 SSH 安全传输文件的方法。它类似于 FTP,但使用 SSH 提供加密。SFTP 通常用于交互式会话,但也可以自动化。

使用 SFTP:

要开始 SFTP 会话,请运行以下命令:

sftp username@remote_host

进入 SFTP 提示符后,您可以使用以下命令:

  • put /path/to/local/file /path/to/remote/destination:将文件从本地计算机上传到远程服务器。
  • get /path/to/remote/file /path/to/local/destination:将文件从远程服务器下载到本地计算机。
  • mput 和 mget:一次上传或下载多个文件。

要退出 SFTP 会话,请输入 exit 或 quit。


5. 使用 SSH 密钥自动化文件传输

对于重复的文件传输,设置基于 SSH 密钥的身份验证是个好主意,这样您就不需要每次都输入密码。

步骤 1:生成 SSH 密钥对(如果您还没有)

在您的本地计算机上运行:

ssh-keygen -t rsa

这将生成一个公钥和私钥对。

步骤 2:将公钥复制到远程服务器

使用以下命令将公钥复制到远程服务器:

ssh-copy-id username@remote_host

现在,您可以登录并传输文件,而无需输入密码,从而更容易实现自动化。


结论

通过 SSH 复制文件是一种安全高效的方式,可以在您的本地计算机与远程服务器之间或在两个远程服务器之间传输数据。无论您使用 SCP、rsync 还是 SFTP,SSH 都提供加密的文件传输,保护您的数据不被拦截。像 SCP 这样的工具适合一次性传输,而 rsync 则非常适合持续同步任务,尤其是对于大型文件或目录。了解这些工具将帮助您更有效地管理文件传输,尤其是在远程服务器环境中。
“`

15%

Alexhost 满足您的愿望

参与调查 并赢得奖品

Похожие записи не найдены.