Linux scp命令
scp全称为secure copy,即安全拷贝,是Linux下进行远程拷贝文件的命令。与其相似的命令是cp和rsync,cp只是在本机进行拷贝不能跨服务器,rsync比较占用资源,虽然会比scp快,但是在小文件众多的情况下,rsync会导致磁盘I/O非常高,而scp则可以进行跨服务器传输,并且传输时加密的,同时不会消耗多少系统资源。
语法
scp [参数] [原路径] [目标路径]
参数解释
-1 强制使用协议ssh1
-2 强制使用协议ssh2
-4 强制只使用IPv4寻址
-6 强制只使用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)的选项。
使用示例
两台服务器:server1、server2
分别进入/usr/local目录,如下图所示:
server1
server3
1、从本地拷贝文件至远程服务器
(1)将server1上/usr/local/url.txt文件拷贝至server3的相同目录下,不显示指定server3的用户名,默认与server1当前登录用户一样,为hadoop
scp命令
拷贝后,显示的url.txt所属用户和组均为hadoop,且文件名与server1一致
(2)将server1上/usr/local/url.txt文件拷贝至server3的相同目录下,显示指定server3的用户名root(之前已删除url.txt文件)
scp命令
拷贝后,显示的url.txt所属用户和组均为root,且文件名与server1一致
(3)将server1上/usr/local/url.txt文件拷贝至server3的相同目录下,显示指定server3的用户名root,并将文件重命名为urltemp.txt
scp命令
拷贝后,显示的urltemp.txt所属用户和组均为root,且文件名为urltemp.txt
2、从远程服务器拷贝文件至本地
(1)将server3上/usr/local/urltemp.txt文件拷贝至server1的相同目录下,并重命名为urltemp2.txt
scp命令
拷贝后,显示的urltemp2.txt所属用户和组均为hadoop,且文件名为urltemp2.txt
3、从本地拷贝文件夹至远程服务器(已提前准备好urltmp文件夹)
(1)将server1上/usr/local/urltemp文件夹拷贝至server3的目录/usr/local下
scp命令
拷贝后,server3的/usr/local目录下就有了一个tmp文件夹
4、从远程服务器拷贝文件夹至本地(server1已删除urltemp文件夹)
(1)将server3上/usr/local/urltemp文件夹拷贝至server1的目录/usr/local下
scp命令
拷贝后,server1的/usr/local/下存在一个urltemp文件夹,且所属用户和组全部为hadoop
5、拷贝文件夹的特殊例子
将server1上/usr/local/utltemp文件夹分别拷贝至server3上/usr/local/urltmp3和/usr/local/urltmp3/下,前者为拷贝至目录local/下,并重命名为urltmp3,后者为拷贝至目录urltmp3/下
scp命令
拷贝后,urltmp3下既存在原urltmp文件夹下的三个文件,又存在urltmp文件夹

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
-
上一篇
PyOdps 0.4版本发布,从一个故事说起
有这么个故事(如有雷同,纯属巧合)。有一天,某运营同学给某开发同学一个excel文件,里面是个客户清单。 “帮我查下这些用户的消耗呢”。 开发同学扫了一眼,几百个用户。这个事肯定是可以办的,但是想到麻烦程度,开发同学心里肯定是有不少羊驼经过的啦。 “有点麻烦啊”,开发同学轻轻抱怨。 “我懂的,把这个表和ODPS里的表join下就好了嘛。”运营同学努努嘴。 “……”。于是,开发同学把excel数据导出成文本格式,然后dship上传到ODPS,ODPS上编写SQL,dship下载,大功告成。 这里说得很轻松,但其实整个过程真的挺麻烦呢。要是这个过程中还要对excel中的数据进行过滤,最终结果还要绘个图,还是需要不少时间。 但是,如果这个开发同学使用PyOdps 0.4+版本新特性,一切就都轻松写意了。 为了模拟这个过程,我们拿movielens 10
-
下一篇
根据JSON创建对应的HIVE表
本文提供一种用SCALA把JSON串转换为HIVE表的方法,由于比较简单,只贴代码,不做解释。有问题可以留言探讨 package com.gabry.hiveimport org.json4s._import org.json4s.native.JsonMethods._import scala.io.Source class Json2Hive{ /** * sealed abstract class JValue *case object JNothing extends JValue // 'zero' for JValue *case object JNull extends JValue *case class JString(s: String) extends JValue *case class JDouble(num: Double) extends JValue *case class JDecimal(num: BigDecimal) extends JValue *case class JInt(num: BigInt) extends JValue *case...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- 面试大杂烩
- MySQL数据库在高并发下的优化方案
- CentOS8编译安装MySQL8.0.19
- Docker安装Oracle12C,快速搭建Oracle学习环境
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- Windows10,CentOS7,CentOS8安装Nodejs环境
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- CentOS关闭SELinux安全模块
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果