6
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

Business Automation Manager Open Edition メモ - (1) 概要

Last updated at Posted at 2022-10-09

はじめに

IBMから提供されるBusiness Automation Manager Open Editionという製品があります。これはいわゆる"Business Automation"と呼ばれる分野に関連する機能を提供する製品ということになります。製品機能としては、BRMS(Business Rule Management System)としての機能や、BPMS(Business Process Management System)としての機能を含みますが、このシリーズでは、BRMS("意思決定管理機能")の部分を中心に見ていきたいと思います。
まずは概要編。

関連記事

Business Automation Manager Open Edition メモ - (1) 概要
Business Automation Manager Open Edition メモ - (2) KIE Server, Business Central 構成
Business Automation Manager Open Edition メモ - (3) Business Centralを使用したルール開発
Business Automation Manager Open Edition メモ - (4) KIEサーバー上のルール呼び出し
Business Automation Manager Open Edition メモ - (5) Embedded形態でのルール開発(DRL編)
Business Automation Manager Open Edition メモ - (6) Embedded形態でのルール開発(DMN編)
Business Automation Manager Open Edition メモ - (7) kogitoでのルール開発(スタンドアローン)
Business Automation Manager Open Edition メモ - (8) kogitoでのルール開発(OpenShiftへのデプロイ)

製品の位置づけ

IBMはCloud Pak for Business Automation や、ODM(Operational Decision Manager)、BAW(Business Automation Workflow)といった"Business Automation"関連の製品を提供しています。
IBM Cloud Pak for Business Automation
IBM Business Automation Workflow(BAW)
IBM Operational Decision Manager(ODM)

Qiita記事書いたものもあるので一応...
Business Automation Study
IBM Operational Decision Manager メモ

一方でRed Hatからも"Business Automation"関連製品は提供されています。
Red Hat Process Automation Manager
Red Hat Decision Manager

2019年にIBMがRed Hatを買収したこともあり、Red Hatから提供されていたBusiness Automation製品もIBMの冠がついた製品として提供されることになりました。それが、「IBM Business Automation Manager Open Edition」です。
IBM Business Automation Manager Open Editions 8.0 発表レター
IBM Business Automation Manager Open Editions 8.0 Documentation

IBM Business Automation Manager Open Edition には、機能としてはRed Hat Process Automation Manager (PAM)、および、Red Hat Decision Manager(DM)が含まれるようです。
IBM Business Automation Manager Open Edition は、Red Hat PAM/DM の後継製品という位置づけになります。つまりIBMから同じカテゴリーの製品が2系統提供されるということになります。

※まだ新しいせいかこの製品の略称があまり見られません。製品名が長ったらしいのでとりあえずここではBAM OEと略して表記します。

関連用語/技術

BAM OEに関連する用語、技術について触れておきます。

ルール・エンジン関連

Drools

Drools

DroolsはBRMS機能を提供するOSSです。
DroolsをベースにRed HatがDecision Managerという商用製品を提供しており、その後継がIBM Business Automation Manager Open Editionということになります。
Droolsには主要なコンポーネントとして、ルールやプロセスの開発/管理を支援するBusiness Central、ルールやプロセスのランタイム環境を提供するKIE Serverが含まれます。

Kogito

Kogito
Kogitoとは
Kogitoを使用してアプリケーションにルール・エンジン機能を追加する

"コジト"と発音するらしいです。("コギト"ではないのね...)
Kogitoはクラウド・ネイティブの考え方でビジネス・プロセス・ベースのアプリケーションやルール・ベースのアプリケーションを実行するための機能を提供するOSSです。ビジネス・ルールやビジネス・プロセスをマイクロサービスとして稼働させることを想定したインフラを提供します。
BAM OEではKogitoをベースにしたルール実行環境提供しています。
KogitoはJavaのフレームワークを使用して実装されているようで、Quarkus もしくは Spring Bootを使用することになります。(推奨はQuarkusとなっています)

Kogito Documentation - 1.4. Kogito on Quarkus and Spring Boot

The primary Java frameworks that Kogito supports are Quarkus (recommended) and Spring Boot.

Kogitoのルール・エンジンのコアの部分はDroolsが使われているようです。KogitoはDroolsを拡張したもの、という関係性のようです。
参考: From Drools to Kogito Rule Engine

Quarkus

Quarkus
Quarkus とは

コンテナやサーバーレスの環境で稼働することを想定した軽量/高速なJavaフレームワークです。OSSとして提供されています。Kogitoのベースのフレームワークとして使われます。

ルール開発関連

DRL(Drools Rule Language)

DRL Rules

Drools上で実行するルールを記述する言語。when/thenで条件とアクションの組み合わせを定義していきます。

sample
rule "Underage"
  salience 15
  agenda-group "applicationGroup"
  when
    $application : LoanApplication()
    Applicant( age < 21 )
  then
    $application.setApproved( false );
    $application.setExplanation( "Underage" );
end

DMN(Decision Model and Notation)

Decision Model and Notation (DMN)

Drools上で実行するルールをグラフィカルに記述するための表記法。
OMGにより標準化が進められているようです。
参考: OMG - Decision Model and Notation

サンプル
image.png

その他

KIE community
KIEというコミュニティがDroolsやKogitoなどのオープンソースのプロジェクトをリードしているようです。KIEは"Knowledge is Everything"の頭文字らしい。

BAM OE の Decision Manager機能

BAM OEに含まれるDecision Manager機能について整理します。

ランタイム構成

BAM OEで提供されるビジネス・ルール実行のためのランタイムの形態としてはいくつかのバリエーションがあります。大きく分けると組み込み型とサーバー型に分かれます。

組み込み型(Embedded)

ルールを呼び出すクライアント・プログラムにルール部分(ルール実行用のランタイム・ライブラリも含む)を組み込んでパッケージングするイメージです。
image.png

サーバー型

ルールを実行する専用のサーバーを立ててそれをREST経由でクライアント・プログラムから呼び出すイメージです。
image.png

このタイプのルール・エンジンの実装についてもバリエーションがあります。

KIE Server
KIE Serverと呼ばれるルールエンジンが提供されています。このKIE ServerをJBossやWASなどのWebアプリケーション・サーバー上で稼働させることで、ルール・エンジンとしてのサービスを提供することができます。(以前から提供されているコンポーネント)
image.png

Kogito
先に示したKogitoというオープンソースをベースにしたルール・エンジンも提供されています。(比較的新しいコンポーネント)
image.png

いずれもコンテナとして稼働させることもできるので、OpenShiftやKubernetes上にデプロイすることも可能です。

ルール開発環境

BAM OEで稼働するルールを開発するための環境について整理します。

Red Hat CodeReady Studio

Eclipseベースの開発環境として Red Hat CodeReady Studioというツールが提供されていて、広く使われていたようです。
しかし、このツールは Red Hat Decision Manager V7.11からサポート終了 となっています。
参考: Red Hat Decision Manager 7 Supported Configurations

Business Central

Business Centralは、BAM OEの各種管理機能や開発ツールを提供するコンポーネントで、Webアプリケーションとして実装されています。JBossなどのWebアプリケーション・サーバー上で稼働し、ブラウザーのインターフェースを提供しています。ユーザーはブラウザーのインターフェースを使用してルールプロジェクトの開発や管理を行うことができます。

BAM OEではルールをなるべく簡単な形式で作成できるように、表形式でルールを記述するための機能(Guided Decision Table)や、ガイドに従ってルールを記述できる機能(Guided Rule)などが提供されています。GUIのインターフェースが提供されていてガイドに従って記述していくと、最終的にはDRLのコードが生成されることになります。

Guided Decision Tableイメージ
image.png

Guided Ruleイメージ
image.png

ルールの簡易的なテスト機能も提供されています。

テスト実行イメージ
image.png

ルールをグループ化して実行順序を制御するフローを作ることができますが、その場合はBPMNのフロー開発の機能を利用することができます。

ルール・フロー開発イメージ
image.png

VS Code

BAM OE固有の機能ではありませんが、以下のようなVS Code Extensionが提供されていますので、これらを利用することができそうです。

DRLでの開発:
Drools VS Code Extension

DMNでの開発:
Red Hat Business Automation Bundle
KIE Business Automation Bundle
Kogito Bundle

Excel

Business Centralで提供されているGuided Decision Tableのように、決められたフォーマットでExcel上の表にルールを記述することで、DRL形式に変換できる機能が提供されています。
Excelでルールを表形式で記述しプロジェクトに取り込む、といったことことができるようです。
参考: Part IV. Designing a decision service using spreadsheet decision tables

まとめ

Business Automation系の製品として、結局IBMは2系統の製品を提供する状況になっています。
1つは元々IBM製品として提供していたODMやBAWなど(Cloud Pak for Business Automationにも含まれて提供される)。
もう1つはRed Hatの製品として提供されていたDM, PAMの後継にあたるBAM OE。

IBM ODMとRed Hat DMという観点で見ると...
ODMは管理ツール(Decision Center)や開発環境(Rule Designer)が充実していて、特に業務寄りのユーザーがルール開発や管理しやすい仕組みが整っている印象。一方で仕組みが大仰でサクッととりあえず動かしてみるというところまで持っていくにはハードルが高いイメージ。
Red Hat DMはDRLでのルール記述がベースなので、業務寄りのユーザーがルール開発やメンテナンスを行うのはちょっとハードルが高い。GUIっぽいサポートツールはあるが、基本DRLを吐くためのツールであり内部の動きをある程度意識して開発しなければならない。DMNはなかなか便利そうではありますが複雑なことをやろうとするとちょっとハードルが高いのではないかという印象。一方、ルール稼働環境としてはスタンドアロンでの構成やコンテナとしての提供もあり環境面での小回りは効きそうな感じ(ODMはルールを格納するのにデータベース・サーバーが必要だが、Red Hat DMだとデータベース・サーバーは基本的に不要です)。

かなり大雑把なすみ分けとしては、ゴリゴリDRL、DMNでルール書いてメンテできるプロジェクト/あるいはExcelだけでルール書けば済むようなプロジェクトであればRed Hat DM系、業務寄りのユーザー含めてルールをきっちりメンテ/管理したいプロジェクトであればIBM ODM系を選択する、というのが一つの基準になるんでしょうか...。

6
4
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
6
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?