linux之间文件传输(转) linux的scp命令mysql
linux 的 scp 命令 能够 在 linux 之间复制 文件 和 目录;linux
scp 命令sql
scp 能够在 2个 linux 主机间复制文件;shell
命令基本格式:安全
scp [可选参数] file_source file_target
从 本地 复制到 远程bash
复制文件: * 命令格式: scp local_file remote_username@remote_ip:remote_folder 或者 scp local_file remote_username@remote_ip:remote_file 或者 scp local_file remote_ip:remote_folder 或者 scp local_file remote_ip:remote_fileoracle
第1,2个指定了用户名,命令执行后须要再输入密码,第1个仅指定了远程的目录,文件名字不变,第2个指定了文件名; 第3,4个没有指定用户名,命令执行后须要输入用户名和密码,第3个仅指定了远程的目录,文件名字不变,第4个指定了文件名; * 例子: scp /home/space/music/1.mp3 root@www.cumt.edu.cn:/home/root/others/music scp /home/space/music/1.mp3 root@www.cumt.edu.cn:/home/root/others/music/001.mp3 scp /home/space/music/1.mp3 www.cumt.edu.cn:/home/root/others/music scp /home/space/music/1.mp3 www.cumt.edu.cn:/home/root/others/music/001.mp3
*** 复制目录:**app
* 命令格式: scp -r local_folder remote_username@remote_ip:remote_folder 或者 scp -r local_folder remote_ip:remote_folder 第1个指定了用户名,命令执行后须要再输入密码; 第2个没有指定用户名,命令执行后须要输入用户名和密码; * 例子: scp -r /home/space/music/ root@www.cumt.edu.cn:/home/root/others/ scp -r /home/space/music/ www.cumt.edu.cn:/home/root/others/ 上面 命令 将 本地 music 目录 复制 到 远程 others 目录下,即复制后有 远程 有 ../others/music/ 目录
脚本执行效果: (1).远程传输本地 /ora_exp/dmp/CWDB_RAMS_* 文件至 11.4.24.21 的 /ora_exp/dmp 目录下。运维
脚本编写步骤: 假设 oracle 用户于 11.4.24.21 上的密码为 123abc,传输本地 /ora_exp/dmp/CWDB_RAMS_* 文件至 11.4.24.21 的 /ora_exp/dmp 目录下。 则传输脚本相似以下。ssh
#!/bin/sh expect -c " spawn bash -c \"scp /ora_exp/dmp/CWDB_RAMS_* oracle@11.4.24.21:/ora_exp/dmp\" expect { \"yes/no\" {send \"yes\r\"; exp_continue;} \"*assword\" {set timeout 300; send \"123abc\r\";} } expect eof"
注意: yes/no 判断后必须加入 exp_continue,这样才能保证 yes/no 判断后还能执行 *assword 的判断。
注意:scp 传输文件中常常使用了通配符,而若是直接使用 spawn 传递带通配符的命令 scp /ora_exp/dmp/CWDB_RAMS_* oracle@11.4.24.21:/ora_exp/dmp\ 将没法执行。所以,需在 spawn 内套用 bash -c 调用带通配符的命令。
sample
#!/bin/bash a=$1 b=$2 ip=$3 port=$4 passwd=$5 /bin/rpm -qa|/bin/grep -q expect if [ $? -ne 0 ];then echo "please install expect" exit fi if [ $# -ne 5 ];then echo "must 5 parameter,1:source file,2:object file,3:object ip 4:object port,5:passwd" exit fi expect -c " spawn scp -P $port $a root@$ip:$b expect { \"*assword\" {set timeout 300; send \"$passwd\r\";} \"yes/no\" {send \"yes\r\"; exp_continue;} } expect eof"
scp是一个基于ssh的Linux环境下传输文件的好工具,可是使用shell脚本调用scp时会面临一个问题,即scp强制要求经过交互方式输入密码,而不像mysql等拥有-u -p选项。下面有两种方法帮助shell脚本跨过输入密码这个障碍。
1.创建机器间彻底信任关系 假设须要从机器A传输文件至机器B 1)在机器A上运行
ssh-keygen -t rsa 上述命令会在~/.ssh/目录生成私钥证书id_rsa和公钥证书id_rsa.pub; 2)将公钥证书id_rsa.pub复制到机器B的用户根目录的.ssh子目录中,再将文件内容append到文件authorized_keys中。
其实只要用一条单行命令就能够完成步骤2,它被commandlinefu.com的用户投票选为十大最酷的Linux单行命令之一:
ssh-copy-id [-i [identity_file]] [user@]machine
identity_file是公钥证书的路径,默认状况下是~/.ssh/id_rsa.pub.
若是要创建双方向的彻底信任关系,还要从机器B到机器A再重复一遍上面的操做。 不过这样的方法并不完美,一是运维成本过高,二是机器间的安全屏障彻底消失,安全代价太大,因此本人强烈推荐第二种方法。
2.expect脚本 expect脚本是一种创建在tcl基础上的脚本语言,曝光率不高,却堪称shell脚本的好基友。expect脚本为交互而生,被设计为专门针对交互式程序的工具,常与对telnet、ftp、fsck、rlogin、tip、scp等配合使用。例如:
#!/usr/bin/expect spawn scp -P 22 20111111.log root@192.168.0.1:/log/expect { "*assword" {set timeout 300; send "passwd\r";} "yes/no" {send "yes\r"; exp_continue;} } expect eof
上面是一个独立的expect脚本文件,若是像把这段脚本嵌入其它shell脚本中就要用到expect -c
#!/bin/bashexpect -c " spawn scp -P 22 20111111.log root@192.168.0.1:/log/ expect { \"*assword\" {set timeout 300; send \"passwd\r\";} \"yes/no\" {send \"yes\r\"; exp_continue;} }
expect eof"这段脚本的含义是监听scp命令,若是输入包含*assword,则输入密码“passwd”;若是输入包含yes/no,输入yes并继续进行交互(exp_continue)。 注:两个用户第一次scp链接时会提示“… Are you sure you want to continue connecting (yes/no)? …”,因此要考虑yes/no的状况。