バッチ処理
バッチ処理(バッチしょり、英: batch processing)はバッチ単位で行なわれる処理である。特に以下の2つの意味で用いられる。
コンピュータのバッチ処理
編集コンピュータのデータ処理におけるバッチ処理は、ひとまとまりのデータを一括して処理する方式である[1]。逐次生み出されるデータを一定期間・一定量集めたものをバッチといい、このバッチ単位で処理を行なう方式がバッチ処理である。
バックアップ、フィルタリング、ソートなどの特定のデータ処理タスクは、個々のデータトランザクションで実行するには計算負荷が高く、非効率的となる場合がある。代わりに、データシステムはそのようなタスクをバッチで(まとめて)処理する。大量の反復的なデータジョブを定期的に完了するためにコンピュータが使用する方法である[2]。
比較される方式として、逐次生み出されるデータをストリームとして捉え、到着したデータを順次扱うストリーム処理がある[3]。データをキューイングせず即時処理するリアルタイム処理とも比較される。
バッチ処理を直列につなぎパイプライン処理とする(パイプラインを構築する)ことがしばしば行なわれる。
MS-DOSおよびMicrosoft Windowsのバッチファイルは複数のコマンド行を連続で自動実行できるようにまとめて記述したテキストファイルであり、プログラムの一種である[4]。Unix系オペレーティングシステムのシェルスクリプトほどの柔軟性はないものの、コマンド群を定期的に繰り返し実行する際に使われ、いずれもバッチ処理に応用される。例えば複数のソースファイルからなるプログラムをコンパイルしてリンクし、実行ファイルを生成(ビルド)するとき、プログラムを修正するたびに毎回コマンドラインシェル(コマンドラインインタプリタ)上でコンパイラに渡す複雑なオプションを指定するためのコマンドを手入力するのは骨が折れるし、途中で入力ミスをしてしまうと最初からやり直しになってしまうこともある。バッチファイルやスクリプトファイルにあらかじめコマンド群を記述しておけば、次回からはそのファイルを使って実行するだけで済み、作業を自動化することができる[注釈 1]。定期的なデータのバックアップや集計作業などにも同じことが言える。ただし、狭義のバッチ処理は単なる自動化にとどまらず、一定期間または一定量蓄積されたデータをまとめて効率的に処理することを指す。
OpenGLやバージョン11までのDirect3Dは、GPUに描画準備をさせるためのレンダーステート(合成方式などの描画設定)の変更や、描画命令を発行するためのドローコールのオーバーヘッドが大きい。スプライトやフォント(文字)の画面描画(レンダリング)をする際、1つのスプライトや1つの文字を描画するたびに設定変更メソッドや描画メソッドを呼び出してしまうと、大量に描画する際のオーバーヘッドが無視できないものとなって低速化してしまう。そのため、複数のスプライトの描画リクエストを一定量キューイングしておき、同じレンダーステートや同じテクスチャを使って描画できるものはまとめてドローコールを発行するバッチ処理で効率化を図るのが一般的である。Direct3D 9/10では公式の拡張ライブラリD3DXにスプライトバッチ機能が用意されていた[5][6]。Direct3D 11上に構築されたDirect2D 1.3にも、スプライトバッチ機能が用意されている[7]。
「バッチ (batch)」はプログラミングをする際、紙テープやパンチカードを利用していた時代より使用され始めた言葉である。カードまたは紙テープはシステムオペレーターに渡され、オペレーターはタスクのスケジューリングをし、コンピュータにカードまたは紙テープを投入していった。スケジューリングされたタスクは直ちにシステムに入れられたのではなく、一緒にまとめて投入されたので(バッチとは、複数の似ているものを1つのグループとして生産、処理すること、または一緒に集めて1つのユニットとして扱うこと。en:Batch processingより)、これらのタスクの集まりを「バッチジョブ」と呼ぶようになった[要出典]。
バッチジョブは一度設定されると人間の手を煩わせることなく動作する非対話型処理である。そのため入力データもスクリプトやコマンド行パラメータを通してあらかじめ用意される。この点でユーザーの入力を必要とする対話型プログラムとは対極にある。
バッチジョブは相互対話式の思想に基づく処理の仕組みではないが、IBM の CICS のようなトランザクション処理システムもテクニカルな視点から見ればバッチジョブとして動いている。もっとも、その部分はユーザーから隠れて見えない部分である。
様々な計算ジョブを制御された順番に行なう強力なユーティリティがUNIXやWindows向けに存在する。このようなユーティリティをジョブ管理システムという。基本的なジョブ管理システムはモダンなデスクトップOSやサーバーOSであれば標準ツールとして搭載されているほか、各種OS用の強力な商用パッケージも市販されている。
NECの情報管理ソフトウェアの中にInfoFrame DataBoosterという製品がある。これは通常夜間行われる日次月次のバッチ処理を高速化しようというもので、数十GB単位の大量のメモリと専用の処理アルゴリズムによって、時間のかかる中間ファイルの生成を行なわないところに特徴がある。
システム利用者が少ない・あるいはサービス提供時間外でシステム負荷が低い夜間に実行されるバッチ処理は「夜間バッチ」と呼ばれる。何らかの事情で夜間バッチが事前の想定時刻までに処理を完了できなかった場合は「突き抜け」と呼ばれることがある[8]。
利点
編集バッチ処理には以下のような利点がある。
- 多くのユーザーがコンピュータのリソースを共有できる。
- 処理をコンピュータのリソースがあまり忙しくない時間帯(多くは夜間、休日)にシフトできる。
- 人間がついていなくてもコンピュータのリソースが暇にならないように最大限有効活用できる。
- 高価なコンピュータをフルに活用することで費用対効果の効率向上に寄与する。
- サービスを停止して行なうバッチ処理の場合、データの整合性を保つことが容易となる。
欠点
編集- 即時性が必要な処理には向かない。
- 夜間バッチを使用して「突き抜け」が発生した場合、本来のサービスと合わせて負荷がかかり大規模なシステム障害を引き起こす可能性がある。
バッチ管理システム
編集この節に雑多な内容が羅列されています。 |
ウィキペディアはオンライン百科事典であって、情報を無差別に収集する場ではありません。 |
- Spring Batch[※ 1]
- Java Batch System[※ 2] - 現在β版
- blancoBatchProcess[※ 3] - Excelから生成
- SUNBATCH - サントリーシステムテクノロジー
- ParallelFrame - メディア情報開発
- オブジェクトワークス/BT JobManager - NRI
- TERASOLUNA Batch Framework for Java - NTTデータ
- Web Solid Framework - ワイ・エス・ピー
- WebSphere Extended Deployment - IBM
- Batch Execution and Control Environment for Java (JBeX) - 日本IBM
- Quartz Enterprise Job Scheduler[※ 4]
- Real timeFramework Architecture - フューチャーアーキテクト
- Batch.dart[※ 5][※ 6]
脚注
編集注釈
編集出典
編集- ^ 「一定期間又は一定量のデータを集め, 一括して処理する方式」 ITパスポート試験. (2018). ITパスポート試験 平成30年度 春期分. 問94ア
- ^ バッチ処理とは? - バッチ処理システムの説明 - AWS
- ^ ストリーミングデータとは - ストリーミングデータの説明 - AWS / §バッチデータとストリーミングデータにはどのような違いがありますか?
- ^ batch fileの意味・使い方|英辞郎 on the WEB
- ^ ID3DXSprite interface (D3dx9core.h) - Win32 apps | Microsoft Learn
- ^ ID3DX10Sprite interface (D3DX10.h) - Win32 apps | Microsoft Learn
- ^ ID2D1SpriteBatch (d2d1_3.h) - Win32 apps | Microsoft Learn
- ^ “夜間バッチとは - 意味をわかりやすく - IT用語辞典 e-Words”. IT用語辞典 e-Words. 株式会社インセプト. 2024年5月22日閲覧。