

(19) 日本国特許庁(JP)

## (12) 特許公報(B2)

(11) 特許番号

特許第6201478号  
(P6201478)

(45) 発行日 平成29年9月27日(2017.9.27)

(24) 登録日 平成29年9月8日(2017.9.8)

(51) Int.Cl.

F 1

G06F 9/48 (2006.01)  
G06F 9/52 (2006.01)G06F 9/46 452Z  
G06F 9/46 472Z  
G06F 9/46 457

請求項の数 7 (全 19 頁)

|           |                              |
|-----------|------------------------------|
| (21) 出願番号 | 特願2013-151711 (P2013-151711) |
| (22) 出願日  | 平成25年7月22日 (2013.7.22)       |
| (65) 公開番号 | 特開2015-22626 (P2015-22626A)  |
| (43) 公開日  | 平成27年2月2日 (2015.2.2)         |
| 審査請求日     | 平成28年4月5日 (2016.4.5)         |

|           |                                                   |
|-----------|---------------------------------------------------|
| (73) 特許権者 | 000005223<br>富士通株式会社<br>神奈川県川崎市中原区上小田中4丁目1番<br>1号 |
| (74) 代理人  | 100129425<br>弁理士 小川 譲晃                            |
| (74) 代理人  | 100099623<br>弁理士 奥山 尚一                            |
| (74) 代理人  | 100078330<br>弁理士 笹島 富二雄                           |
| (72) 発明者  | 川崎 智弘<br>神奈川県川崎市中原区上小田中4丁目1番<br>1号 富士通株式会社内       |

審査官 圓道 浩史

最終頁に続く

(54) 【発明の名称】処理順序制御装置、処理順序制御方法及び処理順序制御プログラム

## (57) 【特許請求の範囲】

## 【請求項 1】

1 又は複数のコンピュータで動作する複数のプロセスが夫々実行する処理の実行順序を制御する制御プロセスが、当該制御プロセス及び前記プロセスによりアクセス可能な記憶手段に含まれる所定の記憶領域の複数の箇所に対して、ロックを実行し、

前記プロセスが、前記制御プロセスによりロックが実行された前記記憶領域のうち、各プロセスの自処理の実行順序に対応する箇所に対してロックを要求し、

前記制御プロセスが、前記プロセスからの前記ロックの要求を前記実行順序に対応する前記箇所毎に前記ロックが解放されるまで待機状態とし、

前記制御プロセスが、前記プロセスによりロックが要求された箇所のロックを、前記処理の前記実行順序と対応させて順次解放する  
処理を含んだ処理順序制御方法。

## 【請求項 2】

前記ロックを順次解放する処理は、前記制御プロセスが、前記プロセスにより実行を終了した処理に対応する箇所に対するロックが解放されると、当該箇所に対するロックを再実行し、当該箇所に対応する実行順序の次の実行順序に対応する箇所のロックを解放する、請求項1記載の処理順序制御方法。

## 【請求項 3】

前記処理が複数の異なるコンピュータで実行され、前記制御プロセスが前記複数の異なるコンピュータの夫々で動作し、

10

20

前記制御プロセスの夫々と通信可能な総合制御プロセスが、前記制御プロセスの夫々に対し、前記複数の異なるコンピュータの夫々に設けられた前記記憶領域のうち前記制御プロセスの夫々が実行順序を制御する処理の実行順序に対応する箇所のロックを順次解放する指示を行い、

前記ロックを順次解放する処理は、前記制御プロセスの夫々が、前記総合制御プロセスによる指示に応じて、少なくとも前記記憶領域のうち自制御プロセスが実行順序を制御する処理の実行順序に対応する箇所のロックを順次解放する、請求項1又は2に記載の処理順序制御方法。

#### 【請求項4】

前記ロックを順次解放する指示を行う処理は、総合制御プロセスが、前記制御プロセスの夫々に対し、同時に同一の実行順序に対応する箇所のロックを解放する指示を行い、

10

前記ロックを順次解放する処理は、前記制御プロセスの夫々が、前記総合制御プロセスによる指示に応じて、他の制御プロセスと同一の実行順序に対応する箇所のロックを順次解放する、請求項3記載の処理順序制御方法。

#### 【請求項5】

前記制御プロセスは、前記実行順序の夫々に対応する箇所と当該実行順序を規定する通し番号のいずれかの値とを対応付け、当該通し番号のうちでより小さい前記値が対応付けられている処理から前記ロックを解放するようにし、

前記実行順序の夫々に対応する箇所には、新たな処理を実行するプロセスが空いている領域の箇所にロックをかけられるように、少なくとも1つの処理の実行順序に対応する箇所分の間隔を空けて前記値が夫々対応付けられている、請求項1又は2に記載の処理順序制御方法。

20

#### 【請求項6】

コンピュータで動作する複数のプロセスが夫々実行する処理の実行順序を制御する制御プロセスが、当該制御プロセス及び前記プロセスによりアクセス可能な記憶手段に含まれる所定の記憶領域の複数の箇所に対して、ロックを実行し、

前記プロセスが、前記制御プロセスによりロックが実行された前記記憶領域のうち、各プロセスの自処理の実行順序に対応する箇所に対してロックを要求し、

前記制御プロセスが、前記プロセスからの前記ロックの要求を前記実行順序に対応する前記箇所毎に前記ロックが解放されるまで待機状態とし、

30

前記制御プロセスが、前記プロセスによりロックが要求された箇所のロックを、前記処理の前記実行順序と対応させて順次解放する処理をコンピュータに実行させる処理順序制御プログラム。

#### 【請求項7】

複数のプロセスが夫々処理を実行する処理実行部と、

前記処理の実行順序を制御する制御プロセスを実行する制御プロセス実行部とを含み、

前記制御プロセスが、当該制御プロセス及び前記プロセスによりアクセス可能な記憶手段に含まれる所定の記憶領域の複数の箇所に対して、ロックを実行し、

前記プロセスが、前記制御プロセスによりロックが実行された前記記憶領域のうち、各プロセスの自処理の実行順序に対応する箇所に対してロックを要求し、

40

前記制御プロセスが、前記プロセスからの前記ロックの要求を前記実行順序に対応する前記箇所毎に前記ロックが解放されるまで待機状態とし、

前記制御プロセスが、前記プロセスによりロックが要求された箇所のロックを、前記処理の前記実行順序と対応させて順次解放する処理順序制御装置。

#### 【発明の詳細な説明】

#### 【技術分野】

#### 【0001】

本発明は、コンピュータにおいて、一連の複数処理を順次実行する技術に関する。

50

**【背景技術】****【0002】**

コンピュータにおいて複数処理を実行する技術がある。その一例として、プログラムの1つのメインスレッドに、そのスレッドが現在その資源の使用を必要とするか否かに関わらず、その資源に関連するロックの所有権を与えることにより、他のスレッドにまさる優先権を与える技術が提案されている。当該技術では、メインスレッドは、資源を使用し終え、別のスレッドが資源を使用するために待っていることを検知すると、その資源についての資源ロックを解放する。

**【0003】**

ここで、コンピュータにおいて複数処理を順次実行する方法の一例として、処理を実行するプロセス同士で連携し、ある処理が終了すると、当該処理を実行するプロセスが次の実行順序の処理を実行するプロセスに対し処理の開始指示を行う方法がある。また、他の一例として、複数の処理の実行順序を制御する制御プロセスが、各処理を実行するプロセスに対して順次処理の開始指示を行う方法がある。

10

**【先行技術文献】****【特許文献】****【0004】**

**【特許文献1】特開平9-198265号公報**

**【発明の概要】****【発明が解決しようとする課題】**

20

**【0005】**

しかし、上記のような方法では、例えばシステムの更新等に伴って処理の実行順序を変更する際に、少なくとも、各処理を実行するプロセスや制御プロセスが行う開始指示の相手先（次に実行する処理）を変更する作業が発生する。また、例えば、各処理を実行するプロセス構成やコンピュータを変更する際等にも、必要に応じて各処理を実行するプロセスや制御プロセスの開始指示の相手先の詳細設定等を変更する作業が発生する。このため、システムの更新を柔軟に行なうことが難しい。

**【0006】**

そこで、本技術は、1つの側面において、複数の処理を順次実行するシステムにおけるシステムの更新を容易にすることを目的とする。

30

**【課題を解決するための手段】****【0007】**

本技術における1つの側面では、1又は複数のコンピュータで動作する複数のプロセスが夫々実行する処理の実行順序を制御する制御プロセスが、当該制御プロセス及び前記プロセスによりアクセス可能な記憶手段に含まれる所定の記憶領域の複数箇所に対して、ロックを実行する。そして、プロセスが、制御プロセスによりロックが実行された記憶領域のうち、各プロセスの自処理の実行順序に対応する箇所に対してロックを要求する。さらに、制御プロセスが、プロセスからのロックの要求を実行順序に対応する箇所毎にロックが解放されるまで待機状態とする。制御プロセスが、プロセスによりロックが要求された箇所のロックを、上記処理の実行順序と対応させて順次解放する。

40

**【発明の効果】****【0008】**

本技術における1つの側面によれば、複数の処理を順次実行するシステムにおけるシステムの更新を容易にことができる。

**【図面の簡単な説明】****【0009】**

**【図1】コンピュータにおいて複数の処理を実行するシステム構成の一例を示す図である。**

**【図2】処理の実行順序の制御の概要の説明図である。**

**【図3】処理の実行順序の制御の一例の説明図である。**

50

【図4】処理の実行順序の制御の一例の説明図である。

【図5】制御プロセス及び各処理が実行する、処理の実行順序の制御処理の一例のフローチャートである。

【図6】ファイルの領域における各処理に対応する箇所の配置の一例の説明図である。

【図7】コンピュータにおいて複数の処理を実行するシステム構成の一例を示す図である。

【図8】コンピュータにおいて複数の処理を実行するシステム構成の一例を示す図である。

【図9】処理の実行順序の制御の一例の説明図である。

【図10】処理の実行順序の制御の一例の説明図である。

10

【図11】処理の実行順序の制御の一例の説明図である。

【図12】処理の実行順序の制御の一例の説明図である。

【図13】処理の実行順序の制御の一例の説明図である。

【図14】制御プロセス及び各処理が実行する、処理の実行順序の制御処理の一例のフローチャートである。

【図15】ハードウェア構成の一例の説明図である。

【図16】複数処理の実行順序の制御を行う技術の一例の説明図である。

【図17】複数処理の実行順序の制御を行う技術の一例の説明図である。

【発明を実施するための形態】

【0010】

20

本明細書で説明する技術は、複数処理を順次実行するシステムにおける処理の実行順序の制御を、記憶手段の任意の領域に対してロックをかけて排他制御を行うことができるファイルロックの技術を用いて行うことで、処理の実行順序の変更等を容易にする。なお、本明細書において「システム」とは、コンピュータを用いて処理を実行する構成全般を示し、処理を実行するコンピュータは1台であっても複数であってもよい。また、本明細書で説明するプロセスと処理との関係は全て一例に過ぎず、各処理を実行するプロセス構成は任意である。

【0011】

【各種処理方法の問題点等】

まず、コンピュータによって複数処理を順次実行する複数の方法の例についていくつか列挙し、その問題点について説明する。ここでは、プロセスAの処理A、プロセスBの処理B、プロセスCの処理Cの順で処理を実行する場合における種々の方法について説明する。

30

【0012】

例えば、図16に示すように、処理を実行するプロセス同士が連携する方法1がある。方法1では、プロセスA901は、処理Aの実行が完了すると、処理Bを実行するプロセスB902に対して通信を行い、処理Bの開始指示を通知する(911)。プロセスB902は、当該開始指示を受けて処理Bを実行し、処理Bの実行が完了すると、処理Cを実行するプロセスC903に対して通信を行い、処理Cの開始指示を通知する(912)。

【0013】

40

しかし、この方法では、処理の実行順序を変更したい場合に、順序の変更を柔軟に行なうことが難しい。例えば、処理Aと処理Bの間に、新たにプロセスDが実行する処理Dを追加するような場合、原則としてプロセスA901の通信論理の変更が必要となる。なお、「通信論理の変更」には、例えば、次に開始指示をする処理の変更をはじめ、変更後において次に実行される処理が変更前と異なるコンピュータで実行される場合には、通信先のコンピュータの変更を含め、必要に応じた通信プロトコル等の変更が含まれる。

【0014】

さらに他の方法として、同じく図16に示すように、制御プロセス904が、夫々の処理の実行順序や処理を実行するプロセスの情報を把握し、各プロセスと通信を行う方法2がある。方法2では、制御プロセス904は、プロセスA901に対して通信を行い、処

50

理 A の開始指示を通知する(921)。プロセス A 901 は、処理 A が完了すると、制御プロセス 904 に対して処理 A の完了を通知する(922)。すると、制御プロセス 904 は、プロセス B 902 に対して処理 B の開始指示を通知する(923)。以下同様にして、図 16 に示す 924 ~ 926 を経て、処理 B の次に処理 C が実行される。

#### 【0015】

しかし、この方法 2 でも、処理の実行順序を変更したい場合に、順序の変更を柔軟に行なうことが難しい。処理の実行順序を変更するには、原則として少なくとも制御プロセスの通信論理の変更が必要となるからである。

#### 【0016】

また、プロセス間における通信を不要とする方法として、図 17 に示すように、管理テーブル 906において各処理の実行順序を一元管理し、各プロセスが、夫々管理テーブル 906 を参照しながら順次処理の実行を開始する方法 3 がある。方法 3 では、プロセス A 901 ~ プロセス C 903 の夫々が管理テーブルにアクセスし、自プロセスが実行する処理の実行可否フラグが「true」であることを検出すると、実行を開始する。例えば、処理 A の実行可否フラグが「true」の場合、プロセス A 901 が、処理 A の実行を開始する(931)。そして、プロセス A 901 は、処理 A の完了後に管理テーブルにおける処理 A に対応する実行可否フラグを「false」にし、次の実行順序の処理 B に対応する実行可否フラグを「true」にする(932)。するとプロセス B 902 が、処理 B の実行可否フラグが「true」になったことを検出して実行を開始する(933)。以下同様にして、図 17 に示す 934 ~ 936 を経て、処理 B の次に処理 C が実行される。

10

20

#### 【0017】

この方法 C では、プロセス同士が直接通信を行わないため、処理の実行順序を変更する場合に、プロセスの通信論理の変更が原則として不要である。しかし、方法 C では、管理テーブル 904 に情報が集中するため、ファイル破壊等により管理テーブル 904 のデータに不具合が生じると、各処理の実行順序の制御が困難になる。また、複数のプロセスが管理テーブル 904 に同時にアクセスするため、データの不整合が発生し易い。さらには、処理実行中に管理テーブル 904 のデータを変更して処理の実行順序を変更する場合、実行中の処理と管理テーブル 904 のデータとの不整合も発生し易く、処理に誤動作が生じることもある。

以下に説明する技術は、上記のような問題点を解決するものである。以下、実施例を示して説明する。

30

#### 【0018】

##### [第 1 実施例]

##### <システム構成>

図 1 は、第 1 実施例におけるシステム構成を示す。本実施例では、システムが、サーバ 1 を備える。サーバ 1 では、プログラムがロードされて実行されることによって実現される、制御プロセス実行部 10 が実行する制御プロセス 11 が動作するとともに、処理実行部 20 が実行するプロセス A 21、プロセス B 22 及びプロセス C 23 が動作している。プロセス A 21 は処理 A を、プロセス B 22 は処理 B を、プロセス C 23 は処理 C を夫々実行する。

40

#### 【0019】

また、サーバ 1 が備える記憶手段 30 が、ファイル 31 を備える。記憶手段 30 には、制御プロセス 11 及びプロセス A 21 ~ プロセス C 23 がアクセスすることができ、ファイル 31 には、制御プロセス 11 及びプロセス A 21 ~ プロセス C 23 が、ファイル 31 に含まれる所定の領域に対してロックを実行することができる。当該所定の領域は、ユーザ等が任意に設定することができる。

#### 【0020】

##### <処理の実行順序の制御の概要>

ここで、第 1 実施例で実現する処理の実行順序の制御の概要について、図 2 ~ 図 4 を参照して説明する。本説明では、プロセス A の処理 A、プロセス B の処理 B、プロセス C の

50

処理 C の順に実行する例を示して説明する。また、当該制御において、処理 A、処理 B、処理 C は、夫々、ファイル 3 1 の 1 バイト目、2 バイト目、3 バイト目を、実行順序の制御の対象領域として使用するものとする。換言すれば、ファイル 3 1 のうち、処理 A、処理 B、処理 C に対応する箇所が夫々 1 バイト目、2 バイト目、3 バイト目であり、これらの箇所は処理 A、処理 B、処理 C の実行順序に対応させて配置されている。図 2 ~ 図 4 に示す 101 ~ 109 では、ファイル 3 1 に対してロックをする処理及びロックをしている状態を実線矢印、ロック要求が Wait (待機) 状態となる処理及び Wait 状態を破線矢印、アンロックをする処理をロック矢印 (白色矢印) で示す。また、以下、本明細書において、「処理」が行うこととして記載している内容は、「処理を実行するプロセス」が行うことと同義とする。

10

#### 【0021】

(101) 制御プロセス 1 1 は、ファイル 3 1 の 1 バイト目～3 バイト目をロックする。  
 (102) 処理 A～処理 C が、夫々ファイル 3 1 の 1 バイト目～3 バイト目に対してロックを要求する。しかし、すでに(101)で制御プロセス 1 1 によりロックされているため、処理 A～処理 C によるロック要求は Wait 状態となる。

#### 【0022】

(103) 制御プロセス 1 1 が、ファイル 3 1 の 1 バイト目をアンロックする。すると、処理 A による 1 バイト目のロック要求の Wait 状態が解除される。  
 (104) 処理 A は、(103)でファイル 3 1 の 1 バイト目のロック要求の Wait 状態が解除されると同時に 1 バイト目をロックする。そして、処理 A は、処理 A 本体の実行を開始する。

20

#### 【0023】

(105) 制御プロセス 1 1 は、ファイル 3 1 の 1 バイト目に対して再度ロックを要求する。しかし、1 バイト目は(104)ですでに処理 A によりロックされているため、制御プロセス 1 1 によるロック要求は Wait 状態となる。  
 (106) 処理 A は、処理 A 本体の実行が終了すると、1 バイト目をアンロックする。すると、制御プロセス 1 1 による 1 バイト目のロック要求の Wait 状態が解除される。

#### 【0024】

(107) 制御プロセス 1 1 は、(106)でファイル 3 1 の 1 バイト目のロック要求の Wait 状態が解除されると、同時に 1 バイト目をロックする。  
 (108) 制御プロセス 1 1 は、次に 2 バイト目をアンロックする。すると、処理 B による 2 バイト目のロック要求の Wait 状態が解除される。  
 (109) 処理 B は、(108)で 2 バイト目のロック要求の Wait 状態が解除されると、同時に 2 バイト目をロックする。そして、処理 B は、処理 B 本体の実行を開始する。  
 以降、同様にして、処理 B に続いて処理 C が実行される。

30

#### 【0025】

<処理フロー・チャートの説明>

図 5 は、制御プロセス 1 1 及び各処理のうちの 1 つの処理である処理 n が実行する、処理の実行順序の制御処理の一例につき、フロー・チャート及びファイル 3 1 の領域例を用いて説明した図である。ステップ S 1 ~ ステップ S 7 が制御プロセス 1 1 による処理を示し、ステップ S 1 1 ~ ステップ S 1 4 が処理 n による処理を示す。当該説明では、処理 n は、ファイル 3 1 のうち n バイト目に対してロックをかけるものとして説明する。なお、図 5 では、処理 n を実行するプロセスの図示は省略する。

40

#### 【0026】

ステップ S 1 で、制御プロセス 1 1 が、処理の実行順序の制御に用いるファイル 3 1 の対象領域の全バイトをロックする。

一方、ステップ S 1 1 で、処理 n が、自処理の実行順序に対応する n バイト目に対してロックを要求する。しかし、制御プロセス 1 1 がすでに n バイト目を含めた対象領域の全バイトをロックしているため、処理 n のロック要求は Wait 状態となる。

#### 【0027】

50

ステップS2で、制御プロセス11が、変数iに1をセットする。なお、ステップS2とステップS11とはどちらが先でもよい。

ステップS3で、制御プロセス11が、iバイト目をアンロックする。

#### 【0028】

ここで、iがnに等しいとき、処理nは、nバイト目に対するロック要求のWait状態が解除され、ステップS12で、nバイト目のロックに成功する。そして、処理nは、ステップS13で、処理n本体の処理を実行する。

#### 【0029】

一方、ステップS4で、制御プロセス11が、iバイト目(=nバイト目)に対してロックを要求する。しかし、処理nがすでにnバイト目をロックしているため、制御プロセス11によるiバイト目に対するロック要求はWait状態となる。なお、ステップS13とステップS4とはどちらが先でもよい。10

#### 【0030】

処理nは、処理n本体の処理の実行が終了すると、ステップS14で、領域のnバイト目をアンロックする。

すると、制御プロセス11は、iバイト目に対するロックのWait状態が解除され、ステップS5で、iバイト目のロックに成功する。

#### 【0031】

ステップS6で、制御プロセス11は、変数iが最大値(max)であるか否かを判定する。この最大値は、実行順序の制御対象となる処理の数の最大数として見込まれる値であり、例えばユーザが予め指定しておくことができる。変数iが最大値であれば(Yes)、処理を終了し、変数iが最大値でなければ(No)、ステップS7に進む。20

#### 【0032】

ステップS7で、制御プロセス11は、変数iに1を加算してステップS3に戻り、ファイル31の次の箇所の処理を開始する。

なお、処理nがiバイト目に対してロックをかけない場合、制御プロセス11はステップS4でiバイト目にロック要求をかけ、すぐにステップS5でロックに成功することができる。この場合、制御プロセスは、ステップS6～ステップS7を経て、ファイルの次の箇所の処理を開始する。

#### 【0033】

<本実施例による効果、変形例等>

本技術では、このように複数の処理を順次実行するときに、ファイルロックの機能を用いて処理の実行順序を制御することにより、次のような効果を奏する。すなわち、本技術では、各処理を実行するプロセスは、記憶手段30のファイル31の対象領域のうち、自プロセスが実行する処理の実行順序に対応する箇所に対してロック又はアンロックを行うだけであり、他の処理やプロセスとの通信を行わない。一方、制御プロセス11も同様であり、ファイル31の対象領域に各処理の実行順序に対応させて配置された箇所に対して、実行順序と対応させて順次ロック又はアンロックを行うだけである。このように、各プロセスが疎に連携しているため、システムの更新によりプロセスの構成や処理の実行順序等を変更する場合に、変更作業が容易となる。具体的には、例えば、プロセスの構成を変更する場合であっても、実行順序の制御に伴うプロセスの通信論理を変更する必要がない。また、例えば、処理の実行順序を変更する場合には、各処理がロックをする領域を必要に応じて変更するだけでよい。40

#### 【0034】

ここで、各処理に対応する箇所は、予め少なくとも1つの処理の実行順序に対応する箇所分の間隔を空けておいてもよい。そして、新たな処理を途中に追加する場合に、新たな処理がその空いている領域のうちの1箇所に対応するようにすれば(すなわち、新たな処理を実行するプロセスがその空いている領域のうちの1箇所にロックをかけるようにすれば)、他のプロセスや処理に対する変更が一切必要ない。その具体例を図6に示す。この例では、処理の実行順序の制御に用いる対象領域として、ファイル31の1バイト目～1

0 バイト目を確保しておき、処理 A が 1 バイト目、処理 B が 5 バイト目、処理 C が 10 バイト目にロックをかけるように、各処理に対応する箇所を配置する。この状態において、処理 B と処理 Cとの間に新たにプロセス D 2 4 の処理 D を追加する場合、例えば、処理 D が 7 バイト目をロックするようになる。このようにすれば、制御プロセス 1 1 やプロセス A 2 1 ~ プロセス C 2 3 の処理 A ~ 処理 C に一切変更を加えることなく、処理 A、処理 B、処理 D、処理 C の順に処理が実行されることとなる。

#### 【 0 0 3 5 】

また、各処理がロックをする箇所を必要に応じて変更するだけで処理の実行順序を変更できるため、処理の実行中に他の処理の実行順序を変更しても、不整合が発生しづらい。

さらに、当該処理の実行順序の制御において使用する記憶領域は、単にロック又はアンロックされるだけであって、処理の実行順序を制御するための情報を持つ必要がないため、データの内容が破壊されることによる不整合も発生しづらい。

10

#### 【 0 0 3 6 】

このため、本技術によれば、処理の実行順序の変更が容易になり、システムの更新にかかる工数を大幅に削減することができる。

なお、各処理の実行順序の制御に用いる記憶手段の対象領域は、ファイル形式に限らず、いかなる態様であってもよい。

#### 【 0 0 3 7 】

ここで、上記説明では、1つのサーバ 1 内で制御プロセス 1 1 並びにプロセス A 2 1 の処理 A、プロセス B 2 2 の処理 B 及びプロセス C 2 3 の処理 C が動作し、かつ、ファイル 3 1 も同一サーバにある例を用いて説明した。しかし、システム構成の変形例として、複数のサーバから参照可能な共有ファイルを設けることにより、各プロセスや処理が複数の異なるサーバで動作していても、同様の処理を実現することができる。そのようなシステムの一例を、図 7 に示す。図 7 に示すシステムでは、制御プロセス 1 1 が動作するサーバ 1 - 1 と、プロセス A 2 1 の処理 A、プロセス B 2 2 の処理 B が動作するサーバ 1 - 2 と、プロセス C 2 3 の処理 C が動作するサーバ 1 - 3 とを備える。そして、サーバ 1 - 1 ~ サーバ 1 - 3 と夫々ネットワーク接続され、制御プロセス 1 1 及び各プロセスが夫々アクセス可能な記憶手段 3 2 が、制御プロセス 1 1 及び各プロセスによる共有ファイル 3 3 を備える。このようなシステムにおいても、共有ファイル 3 3 を上記説明のファイル 3 1 と同様に用いることにより、上記と同様の処理を実現することができる。また、図示を省略するが、共有ファイルが、制御プロセス 1 1 又はいずれかの処理が実行されるサーバ内に存在しても、上記と同様の処理を実現することができる。

20

#### 【 0 0 3 8 】

#### [ 第 2 実施例 ]

第 2 実施例は、第 1 実施例と異なり、実行順序の制御対象となる処理を実行する全てのプロセスが共通してアクセスする記憶手段を設けることができない場合であっても、処理の実行順序の制御を実現するものである。

#### 【 0 0 3 9 】

図 8 は、第 2 実施例におけるシステム構成を示す。本実施例では、システムが、マスター・サーバ 2 、サーバ 3 - 1 及びサーバ 3 - 2 を備える。

30

マスター・サーバ 2 では、サーバ 3 - 1 及びサーバ 3 - 2 で夫々動作する制御プロセス 1 5 と通信可能であり制御プロセス 1 5 の夫々に対して動作指示を行う、総合制御プロセス 実行部 1 2 が実行する総合制御プロセス 1 3 が動作する。

#### 【 0 0 4 0 】

サーバ 3 - 1 では、制御プロセス 実行部 1 4 - 1 が実行する制御プロセス 1 5 - 1 が動作するとともに、処理実行部 2 0 - 1 が実行するプロセス A 2 1 及びプロセス C 2 3 が動作している。プロセス A は処理 A を、プロセス C は処理 C を夫々実行する。さらに、サーバ 3 - 1 が備える記憶手段 3 0 - 1 が、ファイル 3 1 - 1 を備える。制御プロセス 1 5 - 1 、プロセス A 2 1 で動作する処理 A 及びプロセス C 2 3 で動作する処理 C が、夫々ファイル 3 1 - 1 にアクセスすることができ、ファイル 3 1 - 1 に含まれる特定の箇所に対し

40

50

てロックをすることができる。

#### 【0041】

サーバ3-2では、同様に、制御プロセス実行部14-2が実行する制御プロセス15-2が動作するとともに、処理実行部20-2が実行するプロセスB22が動作している。プロセスB22は処理Bを実行する。さらに、サーバ3-2が備える記憶手段30-2が、ファイル31-2を備える。制御プロセス15-2、プロセスB22で動作する処理Bが、ファイル31-2にアクセスすることができ、ファイル31-2に含まれる特定の箇所に対してロックをすることができる。

#### 【0042】

ここで、第2実施例で実現する処理の概要について、図9～図13を参照して説明する。本説明では、処理A、処理B、処理Cの順に実行する例を示して説明する。また、当該制御において、処理A及び処理Cは夫々ファイル31-1の1バイト目及び3バイト目を、処理Bは、ファイル31-2の2バイト目を、実行順序の制御に使用するものとする。換言すれば、処理A及び処理Cに対応する箇所が、ファイル31-1のうち、夫々1バイト目及び3バイト目であり、処理Bに対応する箇所が、ファイル31-2のうち、2バイト目である。これらの箇所は処理A、処理B、処理Cの実行順序に対応させて配置されている。図9～図13に示す111～123では、ファイル31-1又はファイル31-2に対してロックをする処理及びロックをしている状態を実線矢印、ロックがWait(待機)状態となる処理及びWait状態を破線矢印、アンロックをする処理をブロック矢印(白色矢印)で示す。さらに、マスターサーバ2の総合制御プロセス13から各サーバ3の制御プロセス15への指示を、一点鎖線矢印で示す。

10

#### 【0043】

(111)サーバ3-1の制御プロセス15-1は、ファイル31-1の1バイト目～3バイト目をロックする。また、サーバ3-2の制御プロセス15-2も同様に、ファイル31-2の1バイト目～3バイト目をロックする。

(112)サーバ3-1で動作する処理A及び処理Cが、夫々ファイル31-1の1バイト目及び3バイト目に対してロックを要求する。しかし、すでに(111)で制御プロセス15-1によりロックされているため、処理A及び処理Cによるロック要求はWait状態となる。一方、サーバ3-2で動作する処理Bも、ファイル31-2の2バイト目に対してロックを要求する。しかし、同様に、すでに(111)で制御プロセス15-2によりロックされているため、処理Bによるロック要求はWait状態となる。

20

#### 【0044】

(113)ここで、マスターサーバ2の総合制御プロセス13が、全サーバの制御プロセス15に対し、各サーバのファイル31の1バイト目をアンロックするように指示を送信する。その後、総合制御プロセス13は、全サーバからファイル31の1バイト目の再ロックが成功した旨の通知を受信するまで待機する。

(114)サーバ3-1の制御プロセス15-1が、ファイル31-1の1バイト目をアンロックする。すると、処理Aによる1バイト目のロック要求のWait状態が解除される。一方、サーバ3-2の制御プロセス15-2も、ファイル31-2の1バイト目をアンロックする。

30

#### 【0045】

(115)サーバ3-1の処理Aは、(114)で1バイト目のロック要求のWait状態が解除されると即時にファイル31-1の1バイト目をロックする。そして、処理Aは、処理A本体の実行を開始する。

(116)サーバ3-1の制御プロセス15-1が、ファイル31-1の1バイト目に対して再度ロックを要求する。しかし、1バイト目は(115)ですでに処理Aによりロックされているため、制御プロセス15-1によるロック要求はWait状態となる。一方、サーバ3-2の制御プロセス15-2が、ファイル31-2の1バイト目に対して再度ロックを要求する。ファイル31-2の1バイト目は他の処理によってロックされていないため、制御プロセス15-2は、再ロックに成功する。

40

50

**【0046】**

(117) サーバ3-2の制御プロセス15-2は、ファイル31-2の1バイト目の再ロックに成功したことを、マスターサーバ2の総合制御プロセス13に通知する。

(118) サーバ3-1の処理Aは、処理A本体の実行が終了すると、ファイル31-1の1バイト目をアンロックする。すると、制御プロセス15-1によるファイル31-1の1バイト目のロック要求のWait状態が解除される。

**【0047】**

(119) サーバ3-1の制御プロセス15-1は、(118)でファイル31-1の1バイト目のロック要求のWait状態が解除されると、同時にファイル31-1の1バイト目をロックする。

(120) サーバ3-1の制御プロセス15-1は、ファイル31-1の1バイト目の再ロックに成功したことを、マスターサーバ2の総合制御プロセス13に通知する。

**【0048】**

(121) マスターサーバ2の総合制御プロセス13が、全サーバの制御プロセスに対し、各サーバのファイル31の2バイト目をアンロックするように指示を送信する。その後、総合制御プロセス13は、全サーバからファイル31の2バイト目の再ロックが成功したことの通知を受信するまで待機する。

(122) サーバ3-1の制御プロセス15-1が、ファイル31-1の2バイト目をアンロックする。一方、サーバ3-2の制御プロセス15-2も、ファイル31-2の2バイト目をアンロックする。すると、処理Bによるファイル31-2の2バイト目のロック要求のWait状態が解除される。

**【0049】**

(123) サーバ3-2の処理Bは、(122)でファイル31-2の2バイト目のロック要求のWait状態が解除されると同時にファイル31-2の2バイト目をロックする。そして、処理Bは、処理B本体の実行を開始する。

**【0050】**

以降、同様にして、サーバ3-2の処理Bに続いて、サーバ3-1の処理Cが実行される。

なお、制御プロセスは、上記(111)の処理も、総合制御プロセス13の指示によって行ってもよい。

**【0051】**

<処理フローチャートの説明>

図14は、マスターサーバ2の総合制御プロセス13、各サーバ3の制御プロセス15及び各処理のうちの1つの処理である処理nが実行する処理の一例につき、フローチャート及びファイルの領域例を用いて説明した図である。ステップS31～ステップS35が総合制御プロセス13による処理を示す。また、ステップS41～ステップS46が制御プロセス15による処理を示し、ステップS51～ステップS54が処理nによる処理を示す。当該説明では、処理nは、ファイルのうちnバイト目に対してロックをかけるものとして説明する。なお、図13及び図13を参照した説明では、処理nが含まれるプロセスについての記載は省略する。

**【0052】**

ステップS41で、制御プロセス15が、処理の実行順序の制御に用いるファイル31の対象領域の全バイトをロックする。

一方、ステップS51で、処理nが、処理nの実行順序に対応するnバイト目に対してロックを要求する。しかし、制御プロセス15がすでにnバイト目を含めた対象領域の全バイトをロックしているため、処理nのロック要求はWait状態となる。

**【0053】**

ステップS31で、総合制御プロセス13が、変数iに1をセットする。なお、ステップS41及びステップ51と、ステップS31とはどちらが先になってもよい。

ステップS32で、マスターサーバ2の総合制御プロセス13が、全サーバの制御プロ

10

20

30

40

50

セス 1 5 に対し、各サーバのファイル 3 1 の  $i$  バイト目をアンロックするように指示を送信する。その後、総合制御プロセス 1 3 は、全サーバからファイル 3 1 の  $i$  バイト目の再ロックが成功したことの通知を受信するまで待機する。

#### 【 0 0 5 4 】

一方、ステップ S 4 2 で、制御プロセス 1 5 が、マスターサーバ 2 の総合制御プロセス 1 3 からのステップ S 3 2 の指示を受信する。当該指示を受け、ステップ S 4 3 で、制御プロセス 1 5 が、 $i$  バイト目をアンロックする。

#### 【 0 0 5 5 】

ここで、 $i$  が  $n$  に等しいとき、処理  $n$  は、 $n$  バイト目に対するロック要求の W a i t 状態が解除され、ステップ S 5 2 で、 $n$  バイト目のロックに成功する。そして、処理  $n$  は、10 ステップ S 5 3 で、処理  $n$  本体の処理を実行する。

#### 【 0 0 5 6 】

一方、ステップ S 4 4 で、制御プロセス 1 5 が、 $i$  バイト目 ( $= n$  バイト目) に対してロックを要求する。しかし、処理  $n$  がすでに  $n$  バイト目をロックしているため、制御プロセス 1 5 による  $i$  バイト目に対するロック要求は W a i t 状態となる。なお、ステップ S 5 3 とステップ S 4 4 とはどちらが先になってもよい。

#### 【 0 0 5 7 】

処理  $n$  は、処理  $n$  本体の処理の実行が終了すると、ステップ S 5 4 で、領域の  $n$  バイト目をアンロックする。

すると、制御プロセス 1 5 は、 $i$  バイト目に対するロック要求の W a i t 状態が解除され、ステップ S 4 5 で、 $i$  バイト目のロックに成功する。そして、ステップ S 4 6 で、総合制御プロセス 1 3 に対し、 $i$  バイト目のロックが成功したことを通知する。20

#### 【 0 0 5 8 】

ステップ S 3 4 で、総合制御プロセス 1 3 は、変数  $i$  が最大値 ( m a x ) であるか否かを判定する。変数  $i$  が最大値であれば ( Y e s ) 、処理を終了し、変数  $i$  が最大値でなければ ( N o ) 、ステップ S 3 5 に進む。

ステップ S 3 5 で、総合制御プロセス 1 3 は、変数  $i$  に 1 を加算してステップ S 3 2 に戻り、ファイル 3 1 の次の箇所の処理を開始する。

#### 【 0 0 5 9 】

<本実施例による効果等>

30

第 2 実施例によれば、第 1 実施例で説明した効果に加えて、次のような効果を奏する。すなわち、複数の異なるサーバで処理が実行されている場合において、各処理からアクセス可能な記憶手段や共有ファイルが存在しないシステム構成であっても、ファイルロックの機能を用いた処理の実行順序の制御が可能となる。

#### 【 0 0 6 0 】

<本実施例による効果、変形例等>

なお、上記説明では、総合制御プロセス 1 3 が、各処理を実行するサーバ 3 とは別のマスターサーバ 2 で動作していたが、各処理を実行する全てのサーバ 3 と通信可能であれば、総合制御プロセス 1 3 は、例えばサーバ 3 のうちのいずれかで動作していてもよい。

その他の変形例等については、第 1 実施例と同様である。

40

#### 【 0 0 6 1 】

#### [ ハードウェア構成 ]

図 1 5 は、前述の各実施例のサーバやマスターサーバとして機能する情報処理装置のハードウェア構成の一例を示す。本情報処理装置は、プロセッサ 1 0 1 、メモリ 1 0 2 、ストレージ 1 0 3 、可搬記憶媒体駆動装置 1 0 4 、入出力装置 1 0 5 及び通信インタフェース 1 0 6 を備える。

#### 【 0 0 6 2 】

プロセッサ 1 0 1 は、制御ユニット、演算ユニット及び命令デコーダ等を含み、実行ユニットが、命令デコーダで解読されたプログラムの命令に従い、制御ユニットより出力される制御信号に応じ、演算ユニットを用いて算術・論理演算を実行する。かかるプロセッ50

サ 1 0 1 は、制御に用いる各種情報が格納される制御レジスタ、既にアクセスしたメモリ 2 等の内容を一時的に格納可能なキャッシュ、及び、仮想記憶のページテーブルのキャッシュとしての機能を果たす T L B を備える。なお、プロセッサ 1 0 1 は、 C P U (Central Processing Unit) コアが複数設けられている構成でもよい。

#### 【 0 0 6 3 】

メモリ 1 0 2 は、例えば R A M ( Random Access Memory ) 等の記憶装置であり、プロセッサ 1 0 1 で実行されるプログラムがロードされるとともに、プロセッサ 1 0 1 の処理に用いるデータが格納されるメインメモリである。また、ストレージ 1 0 3 は、例えば H D D ( Hard Disk Drive ) やフラッシュメモリ等の記憶装置であり、プログラムや各種データが格納される。可搬記憶媒体駆動装置 1 0 4 は、可搬記憶媒体 1 0 7 に記憶されたデータやプログラムを読み出す装置である。可搬記憶媒体 1 0 7 は、例えば磁気ディスク、光ディスク、光磁気ディスク又はフラッシュメモリ等である。プロセッサ 1 0 1 は、メモリ 1 0 2 やストレージ 1 0 3 と協働しつつ、ストレージ 1 0 3 や可搬記憶媒体 1 0 7 に格納されたプログラムを実行する。なお、プロセッサ 1 0 1 が実行するプログラムや、アクセス対象となるデータは、当該情報処理装置と通信可能な他の装置に格納されていてもよい。なお、上記各実施例で記載した記憶手段 3 0 とは、メモリ 1 0 2 、ストレージ 1 0 3 及び可搬記憶媒体 1 0 7 若しくは当該情報処理装置と通信可能な他の装置の少なくともいずれかを示す。

#### 【 0 0 6 4 】

入出力装置 1 0 5 は例えばキーボード等やディスプレイ等であり、ユーザ操作等による動作命令を受け付ける一方、情報処理装置による処理結果を出力する。通信インターフェース 1 0 6 は例えば L A N ( Local Area Network ) カード等であり、外部とのデータ通信を可能にする。前述した情報処理装置の各構成要素は、バス 1 0 8 で接続されている。

#### 【 0 0 6 5 】

##### [ その他 ]

本明細書で説明した情報処理装置の機能的構成及び物理的構成は、上述の態様に限るものではなく、例えば、各機能や物理資源を統合して実装したり、逆に、さらに分散して実装したりすることも可能である。

#### 【 0 0 6 6 】

以上の実施形態に関し、更に以下の付記を開示する。

##### ( 付記 1 )

1 又は複数のコンピュータで動作する 1 又は複数のプロセスが実行する複数の処理の実行順序を制御する制御プロセスが、当該制御プロセス及び前記プロセスがアクセス可能な記憶手段に含まれる所定の記憶領域に対してロックを実行し、

前記プロセスが、前記制御プロセスによりロックが実行された前記記憶領域のうち、前記複数の処理の実行順序に対応した箇所に対してロックを要求し、

前記制御プロセスが、前記プロセスによりロックが要求された箇所のロックを、前記複数の処理の実行順序と対応させて順次解放し、

前記プロセスが、要求していたロックが実行できると、当該箇所に対応する処理を実行する

処理を含んだ処理順序制御方法。

#### 【 0 0 6 7 】

##### ( 付記 2 )

前記プロセスが、処理の実行を終了したときに、当該処理に対応する箇所に対するロックを解放し、

前記ロックを順次解放する処理は、前記制御プロセスが、前記プロセスにより実行を終了した処理に対応する箇所に対するロックが解放されると、当該箇所に対するロックを再実行し、当該箇所に対応する実行順序の次の実行順序に対応する箇所のロックを解放する、付記 1 記載の処理順序制御方法。

#### 【 0 0 6 8 】

10

20

30

40

50

## (付記3)

前記複数の処理が複数のコンピュータで実行され、前記制御プロセスが前記複数のコンピュータの夫々で動作し、

前記制御プロセスの夫々と通信可能な総合制御プロセスが、前記制御プロセスの夫々に対し、前記記憶領域のうち前記制御プロセスの夫々が実行順序を制御する処理の実行順序に対応する箇所のロックを順次解放する指示を行い、

前記ロックを順次解放する処理は、前記制御プロセスの夫々が、前記総合制御プロセスによる指示に応じて、少なくとも前記記憶領域のうち自制御プロセスが実行順序を制御する処理の実行順序に対応する箇所のロックを順次解放する、付記1又は2に記載の処理順序制御方法。

10

## 【0069】

## (付記4)

前記ロックを順次解放する指示を行う処理は、総合制御プロセスが、前記制御プロセスの夫々に対し、同時に同一の実行順序に対応する箇所のロックを解放する指示を行い、

前記ロックを順次解放する処理は、前記制御プロセスの夫々が、前記総合制御プロセスによる指示に応じて、他の制御プロセスと同一の実行順序に対応する箇所のロックを順次解放する、付記3記載の処理順序制御方法。

## 【0070】

## (付記5)

前記記憶領域のうち前記複数の処理の実行順序の夫々に対応する箇所には、少なくとも1つの処理の実行順序に対応する箇所分の間隔を空けて前記複数の処理が夫々対応付けられている、付記1又は2に記載の処理順序制御方法。

20

## 【0071】

## (付記6)

1又は複数のコンピュータで動作する1又は複数のプロセスが実行する複数の処理の実行順序を制御する制御プロセスが、当該制御プロセス及び前記プロセスがアクセス可能な記憶手段に含まれる所定の記憶領域に対してロックを実行し、

前記プロセスが、前記制御プロセスによりロックが実行された前記記憶領域のうち、前記複数の処理の実行順序に対応した箇所に対してロックを要求し、

前記制御プロセスが、前記プロセスによりロックが要求された箇所のロックを、前記複数の処理の実行順序と対応させて順次解放し、

30

前記プロセスが、要求していたロックが実行できると、当該箇所に対応する処理を実行する

処理をコンピュータに実行させる処理順序制御プログラム。

## 【0072】

## (付記7)

複数の処理を実行する1又は複数のプロセスを実行する処理実行部と、

前記複数の処理の実行順序を制御する制御プロセスを実行する制御プロセス実行部とを含み、

前記制御プロセスが、当該制御プロセス及び前記プロセスがアクセス可能な記憶手段に含まれる所定の記憶領域に対してロックを実行し、

40

前記プロセスが、前記制御プロセスによりロックが実行された前記記憶領域のうち、前記複数の処理の実行順序に対応した箇所に対してロックを要求し、

前記制御プロセスが、前記プロセスによりロックが要求された箇所のロックを、前記複数の処理の実行順序と対応させて順次解放し、

前記プロセスが、要求していたロックが実行できると、当該箇所に対応する処理を実行する

処理順序制御装置。

## 【符号の説明】

## 【0073】

50

1、3…サーバ、2…マスターサーバ、10…制御プロセス実行部、11…制御プロセス  
、20…処理実行部、21…プロセス、30、32…記憶手段、31、33…ファイル

【図1】



【図2】



【図3】



【図4】



【図5】



【図6】



【図7】



【図8】



【図9】



【図10】



【図 1 1】



【図 1 2】



【図 1 3】



【図 1 4】



【図15】



【図16】

方法1:処理を実行するプロセス同士が連携する方法



方法2:制御プロセスが処理の実行順序を制御する方法



【図17】

方法3:テーブルを用いて処理の実行順序を制御する方法



---

フロントページの続き

(56)参考文献 特開平04-127322(JP,A)  
特開平09-198265(JP,A)  
特開平11-065863(JP,A)  
米国特許第06779090(US,B1)  
特開2011-118587(JP,A)  
特開2011-129024(JP,A)  
国際公開第2013/063031(WO,A1)

(58)調査した分野(Int.Cl., DB名)

G 0 6 F 9 / 4 6  
9 / 4 8  
9 / 5 0 - 9 / 5 2  
9 / 5 4  
1 5 / 1 6 - 1 5 / 1 7 7