佳木斯湛栽影视文化发展公司

主頁 > 知識(shí)庫 > Shell多線程操作及線程數(shù)控制實(shí)例

Shell多線程操作及線程數(shù)控制實(shí)例

熱門標(biāo)簽:AI電銷 服務(wù)外包 Linux服務(wù)器 百度競(jìng)價(jià)排名 網(wǎng)站排名優(yōu)化 鐵路電話系統(tǒng) 呼叫中心市場(chǎng)需求 地方門戶網(wǎng)站

前言

在業(yè)務(wù)開發(fā)過程中,經(jīng)常會(huì)在后臺(tái)寫一些shell腳本處理數(shù)據(jù),但估計(jì)很多人不知道shell腳本也可以支持多線程,而且非常簡(jiǎn)單。本篇文章主要就是介紹shell實(shí)現(xiàn)多進(jìn)程以及進(jìn)程數(shù)量控制。

需求

為了更好的說明問題,我們結(jié)合例子講解,假設(shè)需求就是掃描url.txt文件,然后判斷里面的URL是否失效。url.txt文件的內(nèi)容是一行一個(gè)URL,如:

復(fù)制代碼 代碼如下:

http://www.baidu.com

http://www.google.com


https://www.jb51.net

單進(jìn)程實(shí)現(xiàn)

那么shell腳本scanUrl.sh可以這樣寫:

復(fù)制代碼 代碼如下:

#!/bin/bash
#判斷是否有參數(shù)
if [ $# != 1 ] ;then
        echo "The parameters you enter is not correct !";
        exit -1;
fi

#循環(huán)讀出URL并判斷狀態(tài)碼
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 "執(zhí)行結(jié)束"


那么可以執(zhí)行下面的命令掃描:
復(fù)制代碼 代碼如下:

/bin/sh scanUrl.sh url.txt

但這樣腳本執(zhí)行非常慢,一萬個(gè)URL幾個(gè)小時(shí)都掃描不完。

多進(jìn)程實(shí)現(xiàn)


改成多進(jìn)程實(shí)現(xiàn)非常簡(jiǎn)單,只需要在do后面的大括號(hào)加 符號(hào),在done后面加一個(gè)wait,表示父進(jìn)程等待子進(jìn)程退出后再退出

復(fù)制代碼 代碼如下:

#!/bin/bash
#判斷是否有參數(shù)
if [ $# != 1 ] ;then
        echo "The parameters you enter is not correct !";
        exit -1;
fi

#循環(huán)讀出URL并判斷狀態(tài)碼
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 "執(zhí)行結(jié)束"


這樣就能多進(jìn)程并發(fā)執(zhí)行了,但有個(gè)問題是進(jìn)程會(huì)一下子非常多,幾百上千,超過系統(tǒng)限制報(bào)錯(cuò),下面我們就加上進(jìn)程數(shù)控制。

多進(jìn)程實(shí)現(xiàn)并控制進(jìn)程數(shù)

復(fù)制代碼 代碼如下:

#!/bin/bash
#允許的進(jìn)程數(shù)
THREAD_NUM=200
#定義描述符為9的管道
mkfifo tmp
exec 9>tmp
#預(yù)先寫入指定數(shù)量的換行符,一個(gè)換行符代表一個(gè)進(jìn)程
for ((i=0;i$THREAD_NUM;i++))
do
    echo -ne "\n" 1>9
done

if [ $# != 1 ] ;then
        echo "The parameters you enter is not correct !";
        exit -1;
fi

while read line
do
{
    #進(jìn)程控制
    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 "執(zhí)行結(jié)束"
rm tmp


上面的代碼就可以保證子進(jìn)程在指定數(shù)量了,其進(jìn)程控制原理是通過管道實(shí)現(xiàn)的,當(dāng)管道無內(nèi)容可讀時(shí)就不會(huì)執(zhí)行
復(fù)制代碼 代碼如下:

{
    #isok=`curl -I -o /dev/null -s -w %{http_code} $line`
    if [ "$isok" = "200" ]; then
        echo $line "OK"
    else
        echo $line "no"
    fi
    #寫入一個(gè)換行符
    echo -ne "\n" 1>9
}

而且每個(gè)進(jìn)程執(zhí)行完成后都會(huì)向管道寫入一個(gè)換行符,從而保證進(jìn)程數(shù)是指定的。

這樣就能達(dá)到我們的目的了。

您可能感興趣的文章:
  • PowerShell多線程執(zhí)行前后臺(tái)作業(yè)的例子
  • Shell腳本實(shí)現(xiàn)把進(jìn)程負(fù)載均衡到多核CPU中
  • 自動(dòng)殺掉占用較多CPU資源的Shell腳本

標(biāo)簽:衡水 黃山 湖南 仙桃 蘭州 銅川 湘潭 崇左

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Shell多線程操作及線程數(shù)控制實(shí)例》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    黔东| 浑源县| 册亨县| 锡林郭勒盟| 丹寨县| 郸城县| 通州市| 龙胜| 恩平市| 临江市| 文安县| 沐川县| 黑河市| 亚东县| 钟山县| 丰镇市| 靖西县| 房产| 黔江区| 石柱| 万山特区| 梅河口市| 司法| 杨浦区| 介休市| 佳木斯市| 通辽市| 迁西县| 石家庄市| 岐山县| 平阴县| 洛隆县| 湟源县| 扶风县| 永康市| 嘉峪关市| 苗栗市| 汉沽区| 伊宁市| 新和县| 阿坝|