zoukankan      html  css  js  c++  java
  • scp 详细总结

    转自:http://www.ha97.com/4169.html

    scp命令跟cp命令类似,只不过cp命令是在同一台机器上用的,scp是在两台机器上复制传输数据的命令。scp实质相当于利用SSH协议来传输数据的cp命令。

    用法举例:

    1、复制远程服务器的文件到本地:
    scp -P888 root@120.18.50.33:/data/ha97.zip /home/
    2、复制远程服务器的目录到本地:
    scp -vrp -P888 root@120.18.50.33:/data/ha97/ /home/
    3、复制本地的文件到远程服务器:
    scp -P888 /home/ha97.zip root@120.18.50.33:/data/
    4、复制本地的目录到远程服务器:
    scp -vrp -P888 /home/ root@120.18.50.33:/data/

    SCP 命令语法
    scp [-1245BCpqrv] [-c cipher] [F ssh_config] [-I identity_file] [-l limit] [-o ssh_option] [-P port] [-S program] [[user@]host1:] file1 […] [[suer@]host2:]file2

    SCP 命令说明
    Scp在主机间复制文件。他使用 ssh(1)作为数据传输。而且用同样认证和安全性。 scp将在认证中请求输入密码所有的文件可能需要服务器和用户的特别描述来指明文件将被复制到/从某台服务器。两个远程登录的服务器间的文件复制是允许的。

    SCP 命令选项
    -1 强制scp 用协议1
    -2 强制scp 用协议2
    -4 强制scp用IPV4的网址
    -6 强制scp用IPV6的网址
    -B 选择批处理模式(防止输入密码)
    -C 允许压缩。 标注-C到ssh(1)来允许压缩
    -c cipher
    选择cipher来加密数据传输。这个选项直接传递到ssh(1)
    -F ssh_config
    设定一个可变动的用户配置给ssh.这个选项直接会被传递到ssh(1)
    -i identity_file
    选择被RSA认证读取私有密码的文件。这个选项可以直接被传递到ssh(1)
    -l limit
    限制传输带宽,也就是速度 用Kbit/s的速度
    -o ssh_option
    可以把ssh_config中的配置格式传到ssh中。这种模式对于说明没有独立的scp文件中断符的scp很有帮助。关于选项的如下。而他们的值请参看ssh_config(5)
    -P port
    指定连接远程连接端口。注意这个选项需要写成大写的模式。因为-p已经早保留了次数和模式
    -S program
    指定一个加密程序。这个程序必须可读所有ssh(1)的选项。
    -p 指定修改次数,连接次数,还有对于原文件的模式
    -q 把进度参数关掉
    -r 递归的复制整个文件夹
    -S program
    指定一个加密程序。这个程序必须可读所有ssh(1)的选项。
    -V 冗余模式。 让 scp 和 ssh(1) 打印他们的排错信息, 这个在排错连接,认证,和配置中非常有用。

    SCP 命令诊断
    scp 返回0 成功时,不成功时返回值大于0

    SCP 命令不需要输入用户密码的使用方法

    在两台机器的两个用户之间建立安全的信任关系后,可实现执行scp命令时不需要输入用户密码。

    1. 在机器A上root用户执行 ssh-keygen 命令,生成建立安全信任关系的证书。

    [root@A root]# ssh-keygen -b 1024 -t rsa
    Generating public/private rsa key pair.
    Enter file in which to save the key (/root/.ssh/id_rsa): <– 直接输入回车
    Enter passphrase (empty for no passphrase): <– 直接输入回车
    Enter same passphrase again: <– 直接输入回车
    Your identification has been saved in /root/.ssh/id_rsa.
    Your public key has been saved in /root/.ssh/id_rsa.pub.
    The key fingerprint is: ……


    注意:在程序提示输入 passphrase 时直接输入回车,表示无证书密码。
    上述命令将生成私钥证书 id_rsa 和公钥证书 id_rsa.pub,存放在用户目录的 .ssh 子目录中。

    2. 将公钥证书 id_rsa.pub 复制到机器B的root目录的.ssh子目录中,同时将文件名更换为authorized_keys

    [root@A root]# scp -p .ssh/id_rsa.pub root@机器B的IP:/root/.ssh/authorized_keys
    root@192.168.3.206’s password: <– 输入机器B的root用户密码


    在执行上述命令时,两台机器的root用户之间还未建立安全信任关系,所以还需要输入机器B的root用户密码。
    经过以上2步,就在机器A的root和机器B的root之间建立安全信任关系。下面我们看看效果:

    [root@A root]# scp -p test root@机器B的IP地址:/root

    成功了!真的不再需要输入密码了。

  • 相关阅读:
    ZOJ 1002 Fire Net (火力网)
    UVa OJ 117 The Postal Worker Rings Once (让邮差只走一圈)
    UVa OJ 118 Mutant Flatworld Explorers (变体扁平世界探索器)
    UVa OJ 103 Stacking Boxes (嵌套盒子)
    UVa OJ 110 MetaLoopless Sorts (无循环元排序)
    第一次遇到使用NSNull的场景
    NSURL使用浅析
    从CNTV下载《小小智慧树》
    NSDictionary and NSMutableDictionary
    Category in static library
  • 原文地址:https://www.cnblogs.com/zmlctt/p/3700017.html
Copyright © 2011-2022 走看看