平時在處理一個或幾個機器運行環境時,一個機器一個機器處理也能接受,但是如果是一批機器,幾十或幾百臺,要是一臺一臺去安裝環境,光是輸入同一的命令,估計你自己都想吐,所有聰明的人會想一些偷懶的辦法,確實可以找到一些省時省力的方法,比如寫一個批量處理shell腳本,這幾天在處理一批(八九十臺)機器環境,找了一些批量處理的腳本,包括批量傳輸(scp)文件到多臺機器上、批量執行命令到多臺機器、還有需要交互的命令,下面記錄一些這些命令:
機器IP文件:ip.txt
192.168.10.201 192.168.10.202 192.168.10.203 192.168.10.204 192.168.10.205
另外所有機器要可以從一臺機器通過ssh無密登錄其他機器
1.批量傳輸(scp)文件到一批機器上
創建腳本文件,并修改為可執行文件
touch xscp.shchmod +x xscp.sh
腳本命令:
#!/bin/bashfor line in `cat $1`do if [ "$3" == "" ] then # dir echo scp -r $2/ $line:$2/ scp -r $2/ $line:$2/ else # files echo scp ${@:3} $line:$2/ scp ${@:3} $line:$2/ fidone
示例1:指定要傳輸的文件
./xscp.sh ip.txt /opt/soft/ filename1 filename2 ...
第一個參數($1):ip.txt 是一個以換行符分割的IP集合,每個IP占一行
第二個參數($2):/opt/soft/ 文件要傳輸到目標機器的目錄
第三個及以后n個參數(${@:3}):為要傳輸的文件或文件集合
示例2:不指定文件
./xscp.sh ip.txt /opt/soft/
如果不指定要傳輸的文件,會默認傳輸第二個參數($2)目錄(/opt/soft)下的所有文件,到目標機器對應的目錄(/opt/soft)下
2.批量執行命令腳本(無交互)
創建腳本文件,并修改為可執行文件
touch xcall.shchmod +x xcall.sh
腳本命令:
#!/bin/bashparams=${@:2}for line in `cat $1`do echo "============= {print %s, $line} $params =============" ssh $line "$params"done
示例1:
./xcall.sh ip.txt hostname
第一個參數($1):ip.txt 要通過ssh執行命令的機器ip集合
第二個及后續n個參數(${@:2}):視為要執行的整個命令,最好整個命令用雙引號引起,如下示例
示例2:
./xcall.sh ip.txt "rpm -qa | grep lzo"
3.批量執行命令腳本(有交互)
有些時候批量向其他機器執行腳本,需要交互,比如安裝軟件時,需要確認(輸入yes/no),需要輸入密碼等,如果人工輸入,上百臺機器估計夠費勁,所有在執行批量腳本時,讓其自動交互,顯得很實用,下面以expect來實現自動互動交互舉幾個小示例。
expect是一個自動交互功能的工具,可以滿足代替我們實際工作中需要從終端手動輸入某些內容來使得程序或命令繼續運行的目的。如安裝軟件是時的一些提示,ssh遠程主機執行命令時需要多次輸入密碼的情況。
首先在執行腳本的機器上要安裝expect軟件包
yum -y install expect
一些expect基本命令:
示例1:
創建腳本文件并修改為可執行文件:
touch xcall-keytool-list.shchmod +x xcall-keytool-list.sh
腳本命令:
#!/bin/bashparams=${@:2}for line in `cat $1`do echo "============ $line $params =============" /usr/bin/expect << EOF set time 20 spawn ssh $line "$params" expect { "*password:" { send "changeit/r" } } expect eofEOFdone
命令執行 在查詢java證書庫時需要輸入java證書庫密碼(changeit):
./xcall-keytool-list.sh ip.txt "/home/software/java/bin/keytool -list -keystore /home/software/java/jre/lib/security/cacerts | grep baidu"
第一個參數($1):ip.txt 要執行命令的機器IP集合文件
第二個及后面n個參數(${@:2}):為要執行的命令
示例2:更為通用的腳本命令
創建腳本文件并修改為可執行文件:
touch xcall-interaction.shchmod +x xcall-interaction.sh
腳本命令:
#!/bin/bash# IP文件iptxt=$1# 要執行的命令command=$2# 交互時輸入項(yes/no|password)initem=$3# 交互輸入內容(yes | 密碼)input=$4echo "--- command:$command ---"echo "--- 輸入項:$initem ---"echo "--- 輸入內容:$input ---"for line in `cat $iptxt`do echo "============ $line $command =============" if [ "$initem" = "" ] then ssh $line "$command" else /usr/bin/expect << EOF set time 20 spawn ssh $line "$command" expect { "*$initem:" { send "$input/r" } } expect eofEOF fidone
執行命令:
./xcall-interaction.sh ip.txt "/home/software/java/bin/keytool -list -keystore /home/software/java/jre/lib/security/cacerts | grep baidu" password changeit
第一個參數($1):ip.txt 要執行命令的機器IP集合文件
第二個參數($2):為要執行的命令,用雙引號
第三個參數($3):為輸入項,這里是password(輸入密碼),或者輸入yes/no等,如果沒有第三個參數,則當成非交互命令執行
第四個參數($4):為輸入項要輸入的內容,如輸入項是password時,此項輸入密碼;如果輸入項是yes/no時,一般輸入yes
知識點補充:下面看個shell腳本范例---批量復制
腳本目的:工程包的增量替換與升級,增量包放在src目錄下,目標包放在dest目錄下
#!/bin/bashfunction replace(){ for file in `ls $1` do for file1 in `ls $2` do if [ $file1 = $file ]; then cp -f $1"/"$file $2 echo ${file}+++${file1} flag="1" fi done if [ $flag != "1" ] then cp -f $1"/"$file $2 fi flag="0" done}src="/home/cms/app/OpenAS_Tomcat7/webapps/src"dest="/home/cms/app/OpenAS_Tomcat7/webapps/test"replace $src $dest
第三行:對源文件夾下的文件遍歷循環,``會將包含的命令的輸出放在相應位置,$1,$2取得是函數的入參
第七行:if條件判斷,[ 后有空格,=前后要有空格;=無空格會被認為是賦值
shell腳本里賦值使用的是不帶空格的=,條件判斷使用的是帶空格的=
總結
到此這篇關于批量復制及執行命令shell腳本的文章就介紹到這了,更多相關shell腳本批量復制內容請搜索武林網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持武林網!
新聞熱點
疑難解答