linux 两台服务器文件拷贝

copy file:

scp file [email protected]:/tmp

or

scp [email protected]:/tmp/file .

copy folder

scp -r folder [email protected]:/tmp/folder

SSH 应用

1. 配置traffic和web主机之间ssh工具可以直接登陆
    
       1.1 编辑traffic的hosts文件增加web主机条目
       
           ......
           203.81.*.*            web1
           203.81.*.*            web2
           203.81.*.*            web3
       1.2 生成ssh客户密匙

           #ssh-keygen -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:
           d1:69:34:80:56:2a:2d:df:70:2d:10:ac:63:5e:1e:1c root@web
          
        1.3 生成后,将本地的id_rsa.pub复制到远程的./ssh目录下,更改名称为authorized_keys2

            sftp root@web1
            sftp web1
            Connecting to web1
            root@web1's password: (输入密码)
            sftp> 
            sftp>cd .ssh
            sftp>put id_rsa.pub  authorized_keys2
            Uploading id_rsa.pub to /.ssh/authorized_keys2
            
        1.4 测试是否成功
        
            scp web1:/usr/local/apache2/logs/hoho /root/    复制远程的hoho文件到本地的/root/.ssh目录下,无需输入密码
            hoho        100%   40KB  40.2KB/s   00:00 (屏显状态值,显示已传输完毕,文件可正常使用)
        1.5 补遗或者注解
        
            a. 第一次登陆web1,ssh会提示将web1加入自己know_hosts里面。
            b. 直接登陆验证是区别用户的,authorized_keys2文件是分用户的。

 

scp 命令是 SSH 中最方便有用的命令了,试想,在两台服务器之间直接传送文件,仅仅用 scp 一个命令就完全解决了。 你可以在一台服务器上 以 root 身份运行 #scp servername:/home/ftp/pub/file1 . 这样就把另一台服务器上的文件 /home/ftp/pub/file1 直接传到本机器的当前目录下,当然你也可以用 #scp /tmp/file2 servername:/boot 把本机上的文件 /tmp/file2 送到另一台机器的 /boot 目录下。而且整个传送过程仍然是用 SSH 加密的。 
  

scp 就是 secure copy, 是用来进行远程文件拷贝的 . 数据传输使用 ssh1, 并且和 ssh1 使用相同的认证方式 , 提供相同的安全保证 . 与 rcp 不同的是 ,scp 会要求你输入密码如果需要的话 . 

最简单的应用如下 : 

scp 本地用户名 @IP 地址 : 文件名 1 远程用户名 @IP 地址 : 文件名 2 

[ 本地用户名 @IP 地址 :] 可以不输入 , 可能需要输入远程用户名所对应的密码 . 

可能有用的几个参数 : 

-v 和大多数 linux 命令中的 -v 意思一样 , 用来显示进度 . 可以用来查看连接 , 认证 , 或是配置错误 . 

-C 使能压缩选项 . 

-P 选择端口 . 注意 -p 已经被 rcp 使用 . 

-4 强行使用 IPV4 地址 . 

-6 强行使用 IPV6 地址 . 


-r Recursively copy entire directories. 


如—— 

copy 本地的档案到远程的机器上 

scp /etc/lilo.conf [email protected]:/home/my 

会将本地的 /etc/lilo.conf 这个档案 copy 到 www.upsdn.net,使用者my 的家目录下。 
===================================================== 

copy远程机器上的档案到本地来 

scp [email protected]:/etc/lilo.conf /etc 

会将 http://www.upsdn.net 中 /etc/lilo.conf 档案 copy 到本地的 /etc 目录下。

你可能感兴趣的:(linux)