Linux下如何實(shí)現(xiàn)shell多線程編程以提高應(yīng)用程序的響應(yīng)

Linux中多線程編程擁有提高應(yīng)用程序的響應(yīng)、使多cpu系統(tǒng)更加有效等優(yōu)點(diǎn),下面小編將通過Linux下shell多線程編程的例子給大家講解下多線程編程的過程,一起來(lái)了解下吧。
#!/bin/bash
#———————————————————————————–
# 此例子說明了一種用wait、read命令模擬多線程的一種技巧
# 此技巧往往用于多主機(jī)檢查,比如ssh登錄、ping等等這種單進(jìn)程比較慢而不耗費(fèi)cpu的情況
# 還說明了多線程的控制
#———————————————————————————–
function a_sub
{
# 此處定義一個(gè)函數(shù),作為一個(gè)線程(子進(jìn)程)
sleep 3 # 線程的作用是sleep 3s
}
tmp_fifofile=“/tmp/$.fifo” mkfifo $tmp_fifofile # 新建一個(gè)fifo類型的文件
exec 6《》$tmp_fifofile # 將fd6指向fifo類型
rm $tmp_fifofile thread=15 # 此處定義線程數(shù)
for
((i=0;i《$thread;i++));do echo
done 》&6 # 事實(shí)上就是在fd6中放置了$thread個(gè)回車符
for
?。ǎ╥=0;i《50;i++));do # 50次循環(huán),可以理解為50個(gè)主機(jī),或其他
read -u6 # 一個(gè)read -u6命令執(zhí)行一次,就從fd6中減去一個(gè)回車符,然后向下執(zhí)行,
# fd6中沒有回車符的時(shí)候,就停在這了,從而實(shí)現(xiàn)了線程數(shù)量控制
{ # 此處子進(jìn)程開始執(zhí)行,被放到后臺(tái)
a_sub &&
{ # 此處可以用來(lái)判斷子進(jìn)程的邏輯
echo “a_sub is finished”
}
||
{ echo “sub error”
}
echo 》&6 # 當(dāng)進(jìn)程結(jié)束以后,再向fd6中加上一個(gè)回車符,即補(bǔ)上了read -u6減去的那個(gè)
}
& done wait # 等待所有的后臺(tái)子進(jìn)程結(jié)束
exec 6》&- # 關(guān)閉df6 exit 0
說明:
此程序中的命令
mkfifo tmpfile
和linux中的命令
mknod tmpfile p
效?果相同。區(qū)別是mkfifo為POSIX標(biāo)準(zhǔn),因此推薦使用它。該命令創(chuàng)建了一個(gè)先入先出的管道文件,并為其分配文件標(biāo)志符6。管道文件是進(jìn)程之間通信的一種方式,注意這一句很重要
exec 6《》$tmp_fifofile # 將fd6指向fifo類型
如果沒有這句,在向文件$tmp_fifofile或者&6寫入數(shù)據(jù)時(shí),程序會(huì)被阻塞,直到有read讀出了管道文件中的數(shù)據(jù)為止。而執(zhí)行了上面這一句后就可以在程序運(yùn)行期間不斷向fifo類型的文件寫入數(shù)據(jù)而不會(huì)阻塞,并且數(shù)據(jù)會(huì)被保存下來(lái)以供read程序讀出。
通過運(yùn)行命令:
time 。/multithread.sh 》/dev/null
最終運(yùn)算時(shí)間: 50/15 = 3組(每組15)+1組(5個(gè)《15 組成一個(gè)組)= 4組,每組花費(fèi)時(shí)間:3秒,
則 3 * 4 = 12 秒。
傳統(tǒng)非多線程的代碼 運(yùn)算時(shí)間: 50 * 3 = 150 秒。
上面就是Linux下shell多線程編程的實(shí)例介紹了,使用多線程編程還能夠改善程序結(jié)構(gòu),有興趣的朋友不妨試試看吧。
相關(guān)文章
Fedora Linux 42 穩(wěn)定版發(fā)布: 帶來(lái)大量新功能和軟件更新
Fedora 42昨日發(fā)布,這是 Red Hat 贊助開發(fā)的杰出前沿 Linux 發(fā)行版的最新版,包含大量新功能和軟件更新,使其成為 2025 年上半年發(fā)布的一款出色的 Linux 操作系統(tǒng)之一,內(nèi)2025-04-16如何在Linux查看硬盤信息? 查看Linux硬盤大小類型和硬件信息的5種方法
使用Linux系統(tǒng)的過程中,查看和了解硬盤信息是非常重要的工作,尤其是對(duì)于系統(tǒng)管理員而言,那么在Linux系統(tǒng)中如何查看硬盤信息?以下是具體內(nèi)容介紹2025-03-12如何在 Linux 中查看 CPU 詳細(xì)信息? 3招輕松查看CPU型號(hào)、核心數(shù)和溫度
在日常運(yùn)維工作中,獲取 CPU 信息是系統(tǒng)運(yùn)維管理員常見的工作內(nèi)容,無(wú)論是為了性能調(diào)優(yōu)、硬件升級(jí)還是僅僅滿足好奇心2025-03-11什么是 Arch Linux? 獨(dú)樹一幟的Arch Linux發(fā)行版分析
Arch Linux是為簡(jiǎn)化,優(yōu)化,現(xiàn)代化,實(shí)用主義,用戶中心和多功能性而創(chuàng)建Linux發(fā)行版,究竟是什么讓 Arch 與眾不同?下面我們就來(lái)簡(jiǎn)要解讀2025-02-19如何在Linux環(huán)境下制作 Win11裝機(jī)U盤?
一直用的linux辦公,想要將筆記本電腦從 Linux 系統(tǒng)切換回 Windows 11,我們可以制作一個(gè)win11裝機(jī)u盤,詳細(xì)如下2025-02-17Rsnapshot怎么用? 基于Rsync的強(qiáng)大Linux備份工具使用指南
Rsnapshot 不僅可以備份本地文件,還能通過 SSH 備份遠(yuǎn)程文件,接下來(lái)詳細(xì)介紹如何安裝、配置和使用 Rsnapshot,包括創(chuàng)建每小時(shí)、每天、每周和每月的本地備份,以及如何進(jìn)2025-02-06Linux Kernel 6.13發(fā)布:附更新內(nèi)容及新特性解讀
Linux 內(nèi)核 6.13 正式發(fā)布,新版本引入了惰性搶占支持,簡(jiǎn)化內(nèi)核搶占邏輯,通過減少與調(diào)度器相關(guān)的調(diào)用次數(shù),讓內(nèi)核在運(yùn)行時(shí)表現(xiàn)更優(yōu),從而提高效率2025-01-23五大特性引領(lǐng)創(chuàng)新! 深度操作系統(tǒng) deepin 25 Preview預(yù)覽版發(fā)布
今日,深度操作系統(tǒng)正式推出deepin 25 Preview版本,該版本集成了五大核心特性:磐石系統(tǒng)、全新DDE、Treeland窗口合成器、AI For OS以及Distrobox子系統(tǒng)2025-01-18Linux Mint Xia 22.1重磅發(fā)布: 重要更新一覽
Beta 版 Linux Mint“Xia” 22.1 發(fā)布,新版本基于 Ubuntu 24.04,內(nèi)核版本為 Linux 6.8,這次更新帶來(lái)了諸多優(yōu)化和改進(jìn),進(jìn)一步鞏固了 Mint 在 Linux 桌面操作系統(tǒng)領(lǐng)域的2025-01-16LinuxMint怎么安裝? Linux Mint22下載安裝圖文教程
Linux Mint22發(fā)布以后,有很多新功能,很多朋友想要下載并安裝,該怎么操作呢?下面我們就來(lái)看看詳細(xì)安裝指南2025-01-16