成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

使用parallel利用起你的所有CPU資源

系統 Linux
本文中,我們將會使用 parallel 程序。parallel 會接受一個列表作為輸入,然后在所有 CPU 核上并行地執行命令來處理該列表。Parallel 甚至會按順序將結果輸出到標準輸出中,因此它可以用在管道中作為其他命令的標準輸入。

[[214408]]

bash 命令通常單線程運行。這意味著所有的處理工作只在單個 CPU 上執行。隨著 CPU 規模的擴大以及核心數目的增加,這意味著只有一小部分的 CPU 資源用于處理你的工作。

當我們的工作受制于 CPU 處理數據的速度時,這些未使用的 CPU 資源能產生很大的效用。這種情況在進行多媒體轉換(比如圖片和視頻轉換)以及數據壓縮中經常遇到。

本文中,我們將會使用 parallel 程序。parallel 會接受一個列表作為輸入,然后在所有 CPU 核上并行地執行命令來處理該列表。Parallel 甚至會按順序將結果輸出到標準輸出中,因此它可以用在管道中作為其他命令的標準輸入。

 

如何使用 parallel

parallel 在標準輸入中讀取一個列表作為輸入,然后創建多個指定命令的進程來處理這個列表,其格式為:

  1. list | parallel command

這里的 list 可以由任何常見的 bash 命令創建,例如:cat、grep、find。這些命令的結果通過管道從它們的標準輸出傳遞到 parallel 的標準輸入,像這樣:

  1. find . -type f -name "*.log" | parallel

find 中使用 -exec 類似,parallel 使用 {} 來表示輸入列表中的每個元素。下面這個例子中,parallel 會使用 gzip 壓縮所有 find 命令輸出的文件:

  1. find . -type f -name "*.log" | parallel gzip {}

下面這些實際的使用 parallel 的例子可能會更容易理解一些。

 

使用 parallel 來進行 JPEG 壓縮

在這個例子中,我收集了一些比較大的 .jpg 文件(大約 10MB 大?。?,要用 Mozilla 出品的 JPEG 圖像壓縮工具 MozJPEG 來進行處理。該工具會在嘗試保持圖像質量的同時減少 JPEG 圖像文件的大小。這對降低網頁加載時間很重要。

下面是一個普通的 find 命令,用來找出當前目錄中的所有 .jpg 文件,然后通過 MozJPEG 包中提供的圖像壓縮工具 (cjpeg) 對其進行處理:

  1. find . -type f -name "*.jpg" -exec cjpeg -outfile LoRes/{} {} ';'

總共耗時 0m44.114s。該命令運行時的 top 看起來是這樣的:

[[214409]]

你可以看到,雖然有 8 個核可用,但實際只有單個線程在用單個核。

下面用 parallel 來運行相同的命令:

  1. find . -type f -name "*.jpg" | parallel cjpeg -outfile LoRes/{} {}

這次壓縮所有圖像的時間縮減到了 0m10.814s。從 top 顯示中可以很清楚地看出不同:

所有 CPU 核都滿負荷運行,有 8 個線程對應使用 8 個 CPU 核。

 

parallel 與 gzip 連用

如果你需要壓縮多個文件而不是一個大文件,那么 parallel 就能用來提高處理速度。如果你需要壓縮單個文件而同時又想要利用所有的 CPU 核的話,那么你應該 gzip 的多線程替代品 pigz。

首先,我用隨機數據創建了 100 個大約 1GB 的文件:

  1. for i in {1..100}; do dd if=/dev/urandom of=file-$i bs=1MB count=10; done

然而我用 find -exec 命令來進行壓縮:

  1. find . -type f -name "file*" -exec gzip {} ';'

總共耗時 0m28.028s,而且也是只利用了單核。

換成 parallel 版本:

  1. find . -type f -name "file*" | parallel gzip {}

耗時減少到了 0m5.774s

parallel 是一款非常好用的工具,應該加入到你的系統管理工具包中,在合適的場合它能幫你節省大量的時間。 

責任編輯:龐桂玉 來源: Linux中國
相關推薦

2013-10-30 09:37:19

LinuxLinux命令

2021-06-21 06:16:50

cpulimitCPULinux

2021-03-27 10:53:05

NodeJSCPU服務器

2017-02-14 08:33:48

CPULinux內核

2020-11-17 10:50:37

Python

2010-03-19 13:17:26

Parallel

2025-05-29 01:45:00

Kubernetes容器CPU

2010-04-27 18:24:56

AIX CPU

2012-07-26 09:10:31

PHP

2017-04-12 11:02:50

Apache Meso資源利用容器

2024-04-07 09:04:18

Parallel 類編程工具.NET

2015-04-08 09:54:41

OpenStack資源私有云部署

2023-04-04 09:22:50

LinuxCPU命令

2017-08-25 15:56:54

Linuxproc文件系統CPU利用率

2019-08-28 06:58:06

Linux監控腳本Shell

2013-10-29 10:59:49

IT安全IT安全培訓

2021-03-31 13:45:59

CPU運維命令

2020-12-02 12:26:20

CPU網卡通信

2021-08-25 23:03:58

區塊鏈數據安全

2024-07-30 11:21:17

TTSAIAgent
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 在线观看你懂的网站 | 久久亚洲一区二区 | 一区二区三区久久 | 国产免费播放视频 | 99精品国自产在线 | 日韩精品一区二区三区视频播放 | 亚洲一区二区三区免费视频 | 亚洲瑟瑟 | 亚洲第一av | 欧美一区二区黄 | 二区亚洲| 久久久99国产精品免费 | 中文字幕在线一区 | 亚洲日韩中文字幕一区 | 欧美精品欧美精品系列 | 91视频正在播放 | 男人的天堂中文字幕 | 欧美精品免费观看二区 | 亚洲精品成人网 | 看一级毛片视频 | 精品久久精品 | 精品免费国产视频 | 在线精品一区二区 | 亚洲一区中文字幕 | 欧美精品一区二区免费 | 成年人黄色免费视频 | 毛片1| 成人av电影天堂 | 欧美成人免费在线视频 | 中文精品久久 | 欧美日韩精品一区二区三区四区 | 亚洲精品成人免费 | 久久88 | 国产精品久久久久久久岛一牛影视 | 日韩一区二区福利视频 | 国产精品成人一区二区三区 | 成人亚洲网站 | 国产精品免费一区二区三区四区 | 一级黄色毛片子 | 夜夜精品浪潮av一区二区三区 | www.国产|