984

我正在尝试将文件从远程服务器发送到我的本地计算机。只能访问端口 80。

我试过:

scp -p 80 username@www.myserver.com:/root/file.txt .

但收到此错误:cp: 80: No such file or directory

如何在 scp 命令中指定端口号?

4

13 回答 13

1726

与 ssh 不同,scp 使用大写的 P 开关来设置端口,而不是小写的 p:

scp -P 80 ... # Use port 80 to bypass the firewall, instead of the scp default

小写的 p 开关与 scp 一起使用以保存时间和模式。

以下是 scp 手册页的摘录,其中包含有关这两个开关的所有详细信息,以及为什么为 scp 选择大写 P 的解释:

-P port 指定要连接到远程主机上的端口。请注意,此选项用大写的“P”编写,因为 -p 已保留用于在 rcp(1) 中保留文件的时间和模式。

-p 保留原始文件的修改时间、访问时间和模式。

额外提示:如何确定/SSH 守护进程使用的端口来接受 SSH 连接?

这个问题可以通过使用该netstat实用程序来回答,如下所示:

sudo netstat -tnlp | grep sshd

或者,使用更易读的基于单词的 netstat 选项名称:

sudo netstat --tcp --numeric-ports --listening --program | grep sshd

假设您的 ssh 守护程序配置了其侦听端口的默认值,您将看到的输出如下所示(稍微修剪列之间的空白,以使整个表可见而无需滚动):

Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address  Foreign Address  State       ID/Program name
tcp      0      0   0.0.0.0:22     0.0.0.0:*        LISTEN      888/sshd: /usr/sbin 
tcp6     0      0   :::22          :::*             LISTEN      888/sshd: /usr/sbin 

重要的提示

对于上述示例,使用管理员权限运行 netstat ,sudo以便能够查看所有程序名称。如果您以普通用户身份运行 netstat(即,没有 sudo 并且假设您没有通过其他方法授予您管理员权限),您将只会看到以您的 UID 作为所有者的套接字显示的程序名称。属于其他用户的套接字的程序名称将不会显示(即,将被隐藏并显示占位符连字符):

Proto Recv-Q Send-Q Local Address   Foreign Address  State       ID/Program name
tcp        0      0 127.0.0.1:46371 0.0.0.0:*        LISTEN      4489/code
...
tcp        0      0 0.0.0.0:111     0.0.0.0:*        LISTEN      -                   
tcp        0      0 127.0.0.53:53   0.0.0.0:*        LISTEN      -                   
tcp        0      0 0.0.0.0:22      0.0.0.0:*        LISTEN      -                   
...

更新并搁置以解决(高度赞成的)评论之一

关于 Abdull 关于scp期权顺序的评论,他的建议是:

scp -r some_directory -P 80 ...

...,散布选项和参数,因为-r开关不接受额外的参数,some_directory并被视为命令的第一个参数,使得-P和所有后续命令行参数看起来像命令的附加参数(即,连字符前缀的参数不再视为开关)。

getopt(1)明确定义参数必须选项(即开关)之后,而不是随意穿插:

调用 getopt 的参数可以分为两部分:修改 getopt 解析方式的选项(SYNOPSIS 中的选项和 optstring),以及要解析的参数(SYNOPSIS 中的参数)。第二部分将从第一个不是选项参数的非选项参数开始,或者在第一次出现“--”之后开始。如果在第一部分中没有找到“-o”或“--options”选项,则将第二部分的第一个参数用作短选项字符串。

由于-r命令行选项没有进一步的参数,some_directory因此是“第一个不是选项参数的非选项参数”。因此,正如手册页中明确说明的那样,getopt(1)它后面的所有后续命令行参数(即-P 80 ...)都被假定为非选项(和非选项参数)。

因此,实际上,这就是以getopt(1)灰色文本划分的选项结尾和参数开头呈现的示例的方式:

scp -rsome_directory -P 80 ...

这与行为无关,scp与 POSIX 标准应用程序如何使用getopt(3)C 函数集解析命令行选项有关。

有关命令行排序和处理的更多详细信息,请阅读getopt(1)手册页:

man 1 getopt
于 2012-04-26T20:37:03.303 回答
98

一个额外的提示。将“-P”选项放在 scp 命令之后,无论您 ssh 进入的机器是否是第二台(也称为目标)。例子:

scp -P 2222 /absolute_path/source-folder/some-file user@example.com:/absolute_path/destination-folder
于 2015-10-21T09:21:49.513 回答
57

你知道什么比 更酷-P吗?没有

如果您多次使用此服务器,请设置/创建一个~/.ssh/config包含以下条目的文件:

Host www.myserver.com
    Port 80

或者

Host myserver myserver80 short any.name.u.want yes_anything well-within-reason
    HostName www.myserver.com
    Port 80
    User username

然后你可以使用:

scp username@www.myserver.com:/root/file.txt .

或者

scp short:/root/file.txt .

您可以使用 ssh、scp、rsync、git 等“主机”行上的任何内容

您可以在配置文件中使用许多配置选项,请参阅:

man ssh_config

于 2016-04-27T00:14:37.857 回答
35

我使用不同的端口然后是标准的,并在文件之间复制文件,如下所示:

scp -P 1234 user@[ip address or host name]:/var/www/mywebsite/dumps/* /var/www/myNewPathOnCurrentLocalMachine

这仅用于偶尔使用,如果它根据计划重复,您应该使用 rsync 和 cron 作业来完成它。

于 2013-08-19T09:57:11.283 回答
14

要在 scp 命令上使用另一个端口,请像这样使用大写 P

scp -P port-number source-file/directory user@domain:/destination

雅丽

于 2018-10-19T14:04:33.933 回答
7

这可以通过-P交换机指定端口来实现:

scp -i ~/keys/yourkey -P2222 file ubuntu@host:/directory/
于 2017-11-14T09:53:51.967 回答
6

scp help 告诉我们端口是由大写的 P 指定的。

~$ scp
usage: scp [-12346BCpqrv] [-c cipher] [-F ssh_config] [-i identity_file]
           [-l limit] [-o ssh_option] [-P port] [-S program]
           [[user@]host1:]file1 ... [[user@]host2:]file2

希望这可以帮助。

于 2015-07-31T16:59:05.493 回答
3

如果您需要将本地文件复制到服务器(指定端口)

scp -P 3838 /the/source/file username@server.com:/destination/file
于 2018-09-12T12:18:43.683 回答
2

将文件复制到主机: scp SourceFile remoteuser@remotehost:/directory/TargetFile

从主机复制文件: scp user@host:/directory/SourceFile TargetFile

从主机递归复制目录: scp -r user@host:/directory/SourceFolder TargetFolder

注意:如果主机使用的端口不是 22 端口,您可以使用 -P 选项指定它: scp -P 2222 user@host:/directory/SourceFile TargetFile

于 2015-07-25T21:42:22.820 回答
2

若要使用不同的远程端口将所有目录中的所有文件备份到远程 Synology NAS:

scp -P 10022 -r /media/data/somedata/* user@192.168.1.x:/var/services/homes/user/directory/

于 2020-12-30T18:50:38.380 回答
1

希望这会帮助寻找完美答案的人

将文件夹或文件从定义了端口的服务器复制到另一台服务器或本地计算机

  1. 转到您具有管理员权限的目录,最好是您要将文件复制到的计算机上的主目录
  2. 写下面的命令

scp -r -P 端口 user@IP_address:/home/file/pathDirectory 。

**Note:** The last . on the command directs it to copy everything in that folder to your directory of preference
于 2020-01-21T12:17:45.957 回答
1

可以使用 scp 协议路径指定端口:scp://[user@]host[:port][/path]

来自 man scp:

源和目标可以指定为本地路径名、具有 [user@]host:[path] 形式的可选路径的远程主机,或 scp://[user@]host[:port] 形式的 URI [/小路]。本地文件名可以使用绝对或相对路径名明确,以避免 scp 将包含 `:' 的文件名视为主机说明符。

例子:

  • scp local/filename scp://user@acme.com:22222/path/to/filename
  • scp scp://userA@foo.com:22222/path/to/filename scp://userB@bar.com:33333/path/to/filename
于 2022-02-01T13:05:58.987 回答
0

有很多答案,但你应该能够保持简单。确保您知道SSH 正在侦听的端口,并对其进行定义。这是我刚刚用来复制您的问题的内容。

scp -P 12222 file.7z user@193.168.XX:/home/user/Downloads 效果很好。

于 2020-04-03T03:06:06.217 回答