我的unix系统上的目录中有n个文件。有没有一种方法可以编写Shellscript,该脚本将通过scp将所有这些文件传输到指定的远程系统。我将在脚本中指定密码,这样就不必为每个文件输入密码。
我的unix系统上的目录中有n个文件。有没有一种方法可以编写Shellscript,该脚本将通过scp将所有这些文件传输到指定的远程系统。我将在脚本中指定密码,这样就不必为每个文件输入密码。
Answers:
不用在shell脚本中对密码进行硬编码,而是使用SSH密钥,它更容易且安全。
$ scp -i ~/.ssh/id_rsa *.derp devops@myserver.org:/path/to/target/directory/
假设您的私钥位于,~/.ssh/id_rsa
并且您要发送的文件可以使用*.derp
生成公钥/私钥对:
$ ssh-keygen -t rsa
上面将生成2个文件,~/.ssh/id_rsa
(私钥)和~/.ssh/id_rsa.pub
(公钥)
设置SSH密钥以使用(一次任务):复制的内容~/.ssh/id_rsa.pub
并粘贴到in的新行~devops/.ssh/authorized_keys
中myserver.org
。如果~devops/.ssh/authorized_keys
不存在,请随时创建它。
#!/usr/bin/expect -f
# connect via scp
spawn scp "user@example.com:/home/santhosh/file.dmp" /u01/dumps/file.dmp
#######################
expect {
-re ".*es.*o.*" {
exp_send "yes\r"
exp_continue
}
-re ".*sword.*" {
exp_send "PASSWORD\r"
}
}
interact
http://blogs.oracle.com/SanthoshK/entry/automate_linux_scp_command
expect
MSYS2中打包的内容将与整个输出匹配,因此第一个规则将始终匹配。如果交换两个规则的顺序,则将获得所需的行为。
你为什么不试试这个呢?
password="your password"
username="username"
Ip="<IP>"
sshpass -p "$password" scp /<PATH>/final.txt $username@$Ip:/root/<PATH>
您也可以使用rsync。对于多个文件,它似乎比scp IMHO更好。
rsync -avzh / path / to / dir / user @ remote:/ path / to / remote / dir /
更新资料
您可以通过添加'-e'开关通过ssh使用rsync:
rsync -avzh -e ssh / path / do / dir / user @ remote:/ path / to / remote / dir /
#!/usr/bin/expect -f
spawn scp -r BASE.zip abhishek@192.168.1.115:/tmp
expect "password:"
send "wifinetworks\r"
expect "*\r"
expect "\r"
那通配符或多个文件呢?
scp file1 file2 more-files* user@remote:/some/dir/
rsync是一个程序,其行为与rcp几乎相同,但是具有更多选项,并且在更新目标文件时使用rsync远程更新协议可以大大加快文件传输速度。
rsync远程更新协议允许rsync使用此软件包随附的技术报告中所述的高效校验和搜索算法,通过网络连接仅传输两组文件之间的差异。
#!/usr/bin/expect -f
spawn rsync -a -e ssh username@192.168.1.123:/cool/cool1/* /tmp/cool/
expect "password:"
send "cool\r"
expect "*\r"
expect "\r"
如果可以在每次运行脚本时都输入一次密码,则可以使用SSH主连接轻松进行。
#!/usr/bin/env bash
USER_AT_HOST="user@host" # use "$1@$2" here if you like
SSHSOCKET=~/".ssh/$USER_AT_HOST"
# This is the only time you have to enter the password:
# Open master connection:
ssh -M -f -N -o ControlPath="$SSHSOCKET" "$USER_AT_HOST"
# These do not prompt for your password:
scp -o ControlPath="$SSHSOCKET" file1.xy "$USER_AT_HOST":remotefile1.xy
scp -o ControlPath="$SSHSOCKET" file2.xy "$USER_AT_HOST":remotefile2.xy
# You can also use the flag for normal ssh:
ssh -o ControlPath="$SSHSOCKET" "$USER_AT_HOST" "echo hello"
ssh -o ControlPath="$SSHSOCKET" "$USER_AT_HOST" "echo world"
# Close master connection:
ssh -S "$SSHSOCKET" -O exit "$USER_AT_HOST"
您只能使用ssh公钥/私钥来做到这一点。或者使用可以在其中设置密码的腻子。scp不支持在命令行中提供密码。
您可以在此处找到有关公钥/私钥的说明:http : //www.softpanorama.org/Net/Application_layer/SSH/scp.shtml
这将起作用:
#!/usr/bin/expect -f
spawn scp -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no file1 file2 file3 user@host:/path/
expect "password:"
send "xyz123\r"
expect "*\r"
expect "\r"
interact
这是带有.pem密钥文件的SCP的bash代码。只需将其保存到script.sh文件,然后使用“ sh script.sh”运行
请享用
#!/bin/bash
#Error function
function die(){
echo "$1"
exit 1
}
Host=ec2-53-298-45-63.us-west-1.compute.amazonaws.com
User=ubuntu
#Directory at sent destination
SendDirectory=scp
#File to send at host
FileName=filetosend.txt
#Key file
Key=MyKeyFile.pem
echo "Aperture in Process...";
#The code that will send your file scp
scp -i $Key $FileName $User@$Host:$SendDirectory || \
die "@@@@@@@Houston we have problem"
echo "########Aperture Complete#########";
该命令scp
可以像传统的UNIX一样使用cp
。所以,如果你这样做:
scp -r myDirectory/ mylogin@host:TargetDirectory
将工作