前言
在業務開發過程中,經常會在后臺寫一些shell腳本處理數據,但估計很多人不知道shell腳本也可以支持多線程,而且非常簡單。本篇文章主要就是介紹shell實現多進程以及進程數量控制。
需求
為了更好的說明問題,我們結合例子講解,假設需求就是掃描url.txt文件,然后判斷里面的URL是否失效。url.txt文件的內容是一行一個URL,如:
http://www.google.com
http://www.companysz.com
單進程實現
那么shell腳本scanUrl.sh可以這樣寫:
#循環讀出URL并判斷狀態碼
while read line
do
{
isok=`curl -I -o /dev/null -s -w %{http_code} $line`
if [ "$isok" = "200" ]; then
echo $line "OK"
else
echo $line "no"
fi
}
done < $1
echo "執行結束"
但這樣腳本執行非常慢,一萬個URL幾個小時都掃描不完。
多進程實現
改成多進程實現非常簡單,只需要在do后面的大括號加 & 符號,在done后面加一個wait,表示父進程等待子進程退出后再退出
#循環讀出URL并判斷狀態碼
while read line
do
{
isok=`curl -I -o /dev/null -s -w %{http_code} $line`
if [ "$isok" = "200" ]; then
echo $line "OK"
else
echo $line "no"
fi
}
}&
done < $1
wait
echo "執行結束"
多進程實現并控制進程數
if [ $# != 1 ] ;then
echo "The parameters you enter is not correct !";
exit -1;
fi
while read line
do
{
#進程控制
read -u 9
{
#isok=`curl -I -o /dev/null -s -w %{http_code} $line`
if [ "$isok" = "200" ]; then
echo $line "OK"
else
echo $line "no"
fi
echo -ne "/n" 1>&9
}&
}
done < $1
wait
echo "執行結束"
rm tmp
這樣就能達到我們的目的了。
|
新聞熱點
疑難解答