Linux服务器运维小技巧scp命令详细教程

网友投稿 946 2022-10-04

本站部分文章、图片属于网络上可搜索到的公开信息,均用于学习和交流用途,不能代表睿象云的观点、立场或意见。我们接受网民的监督,如发现任何违法内容或侵犯了您的权益,请第一时间联系小编邮箱jiasou666@gmail.com 处理。

Linux服务器运维小技巧scp命令详细教程

Linux服务器运维小技巧scp命令详细教程。

在工作的不断鞭策之下,我其实也想偷偷懒,有时候觉得怎样简单快捷怎样来。在某种特定的工作环境下,有些操作被限制死了,只能用传统的方式传输(比如定制的商业加密U盘、光盘刻录)。当你了解实际情况后,可能有更优解,你会寻求其它的突破口或者折中方案。

夸张的说法,我用了1分钟熟悉了scp的用法,并直接运用于工作当中。然而,我教同事使用,他却花了远远不止10倍的时间。其中的小窍门,你知道是为啥吗?我的回答是:善用系统提供的帮助工具或者提示。

如下图使用scp或者man scp命令:

1、简介

NAME:scp — 安全复制(远程文件复制程序)scp 在网络中的主机间进行文件复制。它用 ssh(1) 来传输及验证数据,提供与 ssh(1)相同的安全保护。它不象 rcp(1), scp 会根据需要询问口令。在任何文件名中都可以包含主机名和用户名,用来指定从/向该主机复制此文件。Linux scp 命令主要用于 Linux 之间复制文件和目录。scp 是 secure copy 的缩写, scp 是 linux 系统下基于 ssh 登陆进行安全的远程文件拷贝命令。scp 是加密的,rcp 是不加密的,scp 是 rcp 的加强版。

2、前世今生

1、排除干扰因素

2、建议

可以租多台云服务器测试,按时计费那种(腾讯云或者阿里云)。个人建议:采用VMware虚拟机搭建两台linux服务环境进行测试学习。或者安装git,使用git bash测试scp传输文件。有人会问,你为啥不直接用WinSCP或者FileZilla传输。生活在于折腾,消磨时间呗。从Windows到linux也是一样的,当然这是本机搭建的VMware虚拟环境网络是打通的。不要问我为什么,问就是省money呗。

3、准备环境

这里可以看看利用Git Bash工具,从Windows本地传文件到搭建的linux服务器上。

1、语法

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

简单来看:

scp [可选参数] 本地文件 目标目录scp root/av/local_file.av remote_username@ip:/root/avscp [可选参数] 本地目录 目标目录scp -r root/av/ remote_username@ip:/root/

2、参数解析

只介绍部分,具体可以参考官方文档。常用的、重要的也就那么几个。

参数

作用

-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为单位

-P port

注意此处是大写P, port是指定数据传输用到的端口号

-S program

指定加密传输时所使用的程序。此程序必须能够理解ssh(1)的选项

3、应用场景

命令格式介绍

#复制文件格式scp local_file remote_username@remote_ip:remote_directory #或者 scp local_file remote_username@remote_ip:remote_file #或者 scp local_file remote_ip:remote_directory #或者 scp local_file remote_ip:remote_file

复制目录命令格式

#复制命令格式scp -r local_directory remote_username@remote_ip:remote_directory #或者 scp -r local_directory remote_ip:remote_directory

3.1、本地到远程

1、准备了两台Centos7服务器,已经设置好了静态IP

2、在147服务器上准备测试内容

#新增一个av目录mkdir root/av#新增cangls文件并添加内容echo "cangls av" > root/av/cangls.av

3、指定用户名

a、传输文件

#切记传输文件时,目标目录后面不要加/,否则会提示拒绝,这个习惯至今没改过来scp root/av/cangls.av root@192.168.245.131:/root

b、验证

#传输文件,指定文件名,注意看目标文件名改了方便区别scp root/av/cangls.av root@192.168.245.131:/root/test.av

指定文件名并验证

#传输目录,需要加上-r参数scp -r root/av/ root@192.168.245.131:/root/

传输目录,到目标服务器验证

4、不指定用户名

输入的时候需要手动输入用户名和密码。

传输文件并沿用原始文件名

#传输文件,沿用原始文件名scp root/av/cangls.av 192.168.245.131:/root

传输文件,指定文件名

#传输文件,指定文件名,注意看目标文件名改了方便区别scp root/av/cangls.av 192.168.245.131:/root/test.av

传输目录,需要加上-r参数

#传输目录,需要加上-r参数scp -r root/av/ 192.168.245.131:/root/

3.2、远程到本地

从远程复制到本地,说白了就是需要知道远程的服务器IP以及用户名密码,反过来操作即可从远程取货物。换个角度思考就是原本从A端传到B端,此时从B端传到A端。前提是两端互通,不然会只进不出。

scp root@192.168.245.147:/root/av/cangls.av root

scp -r root@192.168.245.147:/root/av/ /root/

4、注意事项

scp 命令使用指定端口号 6022

#从远程服务器获取文件到本地,指定端口scp -P 6022 remote@ip:/usr/local/av.sh /root

注意

上一篇:自动化运维平台 Spug 产品简介及官方网址
下一篇:浅谈开源工具自动化运维阶段
相关文章

 发表评论

暂时没有评论,来抢沙发吧~