コンテンツにスキップ

GNU parallel

出典: フリー百科事典『ウィキペディア(Wikipedia)』
GNU parallel
作者 Ole Tange[1]
開発元 GNUプロジェクト
最新版
20240222 ('Навальный') / 2024年2月28日 (8か月前) (2024-02-28)[2]
リポジトリ ウィキデータを編集
プログラミング
言語
Perl
対応OS Unix系
サポート状況 開発中
種別 ユーティリティ
ライセンス GNU GPL v3+[1]
公式サイト GNU Parallel
テンプレートを表示

GNU parallel (グヌー・パラレル) は、Unix系OSコマンドラインユーティリティである。Unixシェル上でコマンド並列実行を可能にする[1]。Ole Tange によってPerl言語で作られ、GNU GPL v3+の下で配布されている[1]

使用方法

[編集]
GNU parallelの紹介 (パート1)
GNU parallelの紹介 (パート2)

最も一般的な使用方法は、sh スクリプトの for の置き換えであり、以下はその例である。

for x in $(cat list) ; do
    do_something "${x}"
done | process_output

このコマンドは以下のように置き換えることができる。

cat list | parallel do_something | process_output

do_something引数となるファイルの一覧 (list) は、パイプによって入力される。また、process_outputが空の場合がある。

GNU parallel を使用するスクリプトは、pexec英語版を使用するスクリプトよりも可読性が高いものになる。

GNU parallel では、以下のような処理が行われる。

デフォルトでは、CPUコア数と同数のジョブが並列実行される。

実行例

[編集]
find . -name "*.foo" | parallel grep bar

上記のコマンドは以下のコマンドと同等である。

find . -name "*.foo" -exec grep bar {} +

これらのコマンドは、カレントディレクトリとそれ以下に存在する全てのファイルとディレクトリで名前が『.foo』で終わるものを検索し、その中で名前に『bar』を含むものを更に検索するものである。parallelは、ファイル名改行が含まれていない限りは正常に動作する。ファイル名に改行が含まれている場合は以下のコマンドによって問題を回避する。

find . -name "*.foo" -print0 | parallel -0 grep bar

上記のコマンドは、ヌル文字によってファイル名を区切っている。

find . -name "*.foo" | parallel -X mv {} /tmp/trash

上記のコマンドは、引数の位置を{}によって変更している。

find . -maxdepth 1 -type f -name "*.ogg" | parallel -X -r cp -v -p {} /home/media

上記のコマンドは以下のコマンドと同等である。

cp -v -p *.ogg /home/media

上記のコマンドよりもfindparallelcpを使用している実行例の方がリソース効率がよく、『*.ogg』に一致するファイルが膨大な場合に発生するシェルへの過負荷によるエラーを防ぐことができる。

脚注

[編集]
  1. ^ a b c d GNU Parallel”. Free Software Foundation. 2018年9月27日閲覧。
  2. ^ Tange, Ole (28 February 2024). "GNU Parallel 20240222 ('Навальный') released [stable]". parallel (Mailing list). 2024年3月11日閲覧

関連項目

[編集]

外部リンク

[編集]