查看原文
其他

Linux scp命令

土豆居士 一口Linux 2021-11-06

概念

scp是secure copy的简写, 是 linux 系统下基于 ssh 登陆进行安全的远程文件拷贝命令。scp 是加密的,rcp 是不加密的,scp 是 rcp 的加强版。

因为scp传输是加密的,可能会稍微影响一下速度。另外,scp还非常不占资源,不会提高多少系统负荷,在这一点上,rsync就远远不及它了。虽然 rsync比scp会快一点,但当小文件众多的情况下,rsync会导致硬盘I/O非常高,而scp基本不影响系统正常使用。

语法

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

简易写法:

scp [可选参数] file_source file_target 

参数说明:

-1: 强制scp命令使用协议ssh1
-2: 强制scp命令使用协议ssh2
-4: 强制scp命令只使用IPv4寻址
-6: 强制scp命令只使用IPv6寻址
-B: 使用批处理模式(传输过程中不询问传输口令或短语)
-C: 允许压缩。(将-C标志传递给ssh,从而打开压缩功能)
-p: 保留原文件的修改时间,访问时间和访问权限。
-q: 不显示传输进度条。
-r: 递归复制整个目录。
-v: 详细方式显示输出。scp和ssh(1)会显示出整个过程的调试信息。这些信息用于调试连接,验证和配置问题。
-c cipher:        以cipher将数据传输进行加密,这个选项将直接传递给ssh。
-F ssh_config:    指定一个替代的ssh配置文件,此参数直接传递给ssh。
-i identity_file: 从指定文件中读取传输时使用的密钥文件,此参数直接传递给ssh。
-l limit:         限定用户所能使用的带宽,以Kbit/s为单位。
-o ssh_option:    如果习惯于使用ssh_config(5)中的参数传递方式,
-P port:          注意是大写的P, port是指定数据传输用到的端口号
-S program:       指定加密传输时所使用的程序。此程序必须能够理解ssh(1)的选项。

命令实例

预置条件:

本例在vmware打开了两个ubuntu。 

ubuntu A 地址:192.168.6.186,并开启了ssh服务器 ;

ubuntu B 地址:192.168.6.111。

安装ssh命令如下:

apt-get install openssh-server

ssh详细安装步骤可以参考博文:《Ubuntu18.04搭建ssh服务器》

开启ssh服务器指令【ubuntu A】:

  /etc/init.d/ssh restart

执行结果如下:

例1 下载文件

把192.168.6.186服务器的t.log拷贝到当前服务器的当前目录下;

scp -r root@192.168.6.186:/home/peng/test/t.log ./

执行结果如下:

例2 上传文件

scp icons.png root@192.168.1.1:/root/下载   #本机文件,copy远程服务器

执行结果:

例3 下载目录

以root用户登录ubuntu A的ssh服务器,并将文件夹copy到本地

 scp -r root@192.168.6.186:/home/peng/driver/list  /home/peng/test

执行结果【ubuntu B】:

例4 上传目录

将本地文件copy到服务器,添填写用户,默认当前用户

scp /home/peng/test/t.log 192.168.6.186:/home/peng/test 

执行结果【ubuntu B】:

 

看到错误提示:Permission denied,这个错误是因为服务器A的文件夹/home/peng/test没有修改权限。 

进入ubuntu A,修改对应文件夹访问权限:

再次执行命令 【ubuntu B】:

显示传输的文件【ubuntu A】

例5 指定端口

使用指定端口从本地拷到远程服务器

scp -P 20022 -r /home/peng/test/list root@192.168.6.186:/home/peng/test

例6 使用证书

使用证书登录,并递归的将远程目录下载到本地,同时指定了所需要的端口号。

scp -r -i /Users/test/wx_Document/private.crt -P 2323 root@10.135.178.6:/data/htdocs/www/logs /Users/local  


END



一口君个人微信


添加一口君个人微信即送Linux、嵌入式等独家入门视频


→ 精选技术资料共享

→ 高手如云交流社群





本公众号全部原创干货已整理成一个目录,请在公众号里回复「m」获取!或者关注进入后台点击左下角「干货」!

推荐阅读



【1】手把手教Linux驱动1-模块化编程
【2】手把手教Linux驱动2-模块参数param和符号导出export用法
【3】手把手教Linux驱动3-之字符设备架构详解,有这篇就够了
【4】手把手教Linux驱动4-进程、文件描述符、file、inode关系详解
【5】玩转内核链表list_head,如何管理不同类型节点的实现(万字文)可以收藏
【6】
I2C干货-基于Cortex-A9(重新整理)【7】一文搞懂ADC裸机和基于Linux驱动编写方法
【8】22张图详解浏览器请求数据包如何到达web服务器(搞懂网络可以毕业了)
【9】手把手教Linux驱动5-自旋锁、信号量、互斥体概述
【10】Linux命令cURL详解+定时上传文件到FTP服务器(送源码)


5T技术资源大放送!包括但不限于:C/C++,Linux,Python,Java,PHP,人工智能,单片机,树莓派,等等。在公众号内回复「1024」,即可免费获取!!




一键四连
: . Video Mini Program Like ,轻点两下取消赞 Wow ,轻点两下取消在看

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存