shell脚本登录sftp

sftp不能像ftp一样直接使用账号/密码登录(ftp ip地址; user 账户/密码),需要交互式输入登录密码。在shell中可以使用expect 传入密码。

sftp $rad.put $BSF_USER@$BSF_IP
expect{
	"password:" {send  "$spwd\r"}
	"(yes/no)?" {send "yes\r";exp_continue}
}

也可以使用  ssh-keygen -t rsa 生成公私钥对,将公钥放到sftp服务器的.ssh目录继而免密登录。

但是如果shell脚本中有逻辑操作则会报错,用 <<也没用。这个时候可以使用 sftp -b(通过指定脚本,调用脚本命令,而不是在shell命令行输入命令),将命令写入文件,再执行。

BSF_IP="172.16.67.23"
BSF_USER="send"
BSF_PATH=/tw/sjzf/sichuan/data/${AC_DATE}/day

FILE_PATH=${ETL_DATA}/PROV_DATA/sichuan/day/${AC_DATE}

for loop in 1 2 3 4 5 6
do
rad=$RANDOM
#生成发送的.put文件
echo "get $BSF_PATH/i_10000_${AC_DATE}_SC000${loop}_00_001.dat $FILE_PATH" >> ${rad}.put
sftp -b $rad.put $BSF_USER@$BSF_IP
rm -f $rad.put
done
bye






你可能感兴趣的:(shell脚本登录sftp)