scp 详细总结

转自:http://www.ha97.com/4169.html

scp命令跟cp命令类似,只不过cp命令是在同一台机器上用的,scp是在两台机器上复制传输数据的命令。scp实质相当于利用SSH协议来传输数据的cp命令。

用法举例:

1、复制远程服务器的文件到本地:
scp -P888 root@120.18.50.33:/data/ha97.zip
/home/

2、复制远程服务器的目录到本地:
scp -vrp -P888
[email protected]:/data/ha97/ /home/

3、复制本地的文件到远程服务器:
scp
-P888 /home/ha97.zip [email protected]:/data/

4、复制本地的目录到远程服务器:

scp -vrp -P888 /home/ [email protected]:/data/

SCP 命令语法
scp [-1245BCpqrv] [-c cipher] [F ssh_config] [-I
identity_file] [-l limit] [-o ssh_option] [-P port] [-S program]
[[[email protected]]host1:] file1 […] [[[email protected]]host2:]file2

SCP 命令说明
Scp在主机间复制文件。他使用 ssh(1)作为数据传输。而且用同样认证和安全性。
scp将在认证中请求输入密码所有的文件可能需要服务器和用户的特别描述来指明文件将被复制到/从某台服务器。两个远程登录的服务器间的文件复制是允许的。


SCP 命令选项
-1 强制scp 用协议1
-2
强制scp 用协议2
-4 强制scp用IPV4的网址
-6 强制scp用IPV6的网址
-B 选择批处理模式(防止输入密码)
-C
允许压缩。 标注-C到ssh(1)来允许压缩
-c cipher
选择cipher来加密数据传输。这个选项直接传递到ssh(1)
-F
ssh_config
设定一个可变动的用户配置给ssh.这个选项直接会被传递到ssh(1)
-i identity_file

选择被RSA认证读取私有密码的文件。这个选项可以直接被传递到ssh(1)
-l limit
限制传输带宽,也就是速度 用Kbit/s的速度

-o ssh_option

可以把ssh_config中的配置格式传到ssh中。这种模式对于说明没有独立的scp文件中断符的scp很有帮助。关于选项的如下。而他们的值请参看ssh_config(5)

-P port
指定连接远程连接端口。注意这个选项需要写成大写的模式。因为-p已经早保留了次数和模式
-S program

指定一个加密程序。这个程序必须可读所有ssh(1)的选项。
-p 指定修改次数,连接次数,还有对于原文件的模式
-q 把进度参数关掉
-r
递归的复制整个文件夹
-S program
指定一个加密程序。这个程序必须可读所有ssh(1)的选项。
-V 冗余模式。 让 scp 和
ssh(1) 打印他们的排错信息, 这个在排错连接,认证,和配置中非常有用。

SCP 命令诊断
scp 返回0 成功时,不成功时返回值大于0

SCP 命令不需要输入用户密码的使用方法

在两台机器的两个用户之间建立安全的信任关系后,可实现执行scp命令时不需要输入用户密码。

1. 在机器A上root用户执行 ssh-keygen 命令,生成建立安全信任关系的证书。


[[email protected] root]# ssh-keygen -b 1024 -t rsa
Generating public/private rsa
key pair.
Enter file in which to save the key (/root/.ssh/id_rsa): <–
直接输入回车
Enter passphrase (empty for no passphrase): <– 直接输入回车
Enter
same passphrase again: <– 直接输入回车
Your identification has been saved in
/root/.ssh/id_rsa.
Your public key has been saved in
/root/.ssh/id_rsa.pub.
The key fingerprint is: ……



注意:在程序提示输入 passphrase 时直接输入回车,表示无证书密码。
上述命令将生成私钥证书 id_rsa
和公钥证书 id_rsa.pub,存放在用户目录的 .ssh
子目录中。

2. 将公钥证书 id_rsa.pub
复制到机器B的root目录的.ssh子目录中,同时将文件名更换为authorized_keys


[[email protected] root]# scp -p .ssh/id_rsa.pub
[email protected]机器B的IP:/root/.ssh/authorized_keys
[email protected]’s password: <–
输入机器B的root用户密码



在执行上述命令时,两台机器的root用户之间还未建立安全信任关系,所以还需要输入机器B的root用户密码。

经过以上2步,就在机器A的root和机器B的root之间建立安全信任关系。下面我们看看效果:

[[email protected] root]#
scp -p test [email protected]机器B的IP地址:/root


成功了!真的不再需要输入密码了。

scp 详细总结,码迷,mamicode.com

时间: 2024-10-13 04:53:14

scp 详细总结的相关文章

SCP命令用法

scp用法 scp [参数] 源文件 目标文件 SCP详细用法 1. man scp查看 2. [菜鸟教程SCP详解](http://www.runoob.com/linux/linux-comm-scp.html) 抽象示例: 1. 本地复制到远程 scp 本地文件地址 用户名@远程地址或主机名:远程文件地址 scp 本地文件地址 远程地址或主机名:远程文件地址 2. 远程复制到本地 scp 用户名@远程地址或主机名:远程文件地址 本地文件地址 scp 远程地址或主机名:远程文件地址 本地文件

详细解析Linux scp命令的应用

详细解析Linux scp命令的应用 Linux命令有人统计说是有4000多个,Linux scp命令是用于Linux之间复制文件和目录,这里详细介绍scp命令使用和参数. AD: Linux scp命令用于Linux之间复制文件和目录,具体如何使用这里好好介绍一下,从本地复制到远程.从远程复制到本地是两种使用方式.这里有具体举例: ================== Linux scp 命令 ================== scp 可以在 2个 linux 主机间复制文件: 命令基本格

详细解析Linux scp命令的应用(转载)

转自:http://os.51cto.com/art/201003/187301.htm Linux scp命令用于Linux之间复制文件和目录,具体如何使用这里好好介绍一下,从本地复制到远程.从远程复制到本地是两种使用方式.这里有具体举例: ================== Linux scp 命令 ================== scp 可以在 2个 linux 主机间复制文件: 命令基本格式: scp [可选参数] file_source file_target ====== 从

Linux下cp和scp的详细说明及其他们的区别

一.说明 cp:是在同一个linux系统上,在不同的目录之间复制文件: scp:是在不同linux系统之间来回复制文件: 二.cp 用法 单个文件复制: cp   源文件   目标路径  ~~从原路径复制源文件到目标路径下:如果在目标路劲之后加文件名称和格式意思就是复制过去之后将该文件重命名. 多个文件复制: cp   源文件1  源文件2 源文件3 ...   目标路径  ~~从原路径复制源文件到目标路径下: 三.cp 的参数详解 -a 尽可能将源文件状态.权限等资料都照原装予以复制,并且是递

SCP 命令参数使用详解(最详细使用指南)

在linux 下scp 命令主要用来在不同主机之间做数据的安全拷贝的.scp 命令可以将文件从本地的计算机中拷贝到远程的主机中,或者从远程计算机中拷贝文件到本地主机,scp命令使用的安全加密的协议,所以在远程拷贝数据的时候会比较安全,不会被黑客截取. 这个命令在日常的工作中经常会被用到,尤其是在多主机的集群环境中或者在cloud 环境里,比如当你想配置hadoop大数据环境或者配置openstack 多节点环境的时候,都会用用到scp命令,用来配置节点间无密码登陆. 本文将会讲述在linux系统

机器A scp 机器B不需要输入密码的详细步骤

机器A:macBook笔记本 机器B:linux台式机 需求:要在mac本上scp项目jar包到linux台式机上,但是每次都需要输入台式机的用户密码,如何不用输入密码? 网管意见:生成ssh key 步骤: 首先在台式机上执行命令: <span style="font-family:Microsoft YaHei;font-size:14px;"><strong>which ssh-copy-id</strong></span> /us

SSH的三个组件ssh、sftp、scp(详细)

SSH  包含3个组件 (1) ssh 远程登录节点 : ssh 用户名@IP地址 ① 不允许空密码或错误密码认证登录 ② 不允许root用户登录 ③ 有两个版本 ssh,ssh2安全性更高 (2) sftp 文件共享连接 , xftp连接就是 sftp实现的 (3)scp  文件拷贝共享 scp命令 :两节点文件的拷贝传输 (1)向目标节点传文件 : scp  路径/文件名 用户名@IP地址:目录 如:向127.0.0.1节点的root用户/tmp 下传文件 scp 路径/文件名 [email

Linux命令之scp

Linux命令之scp 功能说明 scp 是secure copy的简写,用于在Linux下进行远程拷贝文件的命令,和它类似的命令有cp,不过cp只是在本机进行拷贝不能跨服务器,而且 scp传输是加密的.可能会稍微影响一下速度.当你服务器硬盘变为只读 read only system时,用scp可以帮你把文件移出来.另 外,scp还非常不占资源,不会提高多少系统负荷,在这一点上,rsync就远远不及它了.虽然 rsync比scp会快一点,但当小文件众多的情况 下,rsync会导致硬盘I/O非常高

Linux scp命令

scp是secure copy的简写,用于在Linux下进行远程拷贝文件的命令,和它类似的命令有cp,不过cp只是在本机进行拷贝不能跨服务器,而且scp传输是加密的.可能会稍微影响一下速度.当你服务器硬盘变为只读 read only system时,用scp可以帮你把文件移出来.另外,scp还非常不占资源,不会提高多少系统负荷,在这一点上,rsync就远远不及它了.虽然 rsync比scp会快一点,但当小文件众多的情况下,rsync会导致硬盘I/O非常高,而scp基本不影响系统正常使用. 1.命