使用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命令的使用方法

1scp命令的基本语法

scp [options] [[user@]host1:]file1 … [[user@]host2:]file2

2scp命令的常用参数

-1 强制scp命令使用协议ssh1

-2 强制scp命令使用协议ssh2

-4 强行使用 IPV4 地址。

-6 强行使用 IPV6 地址。

-B 使用批处理模式(传输过程中不询问传输口令或短语)

-C使用此参数时ssh协议打开压缩选项。

-P 指定远程主机的端口。注意是大写字母“P”。

-r 以递归方式复制文件夹内的数据。在拷贝文件夹是要用到此选项。

-p 保留原文件的修改时间,访问时间和访问权限。

-q 不显示传输进度条。

-v 详细方式显示输出。scpssh(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的写权限。

2ssh协议中用户权限配置引起的“许可拒绝”问题

示例:

#scp /www/xinpindao [email protected]:/tmp    远程机用户root

[email protected]‘s password:

Permission denied, please try again.

说明:这是由于ssh服务关闭root用户的登录权限引起。可以使用以下解决方法:

要修改rootssh权限,即修改 /etc/ssh/sshd_config文件中PermitRootLogin no 改为 PermitRootLogin yes,然后重启ssh服务即可

#/etc/init.d/sshd   restart

转载地址:http://myblog.jyc.edu.cn/?p=151

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。