JP2005284462A - 業務統合サーバの機能連携制御方式 - Google Patents
業務統合サーバの機能連携制御方式 Download PDFInfo
- Publication number
- JP2005284462A JP2005284462A JP2004094464A JP2004094464A JP2005284462A JP 2005284462 A JP2005284462 A JP 2005284462A JP 2004094464 A JP2004094464 A JP 2004094464A JP 2004094464 A JP2004094464 A JP 2004094464A JP 2005284462 A JP2005284462 A JP 2005284462A
- Authority
- JP
- Japan
- Prior art keywords
- function
- business
- process logic
- business process
- execution
- 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
Links
Images
Landscapes
- Stored Programmes (AREA)
Abstract
【課題】機能連携における抽象化部分と固有部分の完全分離ができ、連携機能が必要とするデータの変更にも機能の変更を不要にする。
【解決手段】実行すべき業務個別機能名をその実行順序に従い記述する業務プロセスロジック2の拡張機能として、機能定義機構M1,M2は業務個別機能名の定義方法として逐次実行する機能及び並列実行する機能と機能の実行形態を状況に応じて定義できるように拡張し、さらに業務プロセスロジックに繰り返しループ制御機構M3、条件分岐機構M4、データ連携のための制御機構M5を追加拡張する。また、これらの拡張に伴い、繰り返しループカウント数、条件分岐の動的処理、及びデータ連携用に、既に実行した個別機能の実行結果を個々に識別できる情報と共に保存するための仕組みである実行結果管理テーブルTを設ける。
【選択図】 図1
【解決手段】実行すべき業務個別機能名をその実行順序に従い記述する業務プロセスロジック2の拡張機能として、機能定義機構M1,M2は業務個別機能名の定義方法として逐次実行する機能及び並列実行する機能と機能の実行形態を状況に応じて定義できるように拡張し、さらに業務プロセスロジックに繰り返しループ制御機構M3、条件分岐機構M4、データ連携のための制御機構M5を追加拡張する。また、これらの拡張に伴い、繰り返しループカウント数、条件分岐の動的処理、及びデータ連携用に、既に実行した個別機能の実行結果を個々に識別できる情報と共に保存するための仕組みである実行結果管理テーブルTを設ける。
【選択図】 図1
Description
本発明は、自コンピュータ内およびネットワークを介して分散配置されているコンピュータ上に存在する各種業務支援個別機能を統合的に機能させるサーバ(業務統合サーバ)に係り、特に業務統合サーバの機能連携制御方式に関するものである。
近年、情報化の促進やネットワーク環境の整備、さらにネットワークの高速化を背景に、従来スタンドアロン型であった業務支援システム(例えば監視業務における監視支援システムや保守業務における保守支援システム等)が図11に示すようなネットワーク対応型へとなってきている。特に、企業内ネットワークを利用したイントラネット対応システムや、インターネットに代表される広域のネットワークを利用したシステムでは、時間や場所に対する制約を受けずに業務支援システムを利用することが可能となり、利便性を向上させている。
このようなシステム形態において、ある特定の業務機能を実現する手段としては、従来のスタンドアロン型業務支援システムでは、幾つかの個別機能を連携させ、1つの業務機能として機能させる。この個別機能の連携制御は通常、業務機能を実現するためのプログラムという形で実装され、それはシステム毎に固有の形態となる。これは近年のネットワーク対応型連携システムにおいても同様であり、機能連携制御はそれ自体がシステム機能プログラムとして実装されるのが一般的である。しかし、近年のシステム形態の主流であるネットワーク対応型連携システムでは、個別機能が分散管理されているという性格上、その機能の変更・更新等も個々に行われる。そのため、個別機能に変更・更新が行われる度にその連携を定義しているプログラムの変更も余儀なくされていた。そのため、このような事態にも容易に対応できるようなシステムが求められてきた。
このような状況を背景に、以下に示す仮想的な連携対象に対し、仮想的な連携機能を有してシステム本体に実装される抽象化部分と、具体的な連携対象に対する具体的な連携機能を有してシステム本体から呼ばれる固有部分とで構成した機能連携制御方法が登場してきた。
(A)抽象化部分と固有部分を別プログラム化する形態。
個別機能連携により実現される業務機能部をシステム本体プログラムから業務機能プログラム(固有部分)として独立させ実装する。これにより、システム本体のプログラム(抽象化部分)を変更すること無く、個別機能の変更・更新時も業務機能プログラムのみの変更で対応することが可能となり、変更範囲の局所化が実現される。
(B)抽象化部分は従来通りのプログラム形式とし、固有部分を外部ファイルとして定義し、これを抽象化プログラムで読み取り実行する形態(例えば、特許文献1参照)。
このシステムにおける業務統合サーバの構成例を図12に示す。クライアントゲート部1は、クライアントから送信されたデータの中から、実行する業務プロセスのロジック、該ロジックの実行に必要な各種パラメータ、作成するGUIに対するスタイルシートの情報を抽出し、内部データとして格納する。業務プロセスロジック実行部2は、業務プロセス機能の名前に対応する業務支援サーバの詳細情報をサービスリポジトリ管理部3より取得し、これら名前及び業務支援サーバの詳細情報を業務支援サーバ通信部4を通して業務支援サーバにサービス実行を依頼し、このサービス実行の結果は内部データとして格納する。サービスリポジトリ管理部3は、業務プロセスロジック実行部2が指定する業務プロセス機能のサービス名に対応する業務支援サーバの詳細情報を取得し、業務プロセスロジック実行部2に通知する。業務支援サーバ通信部4は、業務プロセスロジック実行部2が指定するサービス名及び業務支援サーバの詳細情報を基に、業務支援サーバと通信し、業務支援サーバのサービス実行結果を業務プロセスロジック実行部2に通知する。サービスリポジトリ5は、業務プロセス機能の名前(サーバ名)に対応する業務支援サーバの詳細情報(サーバ名またはIPアドレス、サーバ実行に必要なパラメータ要素等)を格納する。GUI作成部6は、内部データに格納されている前記業務プロセスロジック実行部2の処理結果と、指定されたスタイルシート情報を基に、クライアントへ送信すべきGUIを動的に作成する。
上記のシステム構成において、機能連携制御を行っているのが、業務プロセスロジック実行部2であり、業務機能毎の個別機能の連携を定義する業務プロセスロジックと、それを実行するためのシステムプログラムとが、具体的な業務機能に依存する外部リソース部分(以下、固有部分)と具体的な業務機能に依存しない処理を実行する抽象的な部分(以下、抽象化部分)とに分類されるため、個別機能の変更・更新においてもその機能を連携させて実行する業務機能の変更・更新が容易になる。
特開2003−242127
前記の(A)抽象化部分と固有部分を別プログラム化する形態では、連携させる個別機能に変更があった場合、その変更の大小に関わらず変更分を吸収するために業務機能プログラムを修正し、再コンパイルする必要がある。
また、前記の(B)抽象化部分は従来通りのプログラム形式とし、固有部分を外部ファイルとして定義し、これを抽象化プログラムで読み取り実行する形態では、業務プロセスロジックには業務プロセス(個別機能)の連携順序を羅列しているのみであり、その業務プロセス(個別機能)のデータ連携は抽象化部分で行っている。そのため、個別機能が必要とするデータの変更(データの順序、項目の増減)が発生した場合は、抽象化部分の変更を余儀なくされる。
また、前記の(A)及び(B)のいずれの形態にも当てはまる問題としては、ある個別機能Xの実行結果を、次に実行する個別機能Yに渡し、機能を連携する場合、個別機能Xの実行結果を個別機能Yの入力に合わせるための変換作業が必要となる。これは(A)の場合は業務機能プログラム、(B)の場合は抽象化部分のプログラムで実装されることになる。しかし、これでは、(A)の場合は常に次に実行する個別機能を意識した実装が必要となり、(B)の場合は抽象化部分に業務毎の機能の一部が混入することになり、機能連携における抽象化部分と固有部分の完全分離ができない。
また、例えば個別機能Xの実行結果が場合により“tlue”、または“false”いずれかの値を返す場合において、“tlue”の場合は個別機能Yを、“false”の場合は個別機能Zを実行するような分岐制御を機能連携に組み入れたい場合も同様の問題が発生する。
本発明の目的は、機能連携における抽象化部分と固有部分の完全分離ができ、連携機能が必要とするデータの変更にも機能の変更を不要にした業務統合サーバの機能連携制御方式を提供することにある。
本発明は、前記の課題を解決するため、実行すべき業務個別機能名をその実行順序に従い記述する業務プロセスロジックの拡張機能として、業務個別機能名の定義方法として逐次実行する機能及び並列実行する機能と機能の実行形態を状況に応じて定義できるように拡張し、さらに業務プロセスロジックに繰り返しループ制御、条件分岐制御、データ連携制御機構を追加拡張する。また、これらの拡張に伴い、繰り返しループカウント数、条件分岐の動的処理、及びデータ連携用に、既に実行した個別機能の実行結果を個々に識別できる情報と共に保存するための仕組みである実行結果管理テーブルを設ける。これらのことから、本発明は、以下の構成を特徴とする。
(1)自コンピュータ内、及びLAN、イントラネット、インターネット等のネットワークを介し、分散配置されているコンピュータ上に存在する各種業務支援個別機能を統合的に運用し、業務支援機能を構築・運用する業務支援システムにおいて、
外部リソースファイルの形で業務支援機能の連携情報を定義する業務プロセスロジックと、
前記業務プロセスロジック中に、前記業務支援個別機能の逐次実行及び並列実行の任意の実行形態を定義可能にした個別機能定義機構と、
繰り返し定義による特定の処理のループ制御ができ、ループ制御回数を前回実行個別機能の結果を利用することにより動的定義可能な繰り返し制御機構と、
条件分岐定義による特定の処理の分岐制御ができ、分岐条件を前回実行個別機能の結果を利用することにより動的定義可能な分岐制御機構と、
データ連携定義により個別機能間のデータ変換を用いることで、前回実行個別機能の結果を次回実行個別機能の入力値とすることができるデータ連携制御機構とを備え、
業務機能実行における抽象化部分と機能固有部分とにシステム機能を分離し、その抽象化部分に業務プロセスロジックを解析機構を備えたことを特徴とする。
外部リソースファイルの形で業務支援機能の連携情報を定義する業務プロセスロジックと、
前記業務プロセスロジック中に、前記業務支援個別機能の逐次実行及び並列実行の任意の実行形態を定義可能にした個別機能定義機構と、
繰り返し定義による特定の処理のループ制御ができ、ループ制御回数を前回実行個別機能の結果を利用することにより動的定義可能な繰り返し制御機構と、
条件分岐定義による特定の処理の分岐制御ができ、分岐条件を前回実行個別機能の結果を利用することにより動的定義可能な分岐制御機構と、
データ連携定義により個別機能間のデータ変換を用いることで、前回実行個別機能の結果を次回実行個別機能の入力値とすることができるデータ連携制御機構とを備え、
業務機能実行における抽象化部分と機能固有部分とにシステム機能を分離し、その抽象化部分に業務プロセスロジックを解析機構を備えたことを特徴とする。
(2)前記繰り返し制御機構による繰り返しループカウント数、前記条件分岐制御機構による動的処理、及び前記データ連携制御機構における既に実行した個別機能の実行結果を個々に識別できる情報と共に保存する実行結果管理テーブルを備えたことを特徴とする。
(3)前記業務プロセスロジックの形態は、
テキスト形式による業務プロセスロジック形式、
または、XML形式による業務プロセスロジック形式、
または、XML形式で記述した業務プロセスロジックからプログラム形式の業務プロセスロジックへ変換可能な業務プロセスロジック形式、
または、XML形式で記述した業務プロセスロジックから処理のボトルネックとなる部分のみプログラム形式の業務プロセスロジックへ変換可能な業務プロセスロジック形式としたことを特徴とする。
テキスト形式による業務プロセスロジック形式、
または、XML形式による業務プロセスロジック形式、
または、XML形式で記述した業務プロセスロジックからプログラム形式の業務プロセスロジックへ変換可能な業務プロセスロジック形式、
または、XML形式で記述した業務プロセスロジックから処理のボトルネックとなる部分のみプログラム形式の業務プロセスロジックへ変換可能な業務プロセスロジック形式としたことを特徴とする。
(4)前記業務プロセスロジックおよび前記各機構を業務統合サーバに設け、このサーバからの実行依頼で前記個別機能の実行を複数の業務支援サーバで行うシステム構成としたことを特徴とする。
以上のとおり、本発明によれば、実行すべき業務個別機能名をその実行順序に従い記述する業務プロセスロジックの拡張機能として、業務個別機能名の定義方法として逐次実行する機能及び並列実行する機能と機能の実行形態を状況に応じて定義できるように拡張し、さらに業務プロセスロジックに繰り返しループ制御、機構、条件分岐制御機構、データ連携のための制御機構を追加拡張し、これらの拡張に伴い、繰り返しループカウント数、条件分岐の動的処理、及びデータ連携用に、既に実行した個別機能の実行結果を個々に識別できる情報と共に保存するための仕組みである実行結果管理テーブルを設けるようにしたため、以下の効果がある。
自コンピュータ内、及びネットワークを介し分散配置されているコンピュータ上に存在する各種業務支援個別機能を統合的、且つ柔軟に連携させるために、業務プロセスロジックを拡張することにより、業務プロセスロジック自身に制御機構を保持させることができる。
また、業務プロセスロジックを解析・実行するシステム側においては、ロジックを解析する機能のみを設けることで機能連携における制御機構を定義する必要が無くなり、個別機能の連携において連携処理抽象化部分と、業務機能固有部分を完全に分離することが可能となる。
また、業務支援システムの機能の拡張・変更・追加・削除等がシステム本体のプログラムを変更する必要なく、業務プロセスロジックの変更のみで行うことが可能となる。
また、業務プロセスロジックの変更は、テキストベースによるテキスト形式、XML形式により作成することが可能であるため、容易に編集することが可能となるのでシステム全体における拡張性・柔軟性・保守性を総合的に向上させることが可能となる。
本発明は、前記の特許文献1で記述されている実行すべき業務個別機能名を、その実行順序に従い記述する業務プロセスロジックを以下のような拡張機能を有して構成する。
業務プロセスロジックに繰り返しループ制御、条件分岐制御の制御構造、データ連携のための制御機構を追加拡張する。同時に、業務個別機能名の定義方法も拡張し、逐次実行する機能、及び並列実行する機能と機能の実行形態を状況に応じて定義できるように拡張する。また、これらの拡張に伴い、繰り返しループカウント数、条件分岐の動的処理、及びデータ連携用に、既に実行した個別機能の実行結果を個々に識別できる情報と共に保存するための仕組みである実行結果管理テーブルを設定する。
図1は、本発明の実施形態を示し、図12における業務プロセスロジック2に搭載する拡張機能構成を示す。以下、図1に示す拡張機能別に説明する。
(1)個別機能定義機構
実行する個別機能の名称を定義するための識別情報を定義する。図1中の機能定義機構M1では、識別情報を例として“method”というキーワードを用いる。“method”キーワードには実行する機能名称を設定するための属性情報を定義する。この属性情報は例として“name”というキーワードを用いる。これらの定義情報を実行する個別機能の数だけ、その実行順序に従って繰り返し定義する。
実行する個別機能の名称を定義するための識別情報を定義する。図1中の機能定義機構M1では、識別情報を例として“method”というキーワードを用いる。“method”キーワードには実行する機能名称を設定するための属性情報を定義する。この属性情報は例として“name”というキーワードを用いる。これらの定義情報を実行する個別機能の数だけ、その実行順序に従って繰り返し定義する。
このように、実行順序に従い定義した“method”キーワードで表した個別機能において、単純に1つずつ順序に従い実行するのではなく、ある2つ以上の機能を同時に実行したい場合も存在する。このような場合に対応するために、機能定義機構M2では、同時に実行したい“method”キーワードを束ね、それらを自らの子要素として設定するための識別情報を定義する。この識別情報は例として、“methods”というキーワードを用いる。これにより“methods”キーワードの子要素として定義した“method”キーワードの示す個別機能は、同時に実行する(以下、並列実行)機能を表すことになる。
また、並列実行するのではなく、1つずつ順序に従い実行する場合(以下、逐次実行)においても、“methods”キーワードの子要素として”method“キーワードを設定する。この場合は、”methods“キーワードの子要素として設定される”method“キーワードは1つとなる。以上の定義を、全ての”method“キーワードに対し行う。その結果、業務プロセスロジック中には複数の“methods”キーワードが存在することになる。そのため、これらを一意に識別するための情報を、“methods”キーワードの属性として定義する。ここでは例として、“name”キーワードを用いる。
以上までの定義機構により、“methods”キーワードの順序に従い機能を逐次実行し、“methods”キーワードの子要素として“method”キーワードで定義されている個別機能を実行する。但し、子要素としての“method”キーワードが2つ以上定義されている場合はそれらを並列実行する。
個別機能定義の例を図2に示す。図2で示した業務プロセスロジックは、次のように実行される。
a−1を実行→b−1、及びb−2を同時に実行→c−1を実行
この実行では、b−1,b−2の並列実行、a−1,b−1&b−2,c−1の逐次実行になる。
この実行では、b−1,b−2の並列実行、a−1,b−1&b−2,c−1の逐次実行になる。
(2)繰り返し制御機構
繰り返し識別情報を定義し、これによりある個別機能の繰り返し実行を制御する。図1では、繰り返し制御機構M3の識別情報は例として、“for”キーワードを用いる。繰り返し実行の対象となる個別機能は、“for”キーワードの子要素として定義されたものとする。“for”キーワードの子要素としては、個別機能定義以外に、繰り返し定義(繰り返しの入れ子構造を示すことになる)、後述の条件分岐制御機構M4、及びデータ連携制御機構M5を定義することを可能とする。
繰り返し識別情報を定義し、これによりある個別機能の繰り返し実行を制御する。図1では、繰り返し制御機構M3の識別情報は例として、“for”キーワードを用いる。繰り返し実行の対象となる個別機能は、“for”キーワードの子要素として定義されたものとする。“for”キーワードの子要素としては、個別機能定義以外に、繰り返し定義(繰り返しの入れ子構造を示すことになる)、後述の条件分岐制御機構M4、及びデータ連携制御機構M5を定義することを可能とする。
繰り返し制御機構M3においては、そのループ回数を示す諸条件情報を定義する。ここでは、例として“for”キーワードを用いているので、ループ回数を示す情報として、ループ開始値、及びループ終了値を用いる。設定する情報を各々示す識別情報を“for”キーワードの属性として定義する。ここでは例としてループ開始値を“min”、ループ終了値を“max”というキーワードを用いることとする。“for”キーワードの設定例を図3に示す。図3では、以下のように実行される。
a−1を実行→c−1をminキーワードが示す値(0)からmaxキーワードが示す値(3)まで繰り返し実行。
また、min、maxキーワードには直接値を設定する他に、実行結果管理テーブルTの識別情報を指定することで、実行結果による繰り返し制御を実行することが可能となる。その場合の定義例を図4に示す。図4では、以下のように実行される。
a−1を実行→c−1をminキーワードが示す値(0)からmaxキーワードが示す値(実行結果管理テーブルの識別情報result_a−1が示す値)まで繰り返し実行。
また、実行結果管理テーブルTの識別情報をmin、maxキーワードに指定した場合、実行結果管理テーブルTの識別情報に対し、以下の2つのオプションを用意する。これらのオプションは、実行結果管理テーブルTの識別情報の後に続けて記述する。
・識別情報要素数指定オプション
指定した実行結果管理テーブルTの識別情報と同名の識別情報が複数存在した場合、その識別情報数を取得するオプション。ここでは、例として、“#Length”キーワードを用いることとする。その例を図5に示す。図5では、以下のように実行される。
指定した実行結果管理テーブルTの識別情報と同名の識別情報が複数存在した場合、その識別情報数を取得するオプション。ここでは、例として、“#Length”キーワードを用いることとする。その例を図5に示す。図5では、以下のように実行される。
a−1を実行→c−1をminキーワードが示す値(0)からmaxキーワードが示す値(実行結果管理テーブルの識別情報result_a−1が複数あり、その要素数値)まで繰り返し実行。
・配列要素番号指定オプション
指定した実行結果管理テーブルTの識別情報と同名の識別情報が複数存在した場合、その何番目の実行結果管理テーブルの識別情報が示す値を取得するかを指定するオプション。ここでは、例として、“#[n]キーワード”(nは、整数値)を用いることとする。その例を図6に示す。図6では、以下のように実行される。
指定した実行結果管理テーブルTの識別情報と同名の識別情報が複数存在した場合、その何番目の実行結果管理テーブルの識別情報が示す値を取得するかを指定するオプション。ここでは、例として、“#[n]キーワード”(nは、整数値)を用いることとする。その例を図6に示す。図6では、以下のように実行される。
a−1を実行→c−1をminキーワードが示す値(0)からmaxキーワードが示す値(実行結果管理テーブルの識別情報result_a−1が複数あり、その1番目の示す値)まで繰り返し実行。
(3)条件分岐制御機構
条件分岐識別情報を定義し、これによりある条件値による次に実行する個別機能の条件分岐実行を制御する。図1では、条件分岐制御機構M4の識別情報を例として、“if”キーワードを用いる。通常のプログラム言語における「if」は、条件に合致しない場合に「else」を使用している。また、3つ以上に条件分岐を行う場合においては「elseif」を用いる。「elseif」には「if」と同様の条件式を定義し、「if」の条件に合致しない場合は「elseif」の条件式の判定を行う。この「elseif」を複数用いることで、条件による処理分岐を複数に設定することが可能である。この例にならい、ここでも例として“if”キーワードを用いているので、それぞれを“else”キーワード、“elseif”キーワードを用いることとする。
条件分岐識別情報を定義し、これによりある条件値による次に実行する個別機能の条件分岐実行を制御する。図1では、条件分岐制御機構M4の識別情報を例として、“if”キーワードを用いる。通常のプログラム言語における「if」は、条件に合致しない場合に「else」を使用している。また、3つ以上に条件分岐を行う場合においては「elseif」を用いる。「elseif」には「if」と同様の条件式を定義し、「if」の条件に合致しない場合は「elseif」の条件式の判定を行う。この「elseif」を複数用いることで、条件による処理分岐を複数に設定することが可能である。この例にならい、ここでも例として“if”キーワードを用いているので、それぞれを“else”キーワード、“elseif”キーワードを用いることとする。
条件分岐制御の対象となる個別機能は、“if”,“elseif”,“else”キーワードの子要素として定義されるものとする。各々のキーワードの子要素としては個別機能定義以外に、繰り返し制御機構M3、条件分岐定義(条件分岐の入れ子構造を示すことになる)、及びデータ連携制御機構M5を定義することを可能とする。
条件分岐制御機構においては、分岐条件を示すための諸条件情報を定義する。ここでは例として“if”キーワードを用いているので、条件分岐の条件式設定情報として、条件要素、条件値、条件値のデータ型、判定方法をも用いる。設定する条件の識別情報を“if”キーワードの属性として定義する。ここでは、例として、条件要素を“borderName”、条件値を“borderValue”、条件値のデータ型を“borderValueType”、判定方法を“operator”というキーワードを用いる。
特に、条件値“borderValue”の設定は、実行結果管理テーブルTの識別情報指定により行う。これにより、“if”キーワードの条件式に合致した場合はその子要素として定義しであるものを、そうでない場合は“else”キーワードの子要素として定義しているものを実行する。
“borderValue”キーワードで設定する実行結果管理テーブルTの識別情報には、繰り返し制御機構M3の場合と同様の方法でオプションが指定可能とする。条件分岐制御機構M4の例を図7に示す。図7では、以下のように実行される。
a−1の実行→実行結果管理テーブルの識別情報result_a−1の示す値が1ならc−1を、2ならd−1を、それ以外ならe−1を実行。
(4)データ連携制御機構
データ連携識別情報を定義し、実行結果管理テーブルT内にある識別情報で保存されている個別機能の結果情報を、別の個別機能が読み取り可能な識別情報への変換を行う。このデータ連携制御機構M5による識別情報への変換は、識別情報の変換ルールを設定した外部ファイル(以下、変換ルール外部ファイル)を用いて行う。ここでは、データ連携識別情報を例として“mapping”キーワードを用いる。利用する変換ルール外部ファイルFの名称は、“mapping”キーワードの子要素として定義する識別情報、ここでは例として“xsl”キーワードを使用して定義する。データ連携は、逐次実行する個別機能の1つとして扱うため、個別機能定義機構の章で記述した“methdos”キーワードの子要素として定義する。データ連携定義の例を、図8に示す。
データ連携識別情報を定義し、実行結果管理テーブルT内にある識別情報で保存されている個別機能の結果情報を、別の個別機能が読み取り可能な識別情報への変換を行う。このデータ連携制御機構M5による識別情報への変換は、識別情報の変換ルールを設定した外部ファイル(以下、変換ルール外部ファイル)を用いて行う。ここでは、データ連携識別情報を例として“mapping”キーワードを用いる。利用する変換ルール外部ファイルFの名称は、“mapping”キーワードの子要素として定義する識別情報、ここでは例として“xsl”キーワードを使用して定義する。データ連携は、逐次実行する個別機能の1つとして扱うため、個別機能定義機構の章で記述した“methdos”キーワードの子要素として定義する。データ連携定義の例を、図8に示す。
以上で定義した識別情報(キーワード)を用いて、業務プロセスロジックを実現する場合の例を以下に4つ示す。
(例1)本例では、業務プロセスロジックをテキスト形式により定義した場合に関して記述する。テキスト形式では、業務プロセスロジックの定義は最も容易に編集・加工が行える方式である。
しかし、業務プロセスロジックを解析するプログラム側においては、全てが文字列で記述されている業務プロセスロジックを解析するためのプロセッサを独自に用意する必要がある。また、文字列であるが故にシステムによる取り扱いが複雑になる傾向がある。業務プロセスロジックをテキスト形式により実装した例を図9に示す。
(例2)本例では、業務プロセスロジックをXML形式により定義した場合に関して記述する。XML形式では、定義識別情報(個別機能定義、繰り返し定義、条件分岐定義、データ連携定義)をタグとして位置付け、各定義識別情報を以下のように定義する。
(a)個別機能定義機構M1,M2
例として挙げた“methods”キーワードを<methdos>タグ、“name”キーワードを<methods>タグの属性として定義。同様に、“method”キーワードは<method>タグ、“name”キーワードを<method>タグの属性として定義。
例として挙げた“methods”キーワードを<methdos>タグ、“name”キーワードを<methods>タグの属性として定義。同様に、“method”キーワードは<method>タグ、“name”キーワードを<method>タグの属性として定義。
(b)繰り返し制御機構M3
例として挙げた“for”キーワードを<for>タグ、“min”及び“max”キーワードを<for>タグの属性として定義。
例として挙げた“for”キーワードを<for>タグ、“min”及び“max”キーワードを<for>タグの属性として定義。
(c)条件分岐制御機構M4
例として挙げた“if”キーワードを<if>タグ、“borderName”,“borderValue”,“borderValueType”、及び“operator”キーワードを<if>タグの属性として定義。“elseif”、及び“else”キーワードも同様にそれぞれ<elseif>タグ、<else>タグとする。
例として挙げた“if”キーワードを<if>タグ、“borderName”,“borderValue”,“borderValueType”、及び“operator”キーワードを<if>タグの属性として定義。“elseif”、及び“else”キーワードも同様にそれぞれ<elseif>タグ、<else>タグとする。
(d)データ連携制御機構M5
例として挙げた“mapping”キーワードを<mapping>タグとして定義。
例として挙げた“mapping”キーワードを<mapping>タグとして定義。
XML形式では、拡張性・汎用性に優れたXMLを利用することにより、任意のキーワードの増加減が行い易い特徴を持つことが可能となる。また、データの階層構造定義を効率的に行えるため、各キーワードの階層構造を効率的に定義することが可能となる。業務プロセスロジックを解析するためのプロセッサにおいても、市販のXMLParserを利用することで独自に用意する必要が無く、システムによる取り扱いが容易なものとなる。
しかし、全てのデータを文字列として扱うため、数値データなど、文字列以外のデータに対する処理効率が低く、XMLをシステム内で展開した場合のシステムリソースを多く消費する等の理由により、業務プロセスロジックの解析高速化という面では若千問題が残る。業務プロセスロジックをXML形式により実装した例を図10に示す。
(例3)本例では、XML形式で記述した業務プロセスロジックを、プログラム実装で利用しているプログラム言語に変換するプログラム変換プロセッサを用いてプログラム形式とした業務プロセスロジックを定義した場合に関して記述する。
本方式では、編集時はXML形式、実行時はプログラム形式というハイブリット方式を採用することで、編集性、拡張性、解析の高速化を図ることが可能である。
しかし、XML形式で記述された業務プロセスロジックを実行時にプログラム形態へのコンパイル作業が必要になる、実装プログラム言語に変換するプロセッサを独自に用意する必要がある、コンパイル時に多くのシステムリソースが必要になる等の問題がある。
(例4)本例では、XML形式で記述した業務プロセスロジックの一部分を、プログラム実装で利用しているプログラム言語に変換するプログラム変換プロセッサを用いてプログラム形式とした業務プロセスロジックを定義した場合に関して記述する。
本方式では、業務プロセスロジックの実行において処理負荷が高いと思われる箇所、例えば繰り返しループ部分等のみを部分的にプログラム形式に変換し実行するものである。そのため、コンパイル時間の短縮、処理効率が悪い部分の高速化による全体的な処理速度の向上、コンパイル時に多くのシステムリソースを必要としない等のメリットがある。
しかし、XML形式で記述された業務プロセスロジックの一部分を実装プログラム言語に変換するプロセッサを用意する必要がある。業務プロセスロジック中のボトルネック抽出を適切に実施しないと期待していた処理速度向上が実現できない等の問題がある。
1 クライアントゲート部
2 業務プロセスロジック実行部
3 サービスリポジトリ管理部
4 業務支援サーバ通信部
5 サービスリポジトリ
6 GUI作成部
M1、M2 個別機能定義機構
M3 繰り返し制御機構
M4 条件分岐制御機構
M5 データ連携制御機構
T 実行結果管理テーブル
T 外部ファイル
2 業務プロセスロジック実行部
3 サービスリポジトリ管理部
4 業務支援サーバ通信部
5 サービスリポジトリ
6 GUI作成部
M1、M2 個別機能定義機構
M3 繰り返し制御機構
M4 条件分岐制御機構
M5 データ連携制御機構
T 実行結果管理テーブル
T 外部ファイル
Claims (4)
- 自コンピュータ内、及びLAN、イントラネット、インターネット等のネットワークを介し、分散配置されているコンピュータ上に存在する各種業務支援個別機能を統合的に運用し、業務支援機能を構築・運用する業務支援システムにおいて、
外部リソースファイルの形で業務支援機能の連携情報を定義する業務プロセスロジックと、
前記業務プロセスロジック中に、前記業務支援個別機能の逐次実行及び並列実行の任意の実行形態を定義可能にした個別機能定義機構と、
繰り返し定義による特定の処理のループ制御ができ、ループ制御回数を前回実行個別機能の結果を利用することにより動的定義可能な繰り返し制御機構と、
条件分岐定義による特定の処理の分岐制御ができ、分岐条件を前回実行個別機能の結果を利用することにより動的定義可能な分岐制御機構と、
データ連携定義により個別機能間のデータ変換を用いることで、前回実行個別機能の結果を次回実行個別機能の入力値とすることができるデータ連携制御機構とを備え、
業務機能実行における抽象化部分と機能固有部分とにシステム機能を分離し、その抽象化部分に業務プロセスロジックを解析機構を備えたことを特徴とする業務統合サーバの機能連携制御方式。 - 前記繰り返し制御機構による繰り返しループカウント数、前記条件分岐制御機構による動的処理、及び前記データ連携制御機構における既に実行した個別機能の実行結果を個々に識別できる情報と共に保存する実行結果管理テーブルを備えたことを特徴とする請求項1に記載の業務統合サーバの機能連携制御方式。
- 前記業務プロセスロジックの形態は、
テキスト形式による業務プロセスロジック形式、
または、XML形式による業務プロセスロジック形式、
または、XML形式で記述した業務プロセスロジックからプログラム形式の業務プロセスロジックへ変換可能な業務プロセスロジック形式、
または、XML形式で記述した業務プロセスロジックから処理のボトルネックとなる部分のみプログラム形式の業務プロセスロジックへ変換可能な業務プロセスロジック形式としたことを特徴とする請求項1または2に記載の業務統合サーバの機能連携制御方式。 - 前記業務プロセスロジックおよび前記各機構を業務統合サーバに設け、このサーバからの実行依頼で前記個別機能の実行を複数の業務支援サーバで行うシステム構成としたことを特徴とする請求項1〜3のいずれか1項に記載の業務統合サーバの機能連携制御方式。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2004094464A JP2005284462A (ja) | 2004-03-29 | 2004-03-29 | 業務統合サーバの機能連携制御方式 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2004094464A JP2005284462A (ja) | 2004-03-29 | 2004-03-29 | 業務統合サーバの機能連携制御方式 |
Publications (1)
Publication Number | Publication Date |
---|---|
JP2005284462A true JP2005284462A (ja) | 2005-10-13 |
Family
ID=35182801
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2004094464A Pending JP2005284462A (ja) | 2004-03-29 | 2004-03-29 | 業務統合サーバの機能連携制御方式 |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP2005284462A (ja) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2011529207A (ja) * | 2008-03-04 | 2011-12-01 | アクセス ビジネス グループ インターナショナル リミテッド ライアビリティ カンパニー | ウェブ空間における独立型デバイスからの情報抽出のためのシステム及びマークアップ言語 |
-
2004
- 2004-03-29 JP JP2004094464A patent/JP2005284462A/ja active Pending
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2011529207A (ja) * | 2008-03-04 | 2011-12-01 | アクセス ビジネス グループ インターナショナル リミテッド ライアビリティ カンパニー | ウェブ空間における独立型デバイスからの情報抽出のためのシステム及びマークアップ言語 |
US8631126B2 (en) | 2008-03-04 | 2014-01-14 | Access Business Group International Llc | System and markup language for information extraction from stand-alone devices in webspace |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8799299B2 (en) | Schema contracts for data integration | |
CN107423053B (zh) | 一种遥感图像处理的web化模型封装与分布式处理方法 | |
US9424003B1 (en) | Schema-less system output object parser and code generator | |
Alt et al. | A grid workflow language using high-level petri nets | |
GB2587144A (en) | Collaborative design systems, apparatuses, and methods | |
US20030084127A1 (en) | Integrated business process modeling environment and models created thereby | |
CN106681820B (zh) | 基于消息组合的可扩展大数据计算方法 | |
US8380965B2 (en) | Channel-based runtime engine for stream processing | |
US20090106011A1 (en) | System and method for developing and deploying sensor and actuator applications over distributed computing infrastructure | |
JP5552449B2 (ja) | データ分析及び機械学習処理装置及び方法及びプログラム | |
CN103488674A (zh) | 计算系统和计算系统的执行控制方法 | |
JP2015095096A (ja) | MapReduceジョブ実行システム、MapReduceジョブ実行方法 | |
Jaradat et al. | Workflow partitioning and deployment on the cloud using orchestra | |
JP2005284462A (ja) | 業務統合サーバの機能連携制御方式 | |
Saeedloei et al. | Synthesizing clock-efficient timed automata | |
JP2007188179A (ja) | 計算機システムの性能評価装置、性能評価方法、及び性能評価プログラム | |
US10657476B2 (en) | Just in time compilation (JIT) for business process execution | |
US20130218928A1 (en) | Information processing device | |
US7536674B2 (en) | Method and system for configuring network processing software to exploit packet flow data locality | |
US20200311048A1 (en) | Extensible Validation Framework | |
Chan et al. | Visual programming support for graph‐oriented parallel/distributed processing | |
WO2012137390A1 (ja) | 並列化設計支援システム、プログラム、および方法 | |
CN112287012B (zh) | 采用Spark SQL模式实现http接口调用方法 | |
JP2019179383A (ja) | Api処理方法、端末、api処理プログラム | |
JP5696280B1 (ja) | 用語統一システム及び用語統一プログラム、並びに用語統一方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20061114 |
|
A977 | Report on retrieval |
Effective date: 20090212 Free format text: JAPANESE INTERMEDIATE CODE: A971007 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20090929 |
|
A02 | Decision of refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A02 Effective date: 20100209 |