该scp
命令使在 Linux 计算机之间复制文件变得简单而安全。它使用SSH 安全性,但最重要的是,它很简单。如果可以使用cp
,可以使用scp
。
安全复制协议和 scp
让我们定义几个术语:有 SCP 和scp
. 大写的 SCP 代表安全复制协议。小写字母scp
代表安全cp
。换句话说,SCP是一个协议,scp
是一个程序。
scp
被设计为一种在远程 Linux 计算机之间复制文件的安全方法。它使用 SSH 建立安全连接。SSH 或安全外壳是一种加密网络协议,通常用于访问和登录远程 Linux 计算机。在Linux 发行版上,SSH 功能由 OpenSSH 提供。
SCP 有点长,人们对它在今天的使用表示担忧。自 OpenSSH 版本 8.8 起,SCP 已被视为已弃用。scp
默认情况下默认使用安全文件传输协议的现代实现。SSH 仍用于安全连接,但文件传输由SFTP处理。这一切都是不可见的,并且在幕后神奇地发生,并且scp
语法保持不变。
该rsync
程序优先于scp
,但您可能会遇到一台尚未rsync
安装且您没有root权限的计算机,这意味着您无法继续安装它。对于在独立网络上将文件从计算机复制到计算机,scp
非常好。为了scp
工作,您必须在您将复制到和从中复制的所有计算机上运行 SSH。
要查看计算机上安装的 OpenSSH 版本,请键入:
ssh -V
复制单个文件
与标准cp
命令一样,将scp
文件从 源 位置复制到 目标 位置。要将文件复制到远程计算机,您必须知道远程计算机的 IP 地址或网络名称。您还必须拥有对您要将文件发送到的位置具有写入权限的用户帐户的凭据。
要将名为“sample.txt”的文件发送到本地网络上名为“fedora-34”的计算机,语法为:
scp ./sample.txt dave@fedora-34.local:/home/dave/Downloads/
该命令由以下部分组成:
- scp : scp 命令
- ./sample.txt:我们要发送的文件。这是在当前目录中。
- dave@:我们要将文件发送到的远程计算机上的用户帐户。
- fedora-34.local:远程计算机的网络名称。
- :/home/dave/Downloads/:将文件复制到远程计算机上的位置。注意分隔计算机名称和路径的冒号“:”。
系统将提示您输入远程计算机上帐户的密码,然后复制文件。
如果您希望文件在远程计算机上具有不同的名称,您可以将文件名添加到目标路径。要复制同一个文件并将其命名为“different-file.txt”,请使用以下语法:
scp ./sample.txt dave@fedora-34.local:/home/dave/Downloads/different-file.txt
该scp
命令将静默覆盖现有文件,因此在复制文件时要小心。如果目标计算机上已经存在与您正在复制的文件同名的文件,它将被覆盖并丢失。
如果目标计算机未使用默认的 SSH 端口 22,您可以使用-P
(port number) 选项提供适当的端口号。
检索单个文件
要从远程服务器复制文件,只需将远程服务器作为源,并将要复制文件的本地路径作为目标。我们将从远程计算机复制一个名为“development-plan.md”的文件到本地计算机的当前目录。
scp dave@fedora-34.local:/home/dave/Downloads/development-plan.md。
如果将文件名添加到本地路径,则会复制该文件并赋予该名称。
scp dave@fedora-34.local:/home/dave/Downloads/development-plan.md ./dp-1.md
该文件被复制但重命名为我们指定的文件名。
ls -hl *.md
复制多个文件
在任一方向复制多个文件很容易。您可以列出任意数量的源文件。在这里,我们复制了两个markdown文件和一个CSV 文件。
scp ./dp-1.md ./dp-2.md ./dp-3.csv dave@fedora-34.local:/home/dave/Downloads/
这三个文件被复制到远程计算机。您也可以使用通配符。该命令与上一个命令的作用完全相同。
scp ./dp 。 dave@fedora-34.local:/home/dave/Downloads/
递归复制目录
( -r
recursive) 选项允许您使用单个命令复制整个目录树。我们将两个文件放在一个名为“data”的目录中,并在“data”目录中创建了一个名为“CSV”的目录。我们在“data/CSV”目录中放置了一个 CSV 文件。
此命令复制文件并在远程计算机上重新创建目录结构。
scp -r ./data dave@fedora-34.local:/home/dave/Downloads/
在远程服务器之间复制文件
您甚至可以指示scp
将文件从一台远程服务器复制到另一台服务器。语法非常简单。您提供源服务器的帐户名和网络地址以及目标服务器的帐户名和网络地址。这些文件从源服务器复制并复制到目标服务器上的位置。
虽然语法很简单,但确保其他一切都到位需要更多的思考。显然,您尝试将文件复制到远程服务器上的位置必须可由您在命令行中指定的用户帐户访问。并且该用户帐户必须对该位置具有写入权限。
一个更微妙的先决条件是必须在本地计算机和源计算机之间以及源服务器和目标服务器之间设置 SSH 访问。确保您可以使用 SSH 从源服务器登录到目标服务器。如果你不能这样做,scp
将无法连接。
设置 SSH 密钥以便您可以使用经过身份验证但无密码的访问是目前首选的方法。使用密码很快就会变得一团糟,而且——因为系统会提示您输入每个用户帐户的密码——它会阻止您使用脚本完全自动化该过程。
我们为每个远程服务器上使用的用户帐户设置 SSH 密钥。这为这两个用户提供了对另一台服务器的无缝 SSH 访问。这允许我们使用这两个用户帐户向任一方向传输文件。
要将文件从Manjaro计算机上的“davem”用户帐户复制到 Fedora 计算机上的“dave”帐户,通过scp
我们本地 Ubuntu 计算机发出的命令,语法是:
scp davem@manjaro20-0-1.local:/home/davem/man 。 dave@fedora-34.local:/home/dave/
我们默默地返回到命令行。没有迹象表明发生了什么事。在没有消息就是好消息的前提下工作,scp
只报告这个远程到远程复制的错误。在检查 Fedora 计算机时,我们可以看到来自 Manjaro 计算机的文件已被复制和接收。
默认情况下,文件直接从源计算机复制到目标计算机。您可以使用-3
(三向)选项覆盖它。
使用此选项,文件通过本地计算机从目标传输到源。为此,需要从本地计算机到目标计算机的无缝 SSH 访问。
scp -3 davem@manjaro20-0-1.local:/home/davem/man 。 dave@fedora-34.local:/home/dave/
即使通过本地计算机传输文件,仍然没有任何迹象表明发生了任何事情。布丁的证明,当然是检查目标计算机。
其他选项
(-p
保留文件属性)将保留传输文件上的原始文件创建、所有权和访问标志。它们将具有与源计算机上的原始文件相同的元数据。
如果您看到错误消息,请尝试重复该命令并使用-v
(verbose) 标志查看有关传输尝试的详细信息。您应该能够在输出中发现故障点。
( -C
compress) 选项在复制文件时压缩文件,并在收到文件时对其进行解压缩。这可以追溯到计算机之间的慢速调制解调器通信时代。减小有效载荷的大小可以减少传输时间。
如今,压缩和解压缩文件所需的时间可能比压缩和未压缩传输之间的差异要长。但是因为scp
最好用于在同一局域网的计算机之间复制文件,所以传输速度应该不是太大的问题。
未经允许不得转载:表盘吧 » 如何在 Linux 上使用 scp 命令