使用SCP上传下载文件

一、什么是scp
scp是linux系统下基于ssh登陆进行安全的远程文件拷贝命令。scp命令可以在linux服务器之间复制文件和目录.scp使用ssh安全协议传输数据,具有和ssh一样的验证机制,从而安全的远程拷贝文件。
从一个linux系统中上传,下载文件或目录时,用的最多的是ftp,用ftp的话,要登录,登录后要进行目录的切换,在get和put,感觉挺麻烦的,并且用ftp比较慢的,特别是有图形界面的ftp(例如:gftp)。当然我们可以用rsync,用它呢,就必须保持二个服务器间的目录啊,文件要一样,适用范围就受到限制了,方法有很多。scp还是比较方便和快速的。
二、scp参数及说明
yesdeMacBook-Pro:~ hxshen$ scp -help
usage: scp [-1246BCpqrv] [-c cipher] [-F s . sh_config] [-i identity_file]
[-l limit] [-o ssh_option] [-P port] [-S program] [[user@]host1:]file1 [...] [[user@]host2:]file2
-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)的选项。
三、scp实例
1,下载目录
yesdeMacBook-Pro:~ $ scp -P2208 -r [email protected]:/home/data/xx /Users/Desktop
将10.0.xx.xx linux系统中/home/data/test目录copy到当前目录下面,在这10.0.xx.xx前面加了root@,提示输入密码,如果不加呢,会提示你输入用户名和密码
2,下载文件
yesdeMacBook-Pro:~$ scp -P2208 -r [email protected]:/home/data.txt /Users/Desktop
将10.0.250.128linux系统中/home/data.txt文件copy到当前目录 /Users/Desktop下面

3,上传目录
yesdeMacBook-Pro:~ $ scp -P 2208 -r /Users/Desktop/cf1 [email protected]:/home/
将当前目录中的 /Users/Desktop/cf1目录上传到服务器/home/目录下面。

4,上传文件
yesdeMacBook-Pro:~$ scp -P 2208 -r /Users/Desktop/rec_rank_map_remainder.py @[email protected]:/home
将当前目录中的 /Users/Desktop目录下的rec_rank_map_remainder.py上传到服务器/home目录下面。
PS:-P 2208的P为大写。

5.服务器与服务器之间传输文件
登录128服务器:
scp -P 2208 -r foodFeatureNUdata.txt [email protected]:/home/haram.shen/data/
如果加密的服务器,需要使用公钥和私钥进行(以下用我的mac电脑为例):
1、在本mac 生成秘钥和公钥
ssh-keygen -t rsa -N '' -f /位置/test_key


image.png

test_key:秘钥(私钥)文件---此文件要做为scp的参数以便上传文件
test_key.pub:公钥文件---此文件内的公钥会要拷贝到远程服务器中的验证文件中如下:

2、在远程服务器上将生成的公钥拷贝到验证文件中
sudo vi /home/zhoujing/.ssh/authorized_keys


使用SCP上传下载文件_第1张图片
image.png

3、使用scp将本地文件上传到服务器中
scp -i /Users/zhoujing/test_key -P 10022 /Users/zhoujing/Desktop/webrecord.txt [email protected]:/home/zhoujing
-i 后面接的是秘钥的文件, -P是远端服务器的端口

你可能感兴趣的:(使用SCP上传下载文件)