批量複製及執行命令shell腳本

平時在處理一個或幾個機器運行環境時,一個機器一個機器處理也能接受,可是若是是一批機器,幾十或幾百臺,要是一臺一臺去安裝環境,光是輸入同一的命令,估計你本身都想吐,全部聰明的人會想一些偷懶的辦法,確實能夠找到一些省時省力的方法,好比寫一個批量處理shell腳本,這幾天在處理一批(八九十臺)機器環境,找了一些批量處理的腳本,包括批量傳輸(scp)文件到多臺機器上、批量執行命令到多臺機器、還有須要交互的命令,下面記錄一些這些命令:java

機器IP文件:ip.txtshell

192.168.10.201
192.168.10.202
192.168.10.203
192.168.10.204
192.168.10.205

另外全部機器要能夠從一臺機器經過ssh無密登陸其餘機器bash

1.批量傳輸(scp)文件到一批機器上ssh

建立腳本文件,並修改成可執行文件工具

touch xscp.sh
chmod +x xscp.sh

腳本命令:spa

#!/bin/bash
for 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/
    fi
done

示例1:指定要傳輸的文件code

./xscp.sh ip.txt /opt/soft/ filename1 filename2 ...

第一個參數($1):ip.txt  是一個以換行符分割的IP集合,每一個IP佔一行blog

第二個參數($2):/opt/soft/  文件要傳輸到目標機器的目錄進程

第三個及之後n個參數(${@:3}):爲要傳輸的文件或文件集合ip

示例2:不指定文件

./xscp.sh ip.txt /opt/soft/

若是不指定要傳輸的文件,會默認傳輸第二個參數($2)目錄(/opt/soft)下的全部文件,到目標機器對應的目錄(/opt/soft)下

2.批量執行命令腳本(無交互)

建立腳本文件,並修改成可執行文件

touch xcall.sh
chmod +x xcall.sh

腳本命令:

#!/bin/bash
params=${@: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基本命令:

  • spawn :啓動新進程,用於執行shell命令;
  • expect :從發起交互的命令的進程接受字符串,用於匹配咱們預想的字符串;
  • send :用於向發起交互的命令的進程發送字符串;
  • interact:容許用戶交互,即此命令後,交互將不會由expect進行,將交回給用戶;

示例1:

建立腳本文件並修改成可執行文件:

touch xcall-keytool-list.sh
chmod +x xcall-keytool-list.sh

腳本命令:

#!/bin/bash
params=${@: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 eof
EOF
done

命令執行 在查詢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.sh
chmod +x xcall-interaction.sh

腳本命令:

#!/bin/bash
# IP文件
iptxt=$1
# 要執行的命令
command=$2
# 交互時輸入項(yes/no|password)
initem=$3
# 交互輸入內容(yes | 密碼)
input=$4
echo "--- 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 eof
EOF
    fi
done

執行命令:

./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

相關文章
相關標籤/搜索