通过scp批量上传文件,也可以批量在服务器上执行上传文件

下面是编程之家 jb51.cc 通过网络收集整理的代码片段。

编程之家小编现在分享给大家,也给大家做个参考。

#!/bin/bash
#Author: 		Castle Liu
#Description:	upload a file or excute a script on remote servers
#Usage:			excute_cmd.sh -l {hosts_list} -f {script_file} -d /tmp

####functions###
#help
#function used to print help info.
help() {
	cat <<EOF
	-l 	preferred,the list file of hosts,1st host,2nd user name,and,optional,3st password for the user.
	-f 	preferred,the file to upload.
	-d 	preferred,directory to place the file uploaded.
	-p 	optional,remote sshd listen port,if not provided,use 22 as default.
	-L 	optional,log file path to save excute log,use "excute_cmd.log" as default.
	-S 	optional,selected if chosed to use sudo
	-e 	optional,if selected,will excute the script file 
	-h 	print help info.
EOF
}
#help

#parse_args
#function to parse paremeters.
#do pass in the args from shell,for example:parse_args $*
parse_args(){
	while getopts "hl:f:d:p:L:Se" arg
	do 
		case ${arg} in
			h)
				help
				exit 0
				;;
			l)
				export _HOST_F=${OPTARG}
				;;
			f)
				export _SCRIPT_F=${OPTARG}
				;;
			d)
				export _DIR_R=${OPTARG}
				;;
			p)
				export _PORT_R=${OPTARG}
				;;
			L)
				export _LOG_F=${OPTARG}
				;;
			S)
				export _USE_SUDO=true
				;;
			e)
				export _EXC_F=true
				;;
			?)
				echo "Unknown argument,exit..."
				exit 1
				;;
			esac
	done
	#echo ${_HOST_F},${_SCRIPT_F}
}
#parse_args $*

#scp_file
#function to scp a file to a remote server.
#$1,Remote host ip addresss
#$2,Remote user name
#$3,Remote user password
#$4,The file to be copied local
#$5,Remote loacation of the script to be copied,can be a directory ora absulote file name 
#$6,The remote sshd port in use 
scp_file() {
	_host_r=$1
	_user_r=$2
	_passwd_r=$3
	_script_l=$4
	_script_r=$5
	_port_r=$6
	sed -i "/${_host_r}/d" ~/.ssh/known_hosts
expect  <<  EXPECT_EOF >> .runninglog
	spawn scp -P ${_port_r} ${_script_l} ${_user_r}@${_host_r}:${_script_r}
		expect "continue connecting (yes/no)?" {send "yes\n"}
 		expect  "password:" {send "${_passwd_r}\n"}
	expect off
EXPECT_EOF
}

#excute_script_with_sudo
#function to excute a script on remote server and scp back the running log,sudo will be used.
#$1,The script to be excuted in remote server,must be a absulote file name
#$5,The remote sshd port in use
excute_script_with_sudo () {
	_host_r=$1
	_user_r=$2
	_passwd_r=$3
	_script_r=$4
	_port_r=$5
	_log_r=`dirname ${_script_r}`"/.tmpexc.log"
expect  <<  EXPECT_EOF >> .runninglog
	spawn ssh  -p ${_port_r} ${_user_r}@${_host_r} -C \""sudo su - -c \"bash ${_script_r} > ${_log_r}\""\"
 		expect  "password:" {send "${_passwd_r}\n"}
 		expect  "*password*" {send "${_passwd_r}\n"}
	expect off
	spawn ssh -p ${_port_r} ${_user_r}@${_host_r} -C \""sudo su - -c \"chown ${_user_r} ${_log_r}\""\"
 		expect  "password:" {send "${_passwd_r}\n"}
 		expect  "*password*" {send "${_passwd_r}\n"}
 	expect off
	spawn scp -P ${_port_r} ${_user_r}@${_host_r}:${_log_r} ./${_host_r}.log.tmp
 		expect  "password:" {send "${_passwd_r}\n"}
	expect off
	spawn ssh -p ${_port_r} ${_user_r}@${_host_r} -C "rm -rf ${_log_r};rm -rf ${_script_r}"
		expect  "password:" {send "${_passwd_r}\n"}
	expect off
EXPECT_EOF
}

#excute_script
#function to excute a script on remote server and scp back the running log,The remote sshd port in use
excute_script () {
	_host_r=$1
	_user_r=$2
	_passwd_r=$3
	_script_r=$4
	_port_r=$5
	_log_r=`dirname ${_script_r}`"/.tmpexc.log"
expect  <<  EXPECT_EOF  >> .runninglog
	spawn ssh  -p ${_port_r} ${_user_r}@${_host_r} -C "bash ${_script_r} > ${_log_r}"
 		expect  "password:" {send "${_passwd_r}\n"}
	expect off
	spawn scp -P ${_port_r} ${_user_r}@${_host_r}:${_log_r} ./${_host_r}.log.tmp
 		expect  "password:" {send "${_passwd_r}\n"}
	expect off
	spawn ssh -p ${_port_r} ${_user_r}@${_host_r} -C "rm -rf ${_log_r};rm -rf ${_script_r}"
		expect  "password:" {send "${_passwd_r}\n"}
	expect off
EXPECT_EOF
}

#handle_excute_log
#function to uniq the log file excute remotely and scp back.
#$1,the final log file to be make
#$2,the host list file,using awk -F [,],so the file must be seperated by ',',and the field 1 will be used.
handle_excute_log() {
	_log_l=$1
	_host_l=$2
	echo "###Handling  Log###"
	if [[ -f ${_log_l} ]];then
		echo "log file exist,will be move as .bak..."
		mv ${_log_l} ${_log_l}.bak
	fi
	cat ${_host_l}|awk -F [,] '{print $1}'|while read _host
	do
		if [[ "${host}" != "EOF" ]];then
			_tmp_l=${_host}.log.tmp
			echo "###################"  >> ${_log_l}
			echo "###${_host} excute log begin...." >> ${_log_l}
			cat ${_tmp_l}  >> ${_log_l}
			echo "###${_host}'s excute log ended." >> ${_log_l}
			echo "###################"  >> ${_log_l}
			echo "" >> ${_log_l}
			rm -rf ${_tmp_l}
		fi 
	done
}
#excute_script 192.168.56.5 shell shell /home/shell/test.sh
#handle_excute_log

##$$main$$##
#parsing the args
parse_args $*
export _LOG_F=${_LOG_F:-'excute_cmd.log'}
export _PORT_R=${_PORT_R:-'22'}
#check the required file valid or not
if [[ ! -f ${_HOST_F} ]];then
	echo 'The host_list file not valid,please retry!!!'
	exit 1
fi
if [[ ! -f ${_SCRIPT_F} ]];then
	echo 'The script file not valid,please retry!!!'
	exit 1
fi
#read in password
read -t 20 -s -p "Enter password for ${_HOST},just [enter] if provided by file:" _PASSWD

#excute script file one by one according to _HOST_F
cat ${_HOST_F}|while read _LINE
	do
		if [[ ${_LINE} != "EOF" ]];then
			_HOST=`echo ${_LINE}|awk -F [,] '{print $1}'`
			_USER=`echo ${_LINE}|awk -F [,] '{print $2}'`
			#check if password is provided.
			if [[ "${_PASSWD}"x == ""x  ]];then
				_PASSWD=`echo ${_LINE}|awk -F [,] '{print $3}'`
				if [[ "${_PASSWD}"x == ""x  ]];then
					echo ""
					echo "Password needed,please retry."
					exit 1
				fi
			fi

			echo "Handling ${_HOST}......"
			#upload file to remote server.
			scp_file ${_HOST} ${_USER} ${_PASSWD} ${_SCRIPT_F} ${_DIR_R} ${_PORT_R}
			
			#excute the script if "-e" is selected.
			if [[ ${_EXC_F} ]];then
				echo "${_SCRIPT_F} will be excuted on ${_HOST}."
				_NAME_F=`basename ${_SCRIPT_F}`
				_SCRIPT_R="${_DIR_R}/${_NAME_F}"
				#use excute_script_with_sudo if "-S" is selected
				if [[ ${_USE_SUDO} ]];then
					echo "Script will be excuted with sudo."
					excute_script_with_sudo ${_HOST} ${_USER} ${_PASSWD} ${_SCRIPT_R} ${_PORT_R}
				else
					excute_script ${_HOST} ${_USER} ${_PASSWD} ${_SCRIPT_R} ${_PORT_R}
				fi
			fi
			echo "${_HOST} done."
		fi
	done

#collect the log file 
if [[ ${_EXC_F} ]];then
	handle_excute_log ${_LOG_F} ${_HOST_F}
fi

以上是编程之家(jb51.cc)为你收集整理的全部代码内容,希望文章能够帮你解决所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


系ubuntu 下面打开终端输入:sudo apt-get install sendmail一般就安装完成噶啦跟住进入 /etc/mail/目录输入:m4 sendmail.mc &gt; sendmail.cf意思系跟住.mc文件 生成 sendmial.cf文件输入呢个命令:ps aux | g
依家我有1个软件goagent目录(大家懂得) 放在/home/gateman/Programs/ 下 1. proxy.py 入面有1个 proxy.py 文件 放在/home/gateman/Programs/goagent/local/ 入面 2.breakwall.sh 我在 proxy.p
其实我想讲的是 cp -L关于-L参数的解释:-L, --dereference always follow symbolic links in SOURCE意思是如果复制目标是1个软链接,则复制链接的目标 不是链接本身做个例子: 例如 ~/tmp/fo1 入面有1个c.txt 文件 和 指向他的软
原地址:http://www.rjgc.net/control/content/content.php?nid=4418 1、将文件checkout到本地目录svn checkout path(path是服务器上的目录)例如:svn checkout svn://192.168.1.1/pro/do
chroot,即 change root directory (更改 root 目录)。在 linux 系统中,系统默认的目录结构都是以 `/`,即是以根 (root) 开始的。而在使用 chroot 之后,系统的目录结构将以指定的位置作为 `/` 位置。实例:用live CD ubuntu假设你的
简单解析下, stdin就是标准输入, stdout就是标准。举个例子, 在当前我要打包1个文件夹 /var/log/ 到当前目录下,并用zip压缩,那么我们可以分步执行#tar -cvf log.tar /var/log/#zip -r log.tar.zip log.tar#rm -rf log
转自:http://man.ddvip.com/linux/Mandrakelinuxref/process-priority.html系统中运行的每个进程都有一个优先级(亦称“nice 值”),其范围从 -20 (最高优先级)到 19 (最低优先级)。默认情况下,进程的优先级是 0 (“基本”调度
str=&quot;/home/gateman&quot; if [ ${str:0:1} = &quot;/&quot; ]; then echo &quot;yes&#39;fi ${str:0:1} 中0表示从第几个字符开始,1表示截取多长
转自:http://kwokchivu.blog.51cto.com/1128937/694347 在RedHat系统下用usermod 命令可把某用户添加进多个附属组,默认情况下,一次性添加多个附属组可用以下方式来添加: usermod -G 附属组1,附属组2,...,附属组X 用户名 但在添加
有个文件 test.txt 内容如下:bash-3.00$ cat test.txt user user user_hiuser #注:呢行系空行T JGATEMANGATTTTTEMANGABBEMANAAABbash-3.00$下面介绍下常用的通配符 配合grep 命令:1. &quot;.&q
linux系统为每1个文件都分配有i索引节点(inode),系统根据呢d节点从磁盘找出数据。 一般来讲,每1个文件名(包含全路径)实际上都链接住1个i索引节点。inode实际上系乜咧? 其实可以算系1个指向磁盘具体位置(柱面,扇区之类)的指针, 系统分析某个文件的inode,得出磁盘柱面,扇区等数据
grep 可以立即为筛选, 一般的用法系 grep + 要查询的字段 + 文件(或者内容 例如| 传递既内容)1.grep + 要查询的字段 + 文件gateman@GPC:~/shell/SQL_GSI$ grep OID a.sqlWHERE OID=@BuildNOWHERE OID INWH
原文转自:http://www.ibm.com/developerworks/cn/linux/l-cn-vimcolumn/index.html开始之前人类大脑对文字的处理是平面式的,所以我们浏览文章、查找资料或者重构代码,要么是横向读,要么是纵向读,要么使用搜索功能,将文字作为一个平面整体。而在
PS:偶很喜欢用scp这个命令来传输数据。scp命令跟cp命令类似,只不过cp命令是在同一台机器上用的,scp是在两台机器上复制传输数据的命令。scp实质相当于利用SSH协议来传输数据的cp命令。 用法举例: 1、复制远程服务器的文件到本地: scp -P888 root@120.18.50.33:
打开终端,进入/bin/ls 一下会见到 bash sh 呢两个文件。其实距地系两个唔同既shell 解析器。如果在脚本a.sh 开头写入#!/bin/sh那么执行./a.sh 时候 就相当于 sh a.sh同理 开头写入#!/bin/bash执行./a.sh 时候 就相当于 bash a.sh如果
find查找文件的时候排除某个或几个文件或目录转自:http://www.cnblogs.com/starspace/archive/2008/10/20/1315380.html比如要在/usr/sam目录下查找不在dir1子目录之内的所有文件find /usr/sam -path &quot;/
假设有变量 var=http://www.google.com/test.htm一 # 号截取,删除左边字符,保留右边字符。echo ${var#*//}其中 var 是变量名,# 号是运算符,*// 表示从左边开始删除第一个 // 号及左边的所有字符即删除 http://结果是 :www.goog
转自: http://edyfox.codecarver.org/html/_vimrc_for_beginners.htmlVIM 中可供用户定制的选项非常非常多,作为初学者,我们没有必要了解这么多东西。下面,滇狐简单列出了一些最常用的配置项,大家可以根据自己的需要将这些内容添加到自己的 .vim
转自:http://www.einit.com/user1/11/archives/2006/3603.htmlUnix/Linux下一般想让某个程序在后台运行,很多都是使用 &amp; 在程序结尾来让程序自动运行。比如我们要运行mysql在后台: /usr/local/mysql/bin/mysq
首先, mount是类unix系统, 挂载设备到1个文件夹的操作命令, 注意系设备阿正常来讲,mount 是不能挂在文件夹到文件夹的。例如, 在我的~/tmp/ 目录中有两个文件夹fo1 fo2其中fo1 中有3个文件a.txt b.txt c.txt fo2 有4个 e.txt d.txt e.t