使用scp命令在linux操作系统之间传递文件
一、关于scp
scp是英文secure copy (remote file copy program)的简称,主要用于在两台主机之间通过网络拷贝文件。scp使用ssh协议进行数据传递,其认证方式和安全性同ssh一致。
二、ssh客户端的安装
在使用过程中如果出现提示“-bash: scp: command not found”表示系统还没有安装ssh客户端软件,需要执行yum install openssh-clients命令进行安装
三、scp命令的使用方法
1、scp命令的基本语法
scp [options] [[user@]host1:]file1 … [[user@]host2:]file2
2、scp命令的常用参数
-1 强制scp命令使用协议ssh1
-2 强制scp命令使用协议ssh2
-4 强行使用 IPV4 地址。
-6 强行使用 IPV6 地址。
-B 使用批处理模式(传输过程中不询问传输口令或短语)
-C使用此参数时ssh协议打开压缩选项。
-P 指定远程主机的端口。注意是大写字母“P”。
-r 以递归方式复制文件夹内的数据。在拷贝文件夹是要用到此选项。
-p 保留原文件的修改时间,访问时间和访问权限。
-q 不显示传输进度条。
-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)中的参数传递方式,
-S program 指定加密传输时所使用的程序。此程序必须能够理解ssh(1)的选项。
四、scp命令的使用示例
1、从本地主机复制文件(夹)到远程主机
命令格式为(-r参数用于递归复制文件夹):
scp (–r) local_file remote_username@remote_ip:remote_folder
示例1:
[root@centos ~]#scp /tmp/temp.txt [email protected]:/tmp/temp.txt
说明:将本地主机文件/tmp/temp.txt复制到远程主机192.168.1.2上的/tmp文件夹中(远程主机用户为root)
示例2:
[root@centos ~]#scp –r /tmp [email protected]:/tmp
说明:将本地主机文件夹/tmp中的所有文件以递归方式拷贝到远程主机192.168.1.2上的/tmp文件夹中(远程主机用户为root)
2、从远程主机复制文件(夹)到本地主机
scp (–r) remote_username@remote_ip:remote_folder local_file
3、在两台远程主机之间复制文件(夹)
scp(–r) remote_username@remote_ip:remote_folder
五、使用过程中可能碰到的问题及解决方法
1、用户文件权限引起的“许可拒绝”问题
示例:
username1 是本地机 username2 是远程
# scp /home/files [email protected]:/home/files2 [email protected]‘s password:
scp: /home/files2: Permission denied
说明:这是因为远程主机的用户username2没有/home/files2文件的写权限。可以使用以下解决办法:
本地服务器上执行:
#scp /home/files [email protected]:/tmp
然后远程服务器上执行:
#mv /tmp/files /home/files
或者可以在远程主机上配置/home文件夹增加用户username2的写权限。
2、ssh协议中用户权限配置引起的“许可拒绝”问题
示例:
#scp /www/xinpindao [email protected]:/tmp 远程机用户root
[email protected]‘s password:
Permission denied, please try again.
说明:这是由于ssh服务关闭root用户的登录权限引起。可以使用以下解决方法:
要修改root的ssh权限,即修改 /etc/ssh/sshd_config文件中PermitRootLogin no 改为 PermitRootLogin yes,然后重启ssh服务即可
#/etc/init.d/sshd restart
转载地址:http://myblog.jyc.edu.cn/?p=151
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。