JPH04130929A - キュー管理方式 - Google Patents

キュー管理方式

Info

Publication number
JPH04130929A
JPH04130929A JP2250320A JP25032090A JPH04130929A JP H04130929 A JPH04130929 A JP H04130929A JP 2250320 A JP2250320 A JP 2250320A JP 25032090 A JP25032090 A JP 25032090A JP H04130929 A JPH04130929 A JP H04130929A
Authority
JP
Japan
Prior art keywords
event
events
group
same
key value
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
JP2250320A
Other languages
English (en)
Inventor
Hideo Matsumoto
秀男 松本
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
NEC Corp
Original Assignee
NEC Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by NEC Corp filed Critical NEC Corp
Priority to JP2250320A priority Critical patent/JPH04130929A/ja
Publication of JPH04130929A publication Critical patent/JPH04130929A/ja
Pending legal-status Critical Current

Links

Abstract

(57)【要約】本公報は電子出願前の出願データであるた
め要約のデータは記録されません。

Description

【発明の詳細な説明】 [産業上の利用分野] 本発明は、特定の処理対応のサーバを構築し。
クライアント側において特定の処理発生時にサーΔに対
してイベントとして処理を依頼し、この依頼を受けてサ
ーバ側でそのイベントの処理を実行する際に、他のイベ
ントを実行中のときKは、依頼を受けたイベントをキュ
ー(待ち行列)の形で保存し管理するキュー管理方式に
関する。
[従来の技術] 従来、依頼を受けたイベントをキューの形で保存し管理
するキュー管理方式としては、単純に次ポインタによっ
て管理する方式のものや、インデックスキーを用いた管
理方式のものが知られている。
[発明が解決しようとする課題] しかしながら、次ポインタのみKよるキュー管理におい
ては、キューの数が比較的少ない場合においては特に問
題ないが、キューの数が多くなると、キューサーチ時間
がかなシ長時間となり、特にオンラインシステム等圧お
いてはレスポンスの悪化の要因となるという欠点があっ
た。
また、インデックス管理を行う場合においては。
インデックスのバイナリサーチ等により処理の高速化は
図られるが、動的に変化するイベントのインデックスの
連続性の保証、の必要があるという不便さがあった。ま
た、一般にキューの最大数が固定であれば、あらかじめ
最大数分のインデックス領域を保持しておくことも可能
であるが、キューの数は一般に不定であるので、仮に制
約条件としてキューの最大数が既知の場合においても、
常に最大数のインデックスを用意しておくことは。
リソースの無駄と4なっていた。
本発明はこのような従来の欠点を改善したもので、その
目的は、大規模システム等において、キューの数が多い
場合でも、キューサーチ時間が著しく増加するのを防止
し、効率良くキュー管理を行うことの可能なキュー管理
方式を提供することKある。
[課題を解決するための手段] 本発明のキュー管理方式は、キーによる優先順の定義さ
れているイベントで同じキー値のイベントが大量に発生
しうる場合において、イベントのキューイング及びキュ
ーアウト処理として、イベントをシリアルにキューイン
グする次ポインタ以外に、同じキー値のイベントをグル
ープ化し、グループ対応にサーチ処理が可能となる同一
キーポインタを設け、同一キーポインタを用いることに
よりサーチ処理をスキップして行うスキップサーチ手段
と、同一キー値を持つイベントの追加時には、新規にグ
ループを構成し、すでにグルーデカ1構成されている場
合にはグループへのイベントの追加を行う同一キーポイ
ンタ管理手段とを有している。
[作用] 本発明では、同じキー値のイベントをグループ化し、グ
ループ対応にサーチ可能な同一キーポインタを設けるこ
とにより、この同一キーポインタを用いてサーチ処理を
迅速に行うことができる。
また、同一キー値をもつイベントの追加時には。
新規にグループを構成し、すでにグループが構成されて
いるときKは、このグループへのイベントの追加を行う
[実施例コ 以下、本発明について図面を参照して説明する。
wi1図は本発明の一実施例のブロック図である。
一般に、オンライントランプクシ盲ン処理等においては
、トランザクシ璽ン処理の簡略化のため。
下記のキュ一方式によシ実現することが多い。
すなわち、特定の処理対応のサーバを構築し、クライア
ント側において特定の処理発生時にはそのサーΔに対し
てイベントとして処理を依頼し。
その結果を受は取る処理方式である。この場合、サーバ
IIにおいては、処理要求の受は付けによプ。
すぐに処理可能な場合にはその′−1ま処理を実行する
ことが可能であるが、他のイベントを実行中には「待ち
」の状態となる。この場合、この「待ち」は−船釣には
要求イベントをキューの形で保存し管理される。
このキューは一般的にはFIFO(ファーストイン。
ファーストアウト)で処理場れるが、各イベントにキー
による優先順(例えば時間指定のキー等)がある場合に
は必ずしもFIFOとはならない。
また、これらのイベントが時間指定イベント(例えば、
12時にメールを送信する等)の場合においては、同じ
キー値(この場合、指定時刻の12時)のイベントが大
量に発生しうる。
このようにキーによる優先順の定義されているイベント
で、同じキー値のイベントが大量に発生することが予想
される場合にも、すなわち同一キー値のキューの数が多
くなることが予想される場合においても、キュー処理の
ためのサーチ処理時間のオーバヘッドが少なくなるよう
に1本発明では、第1図に示すように、イベントのキュ
ーイング及びキューアウト処理として、イベントをシリ
アルにキューイングする次Iインタ以外K、同じキー値
のイベントをグルービングし、グループ対応にサーチ処
理が可能となる同一キーポインタSが設けられるよう罠
なっておυ、この同一キー4インタSを用いることによ
シサーチ処理を早くするスキップサーチ手段2と、同一
キー値を持つイベントの追加時KFi、新規にグループ
を構成し、既にグループが構成されている場合にはグル
ープへのイベントの追加を行う同一キーIインタ管理手
段3とが備わっている。
第2図はイベントをキ、−とじて管理する管理テーブル
lの一例を示す図である。第2図では。
同じキー値をもつイベントのグループとして、イベント
2−11乃至2−1nのグループ2−1と。
イベント2−21乃至2−2mのグループ2−2と、・
・・、2−nl乃至2−njのグループ2−nとが示さ
れており、管理テーブル1の先頭キューポインタ11は
、先頭のイベント2−11をポイントするようになりて
いる。また、各イベント2−11乃至2−1 n e 
2−21乃至2−2m、・・・2−nl乃至2−nlに
は、各イベント間をシリアルにキューイングする次ポイ
ンタ2−11p乃至2−1np、2”21p乃至2−2
 m p s 2−nlp乃至2− njpとともK、
同一グループ2−1.2−2.・・・、2−n内のイベ
ント間をキューイングする同一キーポインタSとして、
2−11q乃至2−1nq、2−21q乃至2−2nq
、2−n1q乃至2− njqが設定されている。
一般のキュー管理は、管理テーブルlの先頭キューポイ
ンタ11から特定のキー値の順Kかっ同一キー値の場合
にはイベントの発生順に、シーケンシャルにキューイン
グされているのみである。
換言すると、第2図の先頭キューポインタ11から次ポ
インタ2−11 p、・・・ 2−1ap、2−2−2
1p  2−2ap、”  2−n1p、・・−2−n
lpと単純にキューイングされているのみであったが、
本発明の方式の特徴は、上記のほかに、同一キー値の複
数イベント、例えば2−11乃至2−Inを一つのグル
ーf2−1と定義し。
このグループ2−1の先頭イペン)2−11の同一キー
ポインタ2−11qから最終イベント2−1nを直接ポ
イントしていることにある。なお、同一グループの構成
(/インドの仕方)Kついては、上記のような最終イベ
ントを示す以外に次のグループの先頭を示す仕方も考え
られるが、以下の説明ではとりあえず最終イベントを示
す方式で説明する。
また、イベントサーチにおける本発明の方式の特徴は、
グループを構成しているイベントのチエツク処理におい
ては、全てのイベントについてキー値なチエツクするの
ではなく、グループな構成している全てのイベントのキ
ー値は袴しいことKよ)、グループの先頭のイベントに
ついてのみキー値のチエツクを行うことにある。グルー
プの先頭のイベントについてキー値のチエツクを行った
あとは、スキップサーチ手段2によりグループの最終イ
ベントまでスキップして1次のチエツクはスキップして
たどりついた最終イベントの次のイベントからキー値の
チエツクを行うようになっている。
次にこのような構成におけるキュー管理処理動作につい
て説明する。
tJ/jJ3図はイベントサーチ処理、特にイベントの
追加処理の流れを示すフローチャートである。例えばあ
るイベントを追加する処理では、先づ、最初のイベント
がキューイングされているか否かを判断しくステップ1
0)、キューイングされていないときKは、このイベン
トを先頭のイベントとしてキューイングする(ステップ
20)。これに対し、ステップlOで最初のイベントが
キューイングされていると判断されたときKは、先頭の
イベントをワークイベントとしくステップ100)。
ワークイベントのキー値と追加対象となるイベント(カ
レントイベント)のキー値とを比較する(ステップ11
0)。この結果、ワークイベントoキー値がカレントイ
ベントのキー値よシも大きいときKは、カレントイベン
トをワークイベントの直前にキューイングする(ステッ
プ120)。
第4図(a) e (b)はワークイベントのキー値が
カレントイベントのキー値よシも大きい場合のキューイ
ングの具体例を示す図であり、第4図(1)のようにワ
ークイベントのキー値が16′″であり、これがカレン
トイベントのキー値″″5”よシも大きいときには、第
4図(b)のように、キー値が@5”のカレントイベン
トはキー値が@6@のワークイベントの直前にキューイ
ングされる。
また、ステップ110の結果、ワークイベントのキー値
がカレントイベントのキー値と同じであるときKは、さ
らにワークイベントに同一キーポインタ、すなわちグル
ープIインタがあるかを調べる(ステラ7”130)、
同一キーポインタがあシ、グルーグがすでに構成されて
いるときKは。
カレントイベントをグループの最後のイベントとしてキ
ューイングする(ステップ140)。第5図(a) 、
 (b)はワークイベントのキー値がカレントイベント
のキー値と同じであシ、ワークイベントに同一キーポイ
ンタがある場合のキューイングの具体例を示す図であシ
、第5図(a)のように双方のキー値が11”と同じで
6C、キー値が11”のワークイベントに同一キューイ
ングがあると、第5図に示すように、キー値が@1”の
カレントイベントをこのグループの最後のイベントとし
てキューイングする。
これに対し、ステップ130において同一キーポインタ
がないときKは、グループを構成してキューイングを行
う(ステップ150)、第6図(a)。
(b)はこの場合の具体例を示す図であり、第6図(a
)のようにワークイベントのキー値とカレントイベント
のキー値が′5”と双方とも同じであるが、同一キーポ
インタがなく、またグループが構成されていないときK
は、第6図価)のようにキー値が15”のワークイベン
トとキー値が15”のカレントイベントとで新規にグル
ープを構成してキューイングする。
また、ステップ110の比較の結果、カレントイベント
のキー値がワークイベントのキー値よりも大きいときに
は、さらに、ワークイベントに次の6−があるかを調べ
る(ステップ200 )。ワークイベントに次のキュー
がないときKは、イベントの最後へキューイングする(
ステップ21の。
これに対し、ワークイベントに次のキューがあるときに
は、ワークポインタに同一キーポインタがあるかをさら
に調べ(ステップ220)、同一キーポインタがなくグ
ループを構成していなければ、現ワークイベントの次の
キューのイベントを新ワークイベントとしくステップ2
40)、同一ポインタがありグループが構成されている
ときくに。
現ワークイベントの同一キューイングのイベントを新ワ
ークイベントとする(ステップ230)。
すなわち1次のイベントをサーチする場合に、グループ
が構成されていれば、グループ単位でスキ、プすること
ができる。
上記に示すように、同一キー値のイベントが多数発生す
るような場合においては、同一キー値の複数イベントを
同一のグループと定義することによシ、4!にイベント
の追加等のイベントサーチ処理においては同一キー値の
複数イベントを同一のグループとしてその代表イベント
(先頭イベント)のみのキー値のチエツクでサーチでき
る。
例えば、キューの総数が1000個、キー値の種類(グ
ループ数)が10個、各グループ当た夛のイベント数が
100個とし、イベントサーチにおいて、平均で5oq
bの確率で目的のイベントにたどり着くと仮定すると、
従来の方式においては。
目的のイベントにたどシ着くまでには500個のイベン
トをサーチするが1本発明の方式によると。
グループサーチの回数5回と、最終イベントをサーチす
るための1回の合計6回のサーチで済む。
これにより、キュー処理のためのサーチ処理時間のオー
バヘッドを著しく少なくすることができる。
また第7図はイベントを取り出す場合の処理流れを示す
フローチャートである。イベントの取シ出し時には、先
づ、イベントがキューイングされているか否かを判断す
る(ステラ7’300)。イベントがキューイングされ
ているときKは、ワークイベントとして先頭のイベント
を設定しくステップ301 )、次いで、イベントがあ
るかを判断する(ステップ302)。イベントがあると
吉には、このイベントが取)出し条件、すなわちキー値
の条件に合致するかを調べ(ステップ303)。
合致するときKは、このイベントを取シ出しくステップ
304)、現イベントの次のイベントをワークイベント
とする(ステップ305)。
次いで再びステップ302に戻シ、ステップ302乃至
305の処理をイベントがなくなる壇で繰シ返す。なお
、ステップ303において、イベントが存在しても、キ
ー値の条件が不一致となれば、以後は全て不一致となる
ため処理を終了する。このように取シ出し処理では1条
件に合致したイベントについて、取り出しを行うことが
できる。
[発明の効果] 以上説明したように本発明によれば、イベントのキュー
イング及びキューアウト処理として、イベントをシリア
ルにキューイングする次ポインタ以外に、同じキー値の
イベントをグループ化し、グループ対応にサーチ処理が
可能となる同一キーポインタを設け、この同一キーポイ
ンタを用いることによシサーチ処理をスキップして行い
、また。
同一キー値を持つイベントの追加時には、新規にグルー
プを構成し、既にグループが構成されている場合にはグ
ループへのイベントの追加を行うようになっているので
、大規模システム等において、同一キー値のキューの数
が多くなることが予想され、かつ同一キー値のキューが
多い場合においても、キ1−処理のためのサーチ処理時
間のオーバヘッドが少なくなシ、効率良くキュー管理を
行うことができるという効果がある。
【図面の簡単な説明】
第1図は本発明の一実施例を示すブロック図、第2図は
イベントをキューとして管理する管理テーブルの一例を
示す図、第3図はイベント追加処理の流れを示すフロー
チャート、第4図(&) e (b)乃至第6図(、)
 、 (日はイベント追加処理の具体例を示す図、第7
図はイベント取出処理の流れを示すフローチャートであ
る。 図において。 1・・・管理テーブル、2・・・スキップサーチ手段。 3・・・同一キューインク管理手段、S・・・同一キー
ポインタ。 代理人 弁理士 山 下 穣 平

Claims (1)

    【特許請求の範囲】
  1. キーによる優先順の定義されているイベントで同じキー
    値のイベントが大量に発生しうる場合において、イベン
    トのキューイング及びキューアウト処理として、イベン
    トをシリアルにキューイングする次ポインタ以外に、同
    じキー値のイベントをグループ化し、グループ対応にサ
    ーチ処理が可能となる同一キーポインタを設け、同一キ
    ーポインタを用いることによりサーチ処理をスキップし
    て行うスキップサーチ手段と、同一キー値を持つイベン
    トの追加時には、新規にグループを構成し、すでにグル
    ープが構成されている場合にはグループへのイベントの
    追加を行う同一キーポインタ管理手段とを有しているこ
    とを特徴とするキュー管理方式。
JP2250320A 1990-09-21 1990-09-21 キュー管理方式 Pending JPH04130929A (ja)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2250320A JPH04130929A (ja) 1990-09-21 1990-09-21 キュー管理方式

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2250320A JPH04130929A (ja) 1990-09-21 1990-09-21 キュー管理方式

Publications (1)

Publication Number Publication Date
JPH04130929A true JPH04130929A (ja) 1992-05-01

Family

ID=17206155

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2250320A Pending JPH04130929A (ja) 1990-09-21 1990-09-21 キュー管理方式

Country Status (1)

Country Link
JP (1) JPH04130929A (ja)

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS62257539A (ja) * 1986-04-30 1987-11-10 Toshiba Corp タスク間待ち行列制御方式
JPS63191236A (ja) * 1987-02-04 1988-08-08 Fujitsu Ltd キユ−制御方式
JPH01189733A (ja) * 1988-01-25 1989-07-28 Fujitsu Ltd 代表イベント管理方式
JPH0157373B2 (ja) * 1981-03-16 1989-12-05 Intaanashonaru Bijinesu Mashiinzu Corp
JPH0267639A (ja) * 1988-09-01 1990-03-07 Nec Software Ltd 優先度付き待行列制御方式

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0157373B2 (ja) * 1981-03-16 1989-12-05 Intaanashonaru Bijinesu Mashiinzu Corp
JPS62257539A (ja) * 1986-04-30 1987-11-10 Toshiba Corp タスク間待ち行列制御方式
JPS63191236A (ja) * 1987-02-04 1988-08-08 Fujitsu Ltd キユ−制御方式
JPH01189733A (ja) * 1988-01-25 1989-07-28 Fujitsu Ltd 代表イベント管理方式
JPH0267639A (ja) * 1988-09-01 1990-03-07 Nec Software Ltd 優先度付き待行列制御方式

Similar Documents

Publication Publication Date Title
CN106802826B (zh) 一种基于线程池的业务处理方法及装置
Zhao et al. A window protocol for transmission of time-constrained messages
US6691166B1 (en) System and method for transferring partitioned data sets over multiple threads
US8280917B1 (en) Batching content management operations to facilitate efficient database interactions
US9317556B2 (en) Accelerating database queries containing bitmap-based conditions
CN102073684A (zh) 搜索日志的挖掘方法和装置以及页面搜索的方法和装置
CN106909554B (zh) 一种数据库文本表数据的加载方法及装置
CN109460676A (zh) 一种混合数据的脱敏方法、脱敏装置及脱敏设备
CN113032117A (zh) 深度学习框架的训练方法、装置及存储介质
US8612597B2 (en) Computing scheduling using resource lend and borrow
EP3018581A1 (en) Data staging management system
CN110580255A (zh) 一种存储并检索数据的方法以及系统
US5430874A (en) Control method and system for managing memory control blocks of programmed tasks in a multi-processing system
CN116737829A (zh) 一种数据同步方法、装置、存储介质及电子设备
CN111046077A (zh) 数据的获取方法及装置、存储介质、终端
JPH04130929A (ja) キュー管理方式
CN112507347B (zh) 面向分布式密码破解框架的破解作业描述信息生成方法
CN114281476A (zh) Kubernetes云原生集群资源删除保护方法、装置、设备及存储介质
CN116263717A (zh) 基于事件的订单业务处理方法及装置
JP3231101B2 (ja) タスクキュー管理方法
CN109725994B (zh) 数据抽取任务执行方法、装置、终端及可读存储介质
KR101144502B1 (ko) Ttcan 스케줄링 방법
CN109360561A (zh) 语音控制方法及系统、存储介质、语音模块、主控系统
CN111552561B (zh) 一种任务处理方法及装置
Özkan et al. On the control of fork-join networks