scp是linux系统下基于ssh登陆进行安全的远程文件拷贝命令。scp命令可以在linux服务器之间复制文件和目录.scp使用ssh安全协议传输数据,具有和ssh一样的验证机制,从而安全的远程拷贝文件。
从一个linux系统中上传,下载文件或目录时,用的最多的是ftp,用ftp的话,要登录,登录后要进行目录的切换,在get和put,感觉挺麻烦的,并且用ftp比较慢的,特别是有图形界面的ftp(例如:gftp)。当然我们可以用rsync,用它呢,就必须保持二个服务器间的目录啊,文件要一样,适用范围就受到限制了,方法有很多。scp还是比较方便和快速的。
yesdeMacBook-Pro:~ hxshen$ scp -help
usage: scp [-1246BCpqrv] [-c cipher] [-F ssh_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)的选项。
1,下载目录
yesdeMacBook-Pro:~ $ scp -P2208 -r xxxx@10.0.xx.xx:/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 xxxx@10.0.xx.xx:/home/data.txt /Users/Desktop
将10.0.250.128linux系统中/home/data.txt文件copy到当前目录 /Users/Desktop下面
3,上传目录
yesdeMacBook-Pro:~ $ scp -P2208 -r /Users/Desktop/cf1 haram.shen@10.0.xx.xx:/home/
将当前目录中的 /Users/Desktop/cf1目录上传到服务器/home/目录下面。
4,上传文件
yesdeMacBook-Pro:~$ scp -P2208 -r /Users/Desktop/rec_rank_map_remainder.py @xxxx@10.0.xx.xx:/home
将当前目录中的 /Users/Desktop目录下的rec_rank_map_remainder.py上传到服务器/home目录下面。
PS:-P2208的P为大写。
5.服务器与服务器之间传输文件
登录128服务器:
scp -P2208 -r foodFeatureNUdata.txt [email protected]:/home/haram.shen/data/