位置: 编程技术 - 正文

Linux中SSH的SCP传输命令运用详解

编辑:rootadmin

推荐整理分享Linux中SSH的SCP传输命令运用详解,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

Linux系统管理员应该很熟悉CLI环境,因为通常在Linux服务器中是不安装GUI的。SSH可能是Linux系统管理员通过远程方式安全管理服务器的最流行协议。在SSH命令中内置了一种叫SCP的命令,用来在服务器之间安全传输文件。以下命令可以解读为:用“username account”“拷贝 source file name”到“destination host”上的“destination folder”里。SCP命令的基本语法

复制代码代码如下:scp source_file_name username@destination_host:destination_folder

SCP命令有很多可以使用的参数,这里指的是每次都会用到的参数。用-v参数来提供SCP进程的详细信息

不带参数的基本SCP命令会在后台拷贝文件,除非操作完成或者有错误出现,否则用户在界面上是看不到任何提示信息的。你可以用“-v”参数来在屏幕上打印出调试信息,这能帮助你调试连接、认证和配置的一些问题。

复制代码代码如下: pungki@mint ~/Documents $ scp -v Label.pdf mrarianto@.x.x.x:.

部分输出

复制代码代码如下:Executing: program /usr/bin/ssh host .x.x.x, user mrarianto, command scp -v -t . OpenSSH_6.0p1 Debian-3, OpenSSL 1.0.1c May debug1: Reading configuration data /etc/ssh/ssh_config debug1: /etc/ssh/ssh_config line : Applying options for * debug1: Connecting to .x.x.x [.x.x.x] port . debug1: Connection established. debug1: Host '.x.x.x' is known and matches the RSA host key. debug1: Found key in /home/pungki/.ssh/known_hosts:1 debug1: ssh_rsa_verify: signature correct debug1: Next authentication method: password mrarianto@.x.x.x's password: debug1: Authentication succeeded (password). Authenticated to .x.x.x ([.x.x.x]:). Sending file modes: C Label.pdf Sink: C Label.pdf Label.pdf % KB .0KB/s : Transferred: sent , received bytes, in .2 seconds Bytes per second: sent .4, received .0 debug1: Exit status 0

从源文件获取修改时间、访问时间和模式

“-p”参数会帮到把预计的时间和连接速度会显示在屏幕上。

复制代码代码如下:pungki@mint ~/Documents $ scp -p Label.pdf mrarianto@.x.x.x:.

部分输出

复制代码代码如下:mrarianto@.x.x.x's password: Label.pdf % KB .6KB/s :

用-C参数来让文件传输更快

有一个参数能让传输文件更快,就是“-C”参数,它的作用是不停压缩所传输的文件。它特别之处在于压缩是在网络传输中进行,当文件传到目标服务器时,它会变回压缩之前的原始大小。

来看看这些命令,我们使用一个 Mb的单一文件来做例子。

复制代码代码如下:pungki@mint ~/Documents $ scp -pv messages.log mrarianto@.x.x.x:.

部分输出

复制代码代码如下:Executing: program /usr/bin/ssh host .x.x.x, user mrarianto, command scp -v -p -t . OpenSSH_6.0p1 Debian-3, OpenSSL 1.0.1c May debug1: Reading configuration data /etc/ssh/ssh_config debug1: /etc/ssh/ssh_config line : Applying options for * debug1: Connecting to .x.x.x [.x.x.x] port . debug1: Connection established. debug1: identity file /home/pungki/.ssh/id_rsa type -1 debug1: Found key in /home/pungki/.ssh/known_hosts:1 debug1: ssh_rsa_verify: signature correct debug1: Trying private key: /home/pungki/.ssh/id_rsa debug1: Next authentication method: password mrarianto@.x.x.x's password: debug1: Authentication succeeded (password). Authenticated to .x.x.x ([.x.x.x]:). debug1: Sending command: scp -v -p -t . File mtime atime Sending file timestamps: T 0 0 messages.log % MB .6KB/s : Transferred: sent , received bytes, in .3 seconds Bytes per second: sent .4, received .6 debug1: Exit status 0

不用“-C”参数来拷贝文件,结果用了.3秒,你可以比较下用了“-C”参数之后的结果。

复制代码代码如下: pungki@mint ~/Documents $ scp -Cpv messages.log mrarianto@.x.x.x:.

部分输出

复制代码代码如下:Executing: program /usr/bin/ssh host .x.x.x, user mrarianto, command scp -v -p -t . OpenSSH_6.0p1 Debian-3, OpenSSL 1.0.1c May debug1: Reading configuration data /etc/ssh/ssh_config debug1: /etc/ssh/ssh_config line : Applying options for * debug1: Connecting to .x.x.x [.x.x.x] port . debug1: Connection established. debug1: identity file /home/pungki/.ssh/id_rsa type -1 debug1: Host '.x.x.x' is known and matches the RSA host key. debug1: Found key in /home/pungki/.ssh/known_hosts:1 debug1: ssh_rsa_verify: signature correct debug1: Next authentication method: publickey debug1: Trying private key: /home/pungki/.ssh/id_rsa debug1: Next authentication method: password mrarianto@.x.x.x's password: debug1: Enabling compression at level 6. debug1: Authentication succeeded (password). Authenticated to .x.x.x ([.x.x.x]:). debug1: channel 0: new [client-session] debug1: Sending command: scp -v -p -t . File mtime atime Sending file timestamps: T 0 0 Sink: T 0 0 Sending file modes: C messages.log messages.log % MB .7KB/s : Transferred: sent , received bytes, in .5 seconds Bytes per second: sent .9, received .0 debug1: Exit status 0 debug1: compress outgoing: raw data , compressed , factor 0. debug1: compress incoming: raw data , compressed , factor 0.

看到了吧,压缩了文件之后,传输过程在.5秒内就完成了,速度是不用“-C”参数的倍。如果你要通过网络拷贝很多份文件,那么“-C”参数能帮你节省掉很多时间。

有一点我们需要注意,这个压缩的方法不是适用于所有文件。当源文件已经被压缩过了,那就没办法再压缩很多了。诸如那些像.zip,.rar,pictures和.iso的文件,用“-C”参数就没什么意义。选择其它加密算法来加密文件

SCP默认是用“AES-”加密算法来加密传输的。如果你想要改用其它加密算法来加密传输,你可以用“-c”参数。我们来瞧瞧。

复制代码代码如下:pungki@mint ~/Documents $ scp -c 3des Label.pdf mrarianto@.x.x.x:. mrarianto@.x.x.x's password: Label.pdf % KB .5KB/s :

Linux中SSH的SCP传输命令运用详解

上述命令是告诉SCP用3des algorithm来加密文件。要注意这个参数是“-c”(小写)而不是“-C“(大写)。限制带宽使用

还有一个很有用的参数是“-l”参数,它能限制使用带宽。如果你为了拷贝很多文件而去执行了一份自动化脚本又不希望带宽被SCP进程耗尽,那这个参数会非常管用。

复制代码代码如下:pungki@mint ~/Documents $ scp -l Label.pdf mrarianto@.x.x.x:. mrarianto@.x.x.x's password: Label.pdf % KB .3KB/s :

在“-l”参数后面的这个值意思是我们给SCP进程限制了带宽为 KB/秒。有一点要记住,带宽是以千比特/秒 (kbps)表示的,而8 比特等于1 字节。

因为SCP是用千字节/秒 (KB/s)计算的,所以如果你想要限制SCP的最大带宽只有 KB/s,你就需要设置成 x 8 = 。指定端口

通常SCP是把作为默认端口。但是为了安全起见SSH 监听端口改成其它端口。比如说,我们想用端口,这种情况下就要指定端口。命令如下所示。

复制代码代码如下:pungki@mint ~/Documents $ scp -P Label.pdf mrarianto@.x.x.x:. mrarianto@.x.x.x's password: Label.pdf % KB .3KB/s :

确认一下写的是大写字母“P”而不是“p“,因为“p”已经被用来保留源文件的修改时间和模式(LCTT 译注:和 ssh 命令不同了)。递归拷贝文件和文件夹

有时我们需要拷贝文件夹及其内部的所有文件/子文件夹,我们如果能用一条命令解决问题那就更好了。SCP用“-r”参数就能做到。

复制代码代码如下:pungki@mint ~/Documents $ scp -r documents mrarianto@.x.x.x:. mrarianto@.x.x.x's password: Label.pdf % KB .5KB/s : scp.txt % KB 9.8KB/s :

拷贝完成后,你会在目标服务器中找到一个名为“documents”的文件夹,其中就是所拷贝的所有文件。“documents”是系统自动创建的文件夹。禁用进度条和警告/诊断信息

如果你不想从SCP中看到进度条和警告/诊断信息,你可以用“-q”参数来静默它们,举例如下。

复制代码代码如下:pungki@mint ~/Documents $ scp -q Label.pdf mrarianto@.x.x.x:. mrarianto@.x.x.x's password: pungki@mint ~/Documents $

正如你所看到的,在你输入密码之后,没有任何关于SCP进度的消息反馈。进度完成后,你也看不到任何提示。用SCP通过代理来拷贝文件

代理服务器经常用于办公环境,SCP自然是没有经过代理方面的配置的。当你的环境正在使用代理,那么你就必须要“告诉”SCP与代理关联起来。

场景如下:代理的地址是.0..6,端口是。该代理还实现了用户认证功能。首先,你需要创建一个“~/.ssh/config”文件,其次把以下命令输入进该文件。

复制代码代码如下: ProxyCommand /usr/bin/corkscrew .0..6 %h %p ~/.ssh/proxyauth

接着你需要创建一个同样包括以下命令的“~/.ssh/proxyauth”文件。

复制代码代码如下:myusername:mypassword

然后你就可以像往常一样使用SCP了。

请注意corkscrew可能还没有安装在你的系统中。在我的Linux Mint中,我需要首先先用标准Linux Mint安装程序来安装它。

复制代码代码如下:$ apt-get install corkscrew

对于其它的一些基于yum安装的系统,用户能用以下的命令来安装corkscrew。

复制代码代码如下:# yum install corkscrew

还有一点就是因为“~/.ssh/proxyauth”文件中以明文的格式包含了你的“用户名”和“密码”,所以请确保该文件只能你来查看。选择不同的ssh_config文件

对于经常在公司网络和公共网络之间切换的移动用户来说,一直改变SCP的设置显然是很痛苦的。如果我们能放一个保存不同配置的ssh_config文件来匹配我们的需求那就很好了。以下是一个简单的场景

代理是被用来在公司网络但不是公共网络并且你会定期切换网络时候使用的。

复制代码代码如下:pungki@mint ~/Documents $ scp -F /home/pungki/proxy_ssh_config Label.pdf mrarianto@.x.x.x:. mrarianto@.x.x.x's password: Label.pdf % KB .5KB/s :

默认情况下每个用户会把“ssh_config”文件放在“~/.ssh/config“路径下。用兼容的代理创建一个特定的“ssh_config”文件,能让你切换网络时更加方便容易。

当你处于公司网络时,你可以用“-F”参数,当你处于公共网络时,你可以忽略掉“-F”参数。

标签: Linux中SSH的SCP传输命令运用详解

本文链接地址:https://www.jiuchutong.com/biancheng/366842.html 转载请保留说明!

上一篇:Linux常用网络工具之主机扫描工具fping使用介绍(linux在网络方面的应用)

下一篇:Linux常用网络工具之高级主机扫描工具hping使用介绍(linux强大的网络功能)

  • 个税申报显示无有效的税费种认定信息已核定
  • 付钱给对方会计分录
  • 年报资金数额要怎样填
  • 小规模纳税人不开票收入怎么报税
  • 企业付的快递费是扣增值税还是进入费用扣除
  • 费用挂账的会计分录怎么做
  • 事业单位的会计制度是什么
  • 企业所得税查增值税吗
  • 新个税劳务费税率怎么算
  • 应交税费应交增值税的三级科目有哪些
  • 银行的期初数据怎么进行账务处理?
  • 公司收到股东的钱现金流量表怎么填
  • 发票认证了还能退回吗
  • 计提汇算清缴所得税分录
  • 文化建设事业费按季度申报吗
  • 发票认证系统查不到发票
  • 固定资产清理属于资产类的备抵科目吗
  • 外贸企业申报出口退税商品名称可以改吗
  • 出口退税的计算题
  • 合同增值税如何申报
  • 商业承兑到期兑不出来多久的追诉期
  • 多交的增值税怎么申报
  • 无线路由器1200m覆盖范围
  • 为什么无形资产是非流动资产
  • linux attached
  • 报税时漏报进项怎么办
  • 公司注册小规模有什么要求
  • php odbc
  • 科罗拉多斯普林斯海拔
  • 建造合同完工百分比法
  • 最大的apple商店
  • php实现图片上传显示
  • 存货的盘亏损毁和报废
  • 代购货物的缴税情况
  • 前端将base64图片转换成file文件
  • 装修费用当月摊还是次月摊销
  • egi脑电数据处理
  • 记载资金的账簿
  • 印花税城建税和教育费附加怎么算
  • 国企无偿划转股权免印花税
  • 开具红字发票资料清单
  • mysql数据库基本操作
  • 织梦添加文章如何修改高级参数
  • 主营业务成本可以设明细科目吗
  • 附加税多计提了怎么调整
  • 公司控股另一家公司好与坏
  • mysql性能问题
  • 增值税进项发票不够抵扣怎么办
  • 预收账款是什么要素
  • 投资性房地产出租收入计入什么科目
  • 应收代位追偿款会计分录
  • 评估价值高于账面价值怎么账务处理
  • 外币资产汇兑损失计算公式
  • 固定资产计提折旧是当月还是次月
  • 电子发票上面的字体是什么字体
  • 建账需要买哪些会计用品
  • mongodb与mysql相比的优缺点
  • 常用的sql语句有哪些
  • 硬盘磁盘保护
  • ubuntu禁用服务命令
  • linux日志类型
  • freebsd 安装
  • microsoft/微软
  • WIN10系统中引导修复不工作
  • windows 8连接vpn设置方法(消费者预览版)
  • windows8用的人少
  • WIN10系统中软件打开找不到网络共享盘
  • linux diff命令详解
  • bat 批处理文件
  • css的transition和animation
  • shell脚本监控日志输出
  • 在JavaScript中声明变量的关键词有
  • great 搬运工
  • 简单的设计模式
  • 使用jQuery操作HTML的table表格的实例解析
  • 自然人申报密码丢失如何找回
  • 社保申报截止日期每月2023年
  • 公务员中了彩票怎么领取
  • 年应税销售额超过小规模纳税人标准的企业
  • 电子发票怎么作废
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设