如何在智能告警平台CA触发测试告警
946
2022-10-04
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
注意
发表评论
暂时没有评论,来抢沙发吧~