はじめに
前回の記事ではSample Server(サンプルとして提供されている構成)を使用してチュートリアルを実施する流れをみてきました。ここではLinux上にRESおよびDecision Centerを構成する作業を実施していきます。
関連記事
IBM Operational Decision Manager メモ - (1) 概要、Linuxへのインストール
IBM Operational Decision Manager メモ - (2) ルール開発から実行までの流れ
IBM Operational Decision Manager メモ - (3) Decision Center利用の流れ
IBM Operational Decision Manager メモ - (4) Linux上での環境セットアップ
IBM Operational Decision Manager メモ - (5) z/OS上での環境セットアップ
IBM Operational Decision Manager メモ - (6) z/OS上でのルール呼び出し
IBM Operational Decision Manager メモ - (7) zODM環境補足
環境構築
Windows10 のVirtualBox上にRHELを立てて、そこにODMサーバー環境を作っていきます。Rule Designer部分は前の記事でWindows側に構築したものをそのまま使います。最終的に構築したい環境のイメージは以下の通りです。
RHEL V8.5
ODM V8.11
Db2 V11.5.4
Windows10
Eclipse 4.16(2020-06R)
RES, Decision Center はJavaアプリとして実装されており、LibertyやWAS、JBossなどのJEEサーバー上で稼働させることができます。RESはJEEではなくスタンドアローンのJavaアプリとしても稼働させることも可能です。
※WASのクラスターを使用することでRESの冗長構成を行うことも可能です。
また、RES, Decision Centerでは各オブジェクト管理のためにデータベースを使うことになります。Db2, Oracle, H2, Derby, MySQLなど利用可能です。
ここでは、RES, Decision CenterのランタイムとしてはLibertyを使用し、データベースにはDb2を使用することにします(いずれもODMに付属のもの)。同一OS上に構築しますが、Libertyプロファイル、DatabaseはRES, Decision Center用に、それぞれ別のものを立てることにします(Db2インスタンスは共通とする)。
参考: IBM Operational Decision Manager 8.11 - Detailed System Requirements
構成 on Linux
データベースの準備
Db2インストール時に作成したインスタンス"db2inst1"を使用します。今回、RES、Decision Centerを同一OS上に構成しますが、それぞれデータベースは分けることにするので、それぞれのデータベースを作成しておきます。
RES用データベース作成
参考: Creating the Decision Server database
データベースを作成します。
[root@Test13 ~]# su - db2inst1
[db2inst1@Test13 ~]$ db2 create db ODMDS
DB20000I CREATE DATABASE コマンドが正常に完了しました。
[db2inst1@Test13 ~]$ db2 list db directory
システム・データベース・ディレクトリー
ディレクトリー中の項目数 = 1
データベース 1 項目:
データベース別名 = ODMDS
データベース名 = ODMDS
ローカル・データベース・ディレクトリー = /home/db2inst1
データベース・リリース・レベル = 15.00
コメント =
ディレクトリー項目タイプ = 間接
カタログ・データベース・パーティション番号 = 0
代替サーバー・ホスト名 =
代替サーバーのポート番号 =
ガイドに従ってバッファープールを作成しておきます。
[db2inst1@Test13 ~]$ db2 "CREATE BUFFERPOOL BP32K SIZE 2000 PAGESIZE 32K"
DB20000I SQL コマンドが正常に完了しました。
[db2inst1@Test13 ~]$ db2 "Select * from SYSCAT.BUFFERPOOLS"
BPNAME BUFFERPOOLID DBPGNAME NPAGES PAGESIZE ESTORE NUMBLOCKPAGES BLOCKSIZE NGNAME
-------------------------------------------------------------------------------------------------------------------------------- ------------ -------------------------------------------------------------------------------------------------------------------------------- ----------- ----------- ------ ------------- ----------- --------------------------------------------------------------------------------------------------------------------------------
IBMDEFAULTBP 1 - -2 4096 N 0 0 -
BP32K 2 - 2000 32768 N 0 0 -
2 レコードが選択されました。
Decision Center用データベース作成
参考: Creating the Decision Center database
データベースを作成します。
[db2inst1@Test13 ~]$ db2 create database ODMDC
DB20000I CREATE DATABASE コマンドが正常に完了しました。
[db2inst1@Test13 ~]$ db2 list db directory
システム・データベース・ディレクトリー
ディレクトリー中の項目数 = 2
データベース 1 項目:
データベース別名 = ODMDC
データベース名 = ODMDC
ローカル・データベース・ディレクトリー = /home/db2inst1
データベース・リリース・レベル = 15.00
コメント =
ディレクトリー項目タイプ = 間接
カタログ・データベース・パーティション番号 = 0
代替サーバー・ホスト名 =
代替サーバーのポート番号 =
データベース 2 項目:
データベース別名 = ODMDS
データベース名 = ODMDS
ローカル・データベース・ディレクトリー = /home/db2inst1
データベース・リリース・レベル = 15.00
コメント =
ディレクトリー項目タイプ = 間接
カタログ・データベース・パーティション番号 = 0
代替サーバー・ホスト名 =
代替サーバーのポート番号 =
RES(Rule Execution Server)の構成
参考: Configuring Rule Execution Server on the Liberty profile
基本的に上のガイドに従って構成していきます。
(1) Libertyサーバーの作成/基本構成
参考: Step 1: Deploying the Rule Execution Server management archive
Libertyサーバー"server01"を作成します。
[root@Test13 /opt/IBM/wlp/bin]# ./server create server01
サーバー server01 が作成されました。
ODMインストールディレクトリに提供されているwarファイルを、上で作成したLibertyサーバーのディレクトリにコピーします。(RESの機能はwarファイルとして提供されています)
res.warファイルのコピー
[root@Test13 ~]# cd /opt/IBM/ODM8110/executionserver/applicationservers/WLP
[root@Test13 /opt/IBM/ODM8110/executionserver/applicationservers/WLP]# ls -la
合計 136120
drwxr-xr-x. 2 root root 74 1月 12 18:06 .
drwxr-xr-x. 4 root root 31 1月 12 18:05 ..
-rw-r--r--. 1 root root 59160167 1月 12 18:06 DecisionRunner.war
-rw-r--r--. 1 root root 43291319 1月 12 18:06 DecisionService.war
-rw-r--r--. 1 root root 36926584 11月 10 14:30 res.war
[root@Test13 /opt/IBM/ODM8110/executionserver/applicationservers/WLP]# cp res.war /opt/IBM/wlp/usr/servers/server01/apps/
Db2提供のJDBCドライバーをLibertyのディレクトリにコピー
[root@Test13 /opt/IBM/wlp/usr/shared/resources]# mkdir db2
[root@Test13 /opt/IBM/wlp/usr/shared/resources]# cd db2
[root@Test13 /opt/IBM/wlp/usr/shared/resources/db2]# cp /opt/ibm/db2/V11.5/java/db2jcc4.jar .
[root@Test13 /opt/IBM/wlp/usr/shared/resources/db2]# ls -la
合計 6416
drwxr-xr-x. 2 root root 25 1月 21 18:52 .
drwxr-xr-x. 3 root root 17 1月 21 18:51 ..
-r--r--r--. 1 root root 6568346 1月 21 18:52 db2jcc4.jar
server.xmlを編集して以下の設定を行います。
<!-- Enable features -->
<featureManager>
<feature>jsp-2.3</feature>
<feature>servlet-3.1</feature>
<feature>jdbc-4.1</feature>
<feature>appSecurity-2.0</feature>
<feature>concurrent-1.0</feature>
</featureManager>
<!-- To access this server from a remote client add a host attribute to the following element, e.g. host="*" -->
<httpEndpoint id="defaultHttpEndpoint"
host="*"
httpPort="9080"
httpsPort="9443" />
<!-- RES data source -->
<library id="DB2JCCLib">
<fileset dir="${shared.resource.dir}/db2" includes="db2jcc4.jar"/>
</library>
<dataSource id="db2" jndiName="jdbc/resdatasource" isolationLevel="TRANSACTION_READ_COMMITTED">
<jdbcDriver libraryRef="DB2JCCLib"/>
<properties.db2.jcc databaseName="ODMDS" serverName="localhost" portNumber="50000"
user="db2inst1" password="db2inst1" />
</dataSource>
<!-- Web application security -->
<basicRegistry id="basic" realm="customRealm">
<user name="resAdmin" password="resAdmin"/>
<user name="resDeploy" password="resDeploy"/>
<user name="resMonitor" password="resMonitor"/>
<group name="resAdministrators">
<member name="resAdmin"/>
</group>
<group name="resDeployers">
<member name="resDeploy"/>
</group>
<group name="resMonitors">
<member name="resMonitor"/>
</group>
</basicRegistry>
<!-- RES console -->
<application type="war" id="res" name="res" location="${server.config.dir}/apps/res.war">
<application-bnd>
<security-role name="resAdministrators">
<group name="resAdministrators"/>
</security-role>
<security-role name="resDeployers">
<group name="resDeployers"/>
</security-role>
<security-role name="resMonitors">
<group name="resMonitors"/>
</security-role>
</application-bnd>
</application>
※Db2関連の設定についてはODMのマニュアルにはきちんと書いてくれていないので、以下のガイドを参考に設定します。
参考: Liberty での関連データベース接続の構成
(2) HTDS(Hosted Transparent Decision Service)用の構成
参考: Step 2: Deploying the hosted transparent decision service
HTDSはルールをWebサービス経由で呼び出す際に必要なコンポーネントで、これもWarファイルとして提供されているので、RESと同じLiberty上にデプロイします。
DecisionServer.warファイルのコピー
[root@Test13 ~]# cd /opt/IBM/wlp/usr/servers/server01/apps
[root@Test13 /opt/IBM/wlp/usr/servers/server01/apps]# cp /opt/IBM/ODM8110/executionserver/applicationservers/WLP/DecisionService.war .
[root@Test13 /opt/IBM/wlp/usr/servers/server01/apps]# ls -la
合計 78344
drwxr-x---. 3 root root 64 1月 21 19:28 .
drwxr-x---. 8 root root 175 1月 21 19:17 ..
-rw-r--r--. 1 root root 43291319 1月 21 19:28 DecisionService.war
drwxr-x---. 3 root root 21 1月 21 19:15 expanded
-rw-r--r--. 1 root root 36926584 1月 21 16:57 res.war
server.xmlを編集して以下の設定を追加します。
<!-- HTDS -->
<application type="war" id="DecisionService"
name="DecisionService"
location="${server.config.dir}/apps/DecisionService.war">
</application>
(3) テスト/シミュレーション用の構成
参考: Step 3: Deploying the testing and simulation archive
Decision Centerからテスト/シミュレーションを行う際に必要な設定を行います。これらの機能もWarファイルとして提供されているので、RESと同じLiberty上にデプロイします。
DecisionRunner.warファイルのコピー
[root@Test13 ~]# cd /opt/IBM/wlp/usr/servers/server01/apps
[root@Test13 /opt/IBM/wlp/usr/servers/server01/apps]# cp /opt/IBM/ODM8110/executionserver/applicationservers/WLP/DecisionRunner.war .
[root@Test13 /opt/IBM/wlp/usr/servers/server01/apps]# ls -la
合計 136120
drwxr-x---. 3 root root 90 1月 21 19:33 .
drwxr-x---. 8 root root 175 1月 21 19:33 ..
-rw-r--r--. 1 root root 59160167 1月 21 19:33 DecisionRunner.war
-rw-r--r--. 1 root root 43291319 1月 21 19:28 DecisionService.war
drwxr-x---. 3 root root 21 1月 21 19:15 expanded
-rw-r--r--. 1 root root 36926584 1月 21 16:57 res.war
server.xmlを編集して以下の設定を追加します。
<!-- Managed executor service for Decision Runner -->
<managedExecutorService jndiName="concurrent/drExecutorService"/>
<!-- Decision Runner -->
<application type="war" id="DecisionRunner" name="DecisionRunner" location="${server.config.dir}/apps/DecisionRunner.war">
<application-bnd>
<security-role name="resAdministrators">
<group name="resAdministrators" />
</security-role>
<security-role name="resDeployers">
<group name="resDeployers" />
</security-role>
</application-bnd>
</application>
最終的に、server.xmlは以下のようになります。
server.xml全体
<?xml version="1.0" encoding="UTF-8"?>
<server description="new server">
<!-- Enable features -->
<featureManager>
<feature>jsp-2.3</feature>
<feature>servlet-3.1</feature>
<feature>jdbc-4.1</feature>
<feature>appSecurity-2.0</feature>
<feature>concurrent-1.0</feature>
</featureManager>
<!-- To access this server from a remote client add a host attribute to the following element, e.g. host="*" -->
<httpEndpoint id="defaultHttpEndpoint"
host="*"
httpPort="9080"
httpsPort="9443" />
<!-- Automatically expand WAR files and EAR files -->
<applicationManager autoExpand="true"/>
<!-- RES data source -->
<library id="DB2JCCLib">
<fileset dir="${shared.resource.dir}/db2" includes="db2jcc4.jar"/>
</library>
<dataSource id="db2" jndiName="jdbc/resdatasource" isolationLevel="TRANSACTION_READ_COMMITTED">
<jdbcDriver libraryRef="DB2JCCLib"/>
<properties.db2.jcc databaseName="ODMDS" serverName="localhost" portNumber="50000"
user="db2inst1" password="db2inst1" />
</dataSource>
<!-- Web application security -->
<basicRegistry id="basic" realm="customRealm">
<user name="resAdmin" password="resAdmin"/>
<user name="resDeploy" password="resDeploy"/>
<user name="resMonitor" password="resMonitor"/>
<group name="resAdministrators">
<member name="resAdmin"/>
</group>
<group name="resDeployers">
<member name="resDeploy"/>
</group>
<group name="resMonitors">
<member name="resMonitor"/>
</group>
</basicRegistry>
<!-- RES console -->
<application type="war" id="res" name="res" location="${server.config.dir}/apps/res.war">
<application-bnd>
<security-role name="resAdministrators">
<group name="resAdministrators"/>
</security-role>
<security-role name="resDeployers">
<group name="resDeployers"/>
</security-role>
<security-role name="resMonitors">
<group name="resMonitors"/>
</security-role>
</application-bnd>
</application>
<!-- HTDS -->
<application type="war" id="DecisionService"
name="DecisionService"
location="${server.config.dir}/apps/DecisionService.war">
</application>
<!-- Managed executor service for Decision Runner -->
<managedExecutorService jndiName="concurrent/drExecutorService"/>
<!-- Decision Runner -->
<application type="war" id="DecisionRunner" name="DecisionRunner" location="${server.config.dir}/apps/DecisionRunner.war">
<application-bnd>
<security-role name="resAdministrators">
<group name="resAdministrators" />
</security-role>
<security-role name="resDeployers">
<group name="resDeployers" />
</security-role>
</application-bnd>
</application>
</server>
httpEndpoint以下に、host="*"
を追記しています(指定無しだとデフォルトで127.0.0.1にしかポートがバインドされないので外部からのアクセスができません)。
ポート番号はデフォルトから変更していないので、http用ポート:9080、https用ポート:9443が使用されます。必要に応じてfiewallの設定など行っておきます。
Libertyを起動します。
※事前にDb2は起動させておきます。また、/opt/IBM/wlp/bin/
をPATHに通しておきます。
[root@Test13 ~]# server start server01
サーバー server01 を始動中です。
サーバー server01 がプロセス ID 5393 で始動しました。
(4) RES用Db2の構成
参考: Creating a schema for the Rule Execution Server database
RESを使用する際ルールの情報などをDb2に保持することになりますが、そのために各種RES用のテーブルなどをDb2側に準備しておく必要があります。これらは、RESのコンソールに最初にアクセスした時に開くウィザードで設定することができます。
ブラウザから http://xxx:9080/res
にアクセスしてRESコンソールにログインします。(以降のスクリーンショットはWindows上からアクセスしており、ポートフォワードで19080→9080の変換を行っています)
Db2の構成がされていないので、まずRuleApp用のウィザードが開きます。内容を確認して次へ。
データベース・スキーマとしてdb2を選択、先に作成したバッファープール名を指定し、次へ。
※ちなみにデータベース・スキーマのプルダウンで選択できるメニューは以下の通りです。
※WebのWizardを使ってスキーマを作成する場合、DBの構成として"Automatic storage"機能が使用されるらしい。Db2 V11.5の場合デフォルトでAutomatic storageが有効になっているので特に対応は不要と判断。
参考: Databases use automatic storage by default
Automatic storage can make storage management easier. Rather than managing storage at the table space level using explicit container definitions, storage is managed at the storage group level and the responsibility of creating, extending and adding containers is taken over by the database manager.
Note: Although, you can create a database specifying the AUTOMATIC STORAGE NO clause, the AUTOMATIC STORAGE clause is deprecated and might be removed from a future release.
By default, all databases are created with automatic storage. However, if the database is created specifying the AUTOMATIC STORAGE NO clause it cannot use automatic storage managed table spaces.
"SQLスキーマ"db2inst1"の作成"にチェック、"SQLのdropステートメントを保持"にチェックし、実行。
"SQLステートメントが正常に実行されました"のメッセージが出力されればOK。
※何度かTry&Errorを繰り返したのでメッセージ出力のされ方は状況によって異なると思います。新規で作成する場合はDROPは基本的に警告になるが無視してOK。BufferPool "BP32K"はここでは作成してくれないので事前作成しておく必要あり!!!
次に、Java XOM用のウィザードが開くので内容を確認して次へ。
"SQLのdropステートメントを保持"にチェックし、実行。
"SQLステートメントが正常に実行されました"のメッセージが出力されればOK。
(5) 診断
参考: Completing the configuration of Rule Execution Server
RESコンソールにログインし、"診断"タブをクリックします。
Decision Runnerの診断が失敗しています。ここに示されている"インストール・ウィザードを実行してデータベース表を作成してください"のリンクをクリックします。
Decision Runner用のウィザードが開くので、内容を確認して次へ。
"SQLスキーマ"db2inst1"の作成"にチェック、"SQLのdropステートメントを保持"にチェックし、実行。
"SQLステートメントが正常に実行されました"のメッセージが出力されればOK。
RESコンソールの"診断"タブに戻って再実行ボタンをクリックし、結果を確認。以下のようにエラーが出ていなければOK。
Decision Centerの構成
参考: Configuring Decision Center on the Liberty profile
基本的に上のガイドに従って構成していきます。
(0) 事前準備
参考: Before you start
Libertyサーバー作成
[root@Test13 /opt/IBM/wlp/bin]# ./server create server02
サーバー server02 が作成されました。
環境変数設定
[root@Test13 ~]# env | grep WLP
WLP_HOME=/opt/IBM/wlp
[root@Test13 ~]# env | grep JAVA
JAVA_HOME=/usr/lib/jvm/ibm-semeru-open-8-jdk
(1) Db接続構成
参考: Step 1: Creating a data source
Db2用のJDBCドライバーのファイル(jar)はRES構成でLibertyの共通のディレクトリにコピー済み(/opt/IBM/wlp/usr/shared/resources/db2/db2jcc4.jar
)。
server.xml編集
<!-- Decision Center data source -->
<library id="DB2JCCLib">
<fileset dir="${shared.resource.dir}/db2" includes="db2jcc4.jar"/>
</library>
<dataSource id="db2" jndiName="jdbc/ilogDataSource" isolationLevel="TRANSACTION_READ_COMMITTED">
<jdbcDriver libraryRef="DB2JCCLib"/>
<properties.db2.jcc databaseName="ODMDC" serverName="localhost" portNumber="50000"
user="db2inst1" password="db2inst1" />
</dataSource>
※Db2関連の設定についてはODMのマニュアルにはきちんと書いてくれていないので、以下のガイドを参考に設定します。
参考: Liberty での関連データベース接続の構成
(2) ユーザー設定
参考: Step 2: Configuring user access to Decision Center
ここではユーザー情報はbasec user registry(server.xml内にユーザー情報を持たせる形式)を使用します。LDAPは使用しません。
<!-- Web application security -->
<basicRegistry id="basic" realm="customRealm">
<user name="rtsAdmin" password="rtsAdmin"/>
<user name="Jane" password="Jane"/>
<user name="Bea" password="Bea"/>
<user name="Rex" password="Rex"/>
<group name="AdminGroup">
<member name="rtsAdmin"/>
</group>
<group name="InstallGroup">
<member name="rtsAdmin"/>
</group>
</basicRegistry>
(3) Decision Center用Warファイルのデプロイ
参考: Step 3: Deploying the Decision Center WAR files
Decision CenterもLiberty上のアプリケーション(Warファイル)として実装されているので、これらをデプロイします。
jvmオプションを指定するため、jvm.optionsファイルを作成し、以下の設定を行います。
-Xms4096m
-Xmx8192m
-Dclient.encoding.override=UTF-8
-Dfile.encoding=UTF-8
Warファイルのコピー
[root@Test13 ~]# cd /opt/IBM/wlp/usr/servers/server02/apps
[root@Test13 /opt/IBM/wlp/usr/servers/server02/apps]# cp /opt/IBM/ODM8110/teamserver/applicationservers/WLP/decisioncenter.war .
[root@Test13 /opt/IBM/wlp/usr/servers/server02/apps]# cp /opt/IBM/ODM8110/teamserver/applicationservers/WLP/decisioncenter-api.war .
[root@Test13 /opt/IBM/wlp/usr/servers/server02/apps]# cp /opt/IBM/ODM8110/teamserver/applicationservers/WLP/decisionmodel.war .
[root@Test13 /opt/IBM/wlp/usr/servers/server02/apps]# ls -la
合計 496504
drwxr-x---. 2 root root 87 1月 22 14:06 .
drwxr-x---. 5 root root 126 1月 22 14:02 ..
-rw-r--r--. 1 root root 113465965 1月 22 14:05 decisioncenter-api.war
-rw-r--r--. 1 root root 285624581 1月 22 14:05 decisioncenter.war
-rw-r--r--. 1 root root 109324402 1月 22 14:06 decisionmodel.war
server.xmlを編集します。
最終的に、server.xmlは以下のようになります。
server.xml全体
<?xml version="1.0" encoding="UTF-8"?>
<server description="new server">
<!-- Enable features -->
<featureManager>
<feature>jsp-2.3</feature>
<feature>servlet-3.1</feature>
<feature>jdbc-4.1</feature>
<feature>appSecurity-2.0</feature>
<feature>jaxrs-2.0</feature>
<feature>concurrent-1.0</feature>
<feature>jndi-1.0</feature>
<feature>ssl-1.0</feature>
<feature>ldapRegistry-3.0</feature>
</featureManager>
<!-- To access this server from a remote client add a host attribute to the following element, e.g. host="*" -->
<httpEndpoint id="defaultHttpEndpoint"
host="*"
httpPort="9081"
httpsPort="9444" />
<!-- Automatically expand WAR files and EAR files -->
<applicationManager autoExpand="true"/>
<!-- Decision Center data source -->
<library id="DB2JCCLib">
<fileset dir="${shared.resource.dir}/db2" includes="db2jcc4.jar"/>
</library>
<dataSource id="db2" jndiName="jdbc/ilogDataSource" isolationLevel="TRANSACTION_READ_COMMITTED">
<jdbcDriver libraryRef="DB2JCCLib"/>
<properties.db2.jcc databaseName="ODMDC" serverName="localhost" portNumber="50000"
user="db2inst1" password="db2inst1" />
</dataSource>
<httpSession cookieName="DCSESSIONID"
invalidateOnUnauthorizedSessionRequestException="true"/>
<webContainer deferServletLoad="false"
enableDefaultIsElIgnoredInTag="true"
enableJspMappingOverride="true"/>
<!-- Web application security -->
<basicRegistry id="basic" realm="customRealm">
<user name="rtsAdmin" password="rtsAdmin"/>
<user name="Jane" password="Jane"/>
<user name="Bea" password="Bea"/>
<user name="Rex" password="Rex"/>
<group name="AdminGroup">
<member name="rtsAdmin"/>
</group>
<group name="InstallGroup">
<member name="rtsAdmin"/>
</group>
</basicRegistry>
<!-- Business console -->
<application type="war" id="decisioncenter"
name="decisioncenter"
location="${server.config.dir}/apps/decisioncenter.war">
<classloader delegation="parentLast" />
<application-bnd>
<security-role name="rtsAdministrator">
<group name="AdminGroup"/>
</security-role>
<security-role name="rtsInstaller">
<group name="InstallGroup"/>
</security-role>
<security-role name="rtsUser">
<special-subject type="ALL_AUTHENTICATED_USERS" />
</security-role>
</application-bnd>
</application>
<!-- DC REST API -->
<application type="war" id="decisioncenter-api"
name="decisioncenter-api"
location="${server.config.dir}/apps/decisioncenter-api.war">
<classloader delegation="parentLast" />
<application-bnd>
<security-role name="rtsAdministrator">
<group name="AdminGroup"/>
</security-role>
<security-role name="rtsInstaller">
<group name="InstallGroup"/>
</security-role>
<security-role name="rtsUser">
<special-subject type="ALL_AUTHENTICATED_USERS" />
</security-role>
</application-bnd>
</application>
<!-- Decision modeling -->
<application type="war" id="decisionmodel"
name="decisionmodel"
location="${server.config.dir}/apps/decisionmodel.war">
<classloader delegation="parentLast" />
<application-bnd>
<security-role name="rtsAdministrator">
<group name="AdminGroup"/>
</security-role>
<security-role name="rtsInstaller">
<group name="InstallGroup"/>
</security-role>
<security-role name="rtsUser">
<special-subject type="ALL_AUTHENTICATED_USERS" />
</security-role>
</application-bnd>
</application>
</server>
httpEndpoint以下に、host="*"
を追記しています(指定無しだとデフォルトで127.0.0.1にしかポートがバインドされないので外部からのアクセスができません)。
ポート番号はRESとバッティングしないように、http用ポート:9081、https用ポート:9444に変更しています。必要に応じてfiewallの設定など行っておきます。
(4) Db2の構成
参考: Completing the configuration of Decision Center
さて、ここで、RESと同じようにDecision CenterもDb2上にテーブルなどを作成する必要があるらしいのですが、その作成方法についてのガイドが見当たらりません。前のバージョン(ODM V8.10)であればDecision Center Enterprise Consoleという機能があってそこに最初にアクセスしたタイミングでRESと同様ウィザード形式でDb2の設定を行うことが可能だったらしいです。
参考: ODM V8.10 - Installation Settings Wizard: Creating the database schema
ただし、ODM V8.11からはこのEnterprise Consoleというのは削除されており、この方法が使えません。
参考: Creating the database schema and uploading message files
この辺りの記述を見ると、antスクリプトを使用してDb2の設定ができるらしいのですが、このスクリプトを実行するには extensionModel, extensionData なるものがそれぞれ必要なようで、それらの作り方など詳細がよく分かりません。
上のODM V8.10のマニュアルに以下のような記述があり、どうやら<instdir>\teamserver\bin
以下に提供されているファイルを使っていたらしい。
Under Select the extension files you want to use, select one of the following options:
- Default extensions: The default extensions are available in \teamserver\bin.
- Custom extensions (brmx/brdx): Specify the location of your model extension (.brmx) and data extension (.brdx) files.
- Custom extensions (zip): Specify the location of your .zip files.
ODM V8.11の環境を見てみると以下のようなファイルが提供されていました。これを使ってantスクリプト実行すればよさそうです。
[root@Test13 /opt/IBM/ODM8110/teamserver/bin]# ls -la
合計 124
drwxr-xr-x. 2 root root 4096 1月 25 09:10 .
drwxr-xr-x. 8 root root 133 1月 12 18:05 ..
-rw-r--r--. 1 root root 42176 11月 10 20:06 build.xml
-rw-r--r--. 1 root root 615 11月 10 20:23 defaultExtension.brdx
-rw-r--r--. 1 root root 1569 11月 10 20:23 defaultExtension.brmx
-rw-r--r--. 1 root root 933 11月 10 20:23 defaultextensionmessages_de.properties
-rw-r--r--. 1 root root 924 11月 10 20:23 defaultextensionmessages_en.properties
-rw-r--r--. 1 root root 951 11月 10 20:23 defaultextensionmessages_es.properties
-rw-r--r--. 1 root root 1005 11月 10 20:23 defaultextensionmessages_fr.properties
-rw-r--r--. 1 root root 965 11月 10 20:23 defaultextensionmessages_it.properties
-rw-r--r--. 1 root root 1254 11月 10 20:23 defaultextensionmessages_ja.properties
-rw-r--r--. 1 root root 1163 11月 10 20:23 defaultextensionmessages_ko.properties
-rw-r--r--. 1 root root 943 11月 10 20:23 defaultextensionmessages_nl.properties
-rw-r--r--. 1 root root 1009 11月 10 20:23 defaultextensionmessages_pl.properties
-rw-r--r--. 1 root root 965 11月 10 20:23 defaultextensionmessages_pt_BR.properties
-rw-r--r--. 1 root root 2002 11月 10 20:23 defaultextensionmessages_ru.properties
-rw-r--r--. 1 root root 943 11月 10 20:23 defaultextensionmessages_sv.properties
-rw-r--r--. 1 root root 1104 11月 10 20:23 defaultextensionmessages_zh.properties
-rw-r--r--. 1 root root 1110 11月 10 20:23 defaultextensionmessages_zh_TW.properties
-rw-r--r--. 1 root root 6046 11月 10 20:06 l10n-distrib-macrodefs.xml
-rw-r--r--. 1 root root 931 11月 10 20:06 teamserver-anttasks.properties
(この辺、全然V8.11のマニュアルから見つけられない...。不親切極まりないですなぁ。初めて構成する人、本当にこのマニュアルで構成できるんだろうか???)
上のファイルを使ってantを実行していきますが、このantスクリプトではDecision Centerに接続するようなので事前にDecision Center用のLibertyを起動しておきます。(当然Db2も事前に起動しておきます。)
[root@Test13 /]# server start server02
サーバー server02 を始動中です。
サーバー server02 がプロセス ID 16276 で始動しました
以下のようにant実行します。
[root@Test13 /opt/IBM/ODM8110/teamserver/bin]# ant set-extensions -DextensionModel=/opt/IBM/ODM8110/teamserver/bin/defaultExtension.brmx -DextensionData=/opt/IBM/ODM8110/teamserver/bin/defaultExtension.brdx -Dserver.url=http://localhost:9081/decisioncenter
Buildfile: /opt/IBM/ODM8110/teamserver/bin/build.xml
set-extensions:
[set-extensions] [serverURL] 'http://localhost:9081/decisioncenter'
[set-extensions] [datasourceName] 'jdbc/ilogDataSource'
[set-extensions] [username] 'rtsAdmin'
[set-extensions] [password] '********'
[set-extensions] [extensionModel] '/opt/IBM/ODM8110/teamserver/bin/defaultExtension.brmx'
[set-extensions] [extensionData] '/opt/IBM/ODM8110/teamserver/bin/defaultExtension.brdx'
[set-extensions] 1 25, 2022 2:25:38 午後 com.ibm.rules.decisioncenter.remoting.internal.RemoteSessionHttpExecutorBuilder log
[set-extensions] 情報: {"url":"http://localhost:9081/decisioncenter","datasource":"jdbc/ilogDataSource","username":"rtsAdmin","message":"Sign in successfully","date":"2022/01/25 14:25:38"}
[set-extensions] Generating tables creation script ...
[set-extensions] Executing tables creation script ...
[set-extensions] Script was executed successfully
[set-extensions] Uploading extensions ...
[set-extensions] Initializing hierarchies data ...
[set-extensions] 1 25, 2022 2:27:20 午後 com.ibm.rules.decisioncenter.remoting.internal.RemoteSessionHttpExecutorBuilder log
[set-extensions] 情報: {"url":"http://localhost:9081/decisioncenter","datasource":"jdbc/ilogDataSource","username":"rtsAdmin","message":"Sign out successfully","date":"2022/01/25 14:27:20"}
BUILD SUCCESSFUL
Total time: 1 minute 43 seconds
補足
上のant実行時に、Libertyのmessages.logに以下のような謎のエラーが出ていました。バグっぽい気もしますがselect count(*)
でのデッドロックなので影響は無いかと思い一旦放置します。
[22/01/25 14:25:40:471 JST] 00000034 ilog.rules.teamserver.model.IlrModelInfo W Can't find resource: /ilog/rules/teamserver/model/biggerExtension.brmx
[22/01/25 14:25:40:471 JST] 00000034 ilog.rules.teamserver.model.IlrModelInfo W Can't find resource: /ilog/rules/teamserver/model/biggerExtension.brdx
[22/01/25 14:27:16:319 JST] 0000004f eamserver.transaction.logger.IlrSQLInvocationExceptionLogger E select count(*) from DB2INST1.RTSRESOURCE
Error: com.ibm.db2.jcc.am.SqlTransactionRollbackException: デッドロックまたはタイムアウトのため、現在のトランザクションがロールバックされました。 理由コード "2". SQLCODE=-911, SQLSTATE=40001, DRIVER=4.27.25
at <unknown class>.a(b7.java:797)
at <unknown class>.a(b7.java:66)
at <unknown class>.a(b7.java:140)
at <unknown class>.c(k6.java:2825)
at <unknown class>.s(ab.java:1668)
at <unknown class>.i(ab.java:209)
at <unknown class>.b(ab.java:96)
at <unknown class>.a(p.java:32)
at <unknown class>.i(av.java:150)
at <unknown class>.al(k6.java:2204)
at <unknown class>.bq(k7.java:3763)
at <unknown class>.a(k7.java:4642)
at <unknown class>.b(k7.java:4215)
at <unknown class>.bd(k7.java:785)
at <unknown class>.executeQuery(k7.java:750)
at <unknown class>.executeQuery(WSJdbcPreparedStatement.java:475)
at sun.reflect.GeneratedMethodAccessor124.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at ilog.rules.teamserver.transaction.logger.IlrStatementInvocationHandler.executeStatement(IlrStatementInvocationHandler.java:66)
at ilog.rules.teamserver.transaction.logger.IlrPreparedStatementInvocationHandler.invoke(IlrPreparedStatementInvocationHandler.java:38)
at com.sun.proxy.$Proxy282.executeQuery(Unknown Source)
at ilog.rules.teamserver.ejb.service.dao.IlrElementDAOJDBC.canSelectTable(IlrElementDAOJDBC.java:1045)
at ilog.rules.teamserver.ejb.service.dao.IlrElementDAOJDBC.tableExists(IlrElementDAOJDBC.java:1069)
at ilog.rules.teamserver.ejb.service.dao.IlrElementDAOJDBC.tableExists(IlrElementDAOJDBC.java:1111)
at ilog.rules.teamserver.ejb.service.dao.IlrElementDAOJDBC.checkTablesExistAndInitialized(IlrElementDAOJDBC.java:1167)
at ilog.rules.teamserver.ejb.service.IlrSessionFacadeImpl.checkTablesExistAndInitialized(IlrSessionFacadeImpl.java:9958)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at ilog.rules.teamserver.transaction.IlrTransactionalInvocationHandler.invoke(IlrTransactionalInvocationHandler.java:107)
at com.sun.proxy.$Proxy262.checkTablesExistAndInitialized(Unknown Source)
at ilog.rules.teamserver.model.impl.IlrAbstractSession.checkTablesExistAndInitialized(IlrAbstractSession.java:2706)
at com.ibm.rules.decisioncenter.web.search.IndexerServiceThread.getRefreshPeriod(IndexerServiceThread.java:193)
at com.ibm.rules.decisioncenter.web.search.IndexerServiceThread$Service.run(IndexerServiceThread.java:114)
at com.google.common.util.concurrent.AbstractExecutionThreadService$1$2.run(AbstractExecutionThreadService.java:66)
at com.google.common.util.concurrent.Callables$4.run(Callables.java:119)
at java.lang.Thread.run(Thread.java:826)
[22/01/25 14:27:16:346 JST] 0000004f com.ibm.rules.decisioncenter.web.search.IndexerService I Database is still not initialized. Retry in 5 minutes
[22/01/25 14:27:17:313 JST] 00000062 eamserver.transaction.logger.IlrSQLInvocationExceptionLogger E select count(*) from DB2INST1.RTSRESOURCE
Error: com.ibm.db2.jcc.am.SqlTransactionRollbackException: デッドロックまたはタイムアウトのため、現在のトランザクションがロールバックされました。 理由コード "2". SQLCODE=-911, SQLSTATE=40001, DRIVER=4.27.25
at <unknown class>.a(b7.java:797)
at <unknown class>.a(b7.java:66)
at <unknown class>.a(b7.java:140)
at <unknown class>.c(k6.java:2825)
at <unknown class>.s(ab.java:1668)
at <unknown class>.i(ab.java:209)
at <unknown class>.b(ab.java:96)
at <unknown class>.a(p.java:32)
at <unknown class>.i(av.java:150)
at <unknown class>.al(k6.java:2204)
at <unknown class>.bq(k7.java:3763)
at <unknown class>.a(k7.java:4642)
at <unknown class>.b(k7.java:4215)
at <unknown class>.bd(k7.java:785)
at <unknown class>.executeQuery(k7.java:750)
at <unknown class>.executeQuery(WSJdbcPreparedStatement.java:475)
at sun.reflect.GeneratedMethodAccessor124.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at ilog.rules.teamserver.transaction.logger.IlrStatementInvocationHandler.executeStatement(IlrStatementInvocationHandler.java:66)
at ilog.rules.teamserver.transaction.logger.IlrPreparedStatementInvocationHandler.invoke(IlrPreparedStatementInvocationHandler.java:38)
at com.sun.proxy.$Proxy282.executeQuery(Unknown Source)
at ilog.rules.teamserver.ejb.service.dao.IlrElementDAOJDBC.canSelectTable(IlrElementDAOJDBC.java:1045)
at ilog.rules.teamserver.ejb.service.dao.IlrElementDAOJDBC.tableExists(IlrElementDAOJDBC.java:1069)
at ilog.rules.teamserver.ejb.service.dao.IlrElementDAOJDBC.tableExists(IlrElementDAOJDBC.java:1111)
at ilog.rules.teamserver.ejb.service.dao.IlrElementDAOJDBC.checkTablesExistAndInitialized(IlrElementDAOJDBC.java:1167)
at ilog.rules.teamserver.ejb.service.IlrSessionFacadeImpl.checkTablesExistAndInitialized(IlrSessionFacadeImpl.java:9958)
at ilog.rules.teamserver.ejb.service.IlrSessionFacadeImpl.loginInitializationWithTxnPart1(IlrSessionFacadeImpl.java:316)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at ilog.rules.teamserver.transaction.IlrTransactionalInvocationHandler.invoke(IlrTransactionalInvocationHandler.java:107)
at com.sun.proxy.$Proxy262.loginInitializationWithTxnPart1(Unknown Source)
at ilog.rules.teamserver.ejb.service.IlrLocalSessionImpl.loginInitializationWithTxnPart1(IlrLocalSessionImpl.java:69)
at ilog.rules.teamserver.ejb.service.IlrSessionFacadeImpl.login(IlrSessionFacadeImpl.java:275)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at ilog.rules.teamserver.transaction.IlrTransactionalInvocationHandler.invoke(IlrTransactionalInvocationHandler.java:107)
at com.sun.proxy.$Proxy262.login(Unknown Source)
at ilog.rules.teamserver.ejb.service.IlrLocalStealthySessionFactory.makeSession(IlrLocalStealthySessionFactory.java:95)
at ilog.rules.teamserver.ejb.service.IlrLocalStealthySessionFactory.connect(IlrLocalStealthySessionFactory.java:59)
at ilog.rules.teamserver.ejb.service.IlrLocalStealthySessionFactory.connect(IlrLocalStealthySessionFactory.java:45)
at com.ibm.rules.decisioncenter.sqllogging.LongSqlQueryManagerThreadService.createSession(LongSqlQueryManagerThreadService.java:313)
at com.ibm.rules.decisioncenter.sqllogging.LongSqlQueryManagerThreadService.updateSqlLoggingParameter(LongSqlQueryManagerThreadService.java:259)
at com.ibm.rules.decisioncenter.sqllogging.LongSqlQueryManagerThreadService.timedParametersUpdate(LongSqlQueryManagerThreadService.java:167)
at com.ibm.rules.decisioncenter.sqllogging.LongSqlQueryManagerThreadService.run(LongSqlQueryManagerThreadService.java:154)
at com.google.common.util.concurrent.AbstractExecutionThreadService$1$2.run(AbstractExecutionThreadService.java:66)
at com.google.common.util.concurrent.Callables$4.run(Callables.java:119)
at java.lang.Thread.run(Thread.java:826)
[22/01/25 14:27:17:643 JST] 0000002b ilog.rules.teamserver.model.IlrModelInfo W Can't find resource: /ilog/rules/teamserver/model/biggerExtension.brmx
[22/01/25 14:27:17:644 JST] 0000002b ilog.rules.teamserver.model.IlrModelInfo W Can't find resource: /ilog/rules/teamserver/model/biggerExtension.brdx
[22/01/25 14:27:17:660 JST] 00000062 s.decisioncenter.sqllogging.LongSqlQueryManagerThreadService I Schema not available, long SQL query logging parameters persistence is aborted
[22/01/25 14:27:18:222 JST] 00000029 ilog.rules.teamserver.dbmapping.schema.IlrSQLAdapter I Running checkMaxColumnLength() for datasource 'jdbc/ilogDataSource', initial length = 128
[22/01/25 14:27:18:787 JST] 00000029 ilog.rules.teamserver.dbmapping.schema.IlrSQLAdapter I Completed checkMaxColumnLength() for datasource 'jdbc/ilogDataSource', final length = 128
[22/01/25 14:27:37:973 JST] 0000005c com.ibm.rules.decisioncenter.json I {"date":"2022\/01\/25 14:27:37","system":{"ldapMode":"None","solrLocation":"\/tmp\/decisioncenter-solr-v6","buildCachePath":"\/tmp\/rtscache_root","NPSEnabled":"true","solrMode":"SolrEmbedded"},"datasource":{"schemaVersion":"JRules 8.10.5","driver":"DB2\/LINUXX8664 SQL110540","isolationLevel":"TRANSACTION_READ_COMMITTED","datasourceName":"jdbc\/ilogDataSource"},"userAgent":"Mozilla\/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit\/537.36 (KHTML, like Gecko) Chrome\/97.0.4692.99 Safari\/537.36","message":"Connected user","user":{"displayName":"rtsAdmin","groups":[],"userName":"rtsAdmin"},"timestamp":1643088457788}
[22/01/25 14:27:38:705 JST] 0000006a com.ibm.ws.logging.internal.impl.IncidentImpl I FFDC1015I: FFDC 発生事象が作成されました: "sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target com.ibm.ws.ssl.core.WSX509TrustManager checkServerTrusted" ロケーション: ffdc_22.01.25_14.27.38.0.log
[22/01/25 14:27:38:710 JST] 0000006a com.ibm.ws.ssl.core.WSX509TrustManager E CWPKI0823E: SSL ハンドシェークの失敗: SubjectDN [CN=www.ibm.com, O=International Business Machines Corporation, L=Armonk, ST=New York, C=US] の署名者がホスト [www.ibm.com:443] から送信されました。 SSL 構成別名 [defaultSSLConfig] にあるトラストストア [/opt/IBM/wlp/usr/servers/server02/resources/security/key.p12] にこの署名者を追加する必要がある可能性があります。 SSL ハンドシェーク例外からの拡張エラー・メッセージ: [PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target]
[22/01/25 14:27:38:762 JST] 0000006a com.ibm.ws.ssl.core.WSX509TrustManager E CWPKI0823E: SSL ハンドシェークの失敗: SubjectDN [CN=www.ibm.com, O=International Business Machines Corporation, L=Armonk, ST=New York, C=US] の署名者がホスト [www.ibm.com:443] から送信されました。 SSL 構成別名 [defaultSSLConfig] にあるトラストストア [/opt/IBM/wlp/usr/servers/server02/resources/security/key.p12] にこの署名者を追加する必要がある可能性があります。 SSL ハンドシェーク例外からの拡張エラー・メッセージ: [PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target]
[22/01/25 14:27:38:764 JST] 0000006a ilog.rules.teamserver.model.util.HelpService W Help service is not accessible [PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target]
[22/01/25 14:27:39:648 JST] 00000034 com.ibm.rules.decisioncenter.services.dmn E Error trying to reach http://localhost:19081/decisionmodel. Cannot get resource directory. We will try 'cachebustdir' by default
[22/01/25 14:27:40:819 JST] 00000034 com.ibm.ws.webcontainer.servlet I SRVE0242I: [decisioncenter] [/decisioncenter] [/WEB-INF/views/page.jsp]: 初期化が成功しました。
[22/01/25 14:27:41:427 JST] 0000002d com.ibm.ws.webcontainer.servlet I SRVE0242I: [decisioncenter] [/decisioncenter] [dmn]: 初期化が成功しました。
[22/01/25 14:27:41:632 JST] 0000002d com.ibm.ws.webcontainer.util.ApplicationErrorUtils E SRVE0777E: アプリケーション・クラス 'org.apache.http.impl.conn.DefaultHttpClientConnectionOperator.connect:156' によって例外がスローされました
org.apache.http.conn.HttpHostConnectException: Connect to localhost:19081 [localhost/127.0.0.1, localhost/0:0:0:0:0:0:0:1] failed: 接続を拒否されました (Connection refused)
at org.apache.http.impl.conn.DefaultHttpClientConnectionOperator.connect(DefaultHttpClientConnectionOperator.java:156)
at org.apache.http.impl.conn.PoolingHttpClientConnectionManager.connect(PoolingHttpClientConnectionManager.java:376)
at org.apache.http.impl.execchain.MainClientExec.establishRoute(MainClientExec.java:393)
at org.apache.http.impl.execchain.MainClientExec.execute(MainClientExec.java:236)
at org.apache.http.impl.execchain.ProtocolExec.execute(ProtocolExec.java:186)
at org.apache.http.impl.execchain.RetryExec.execute(RetryExec.java:89)
at org.apache.http.impl.execchain.RedirectExec.execute(RedirectExec.java:110)
at org.apache.http.impl.client.InternalHttpClient.doExecute(InternalHttpClient.java:185)
at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:118)
at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:56)
at org.mitre.dsmiley.httpproxy.ProxyServlet.doExecute(ProxyServlet.java:333)
at com.ibm.rules.decisioncenter.web.core.servlets.DmnProxyServlet.doExecute(DmnProxyServlet.java:134)
at org.mitre.dsmiley.httpproxy.ProxyServlet.service(ProxyServlet.java:275)
at com.ibm.rules.decisioncenter.web.core.servlets.DmnProxyServlet.service(DmnProxyServlet.java:143)
at <unknown class>.service(HttpServlet.java:790)
at <unknown class>.service(ServletWrapper.java:1258)
at <unknown class>.handleRequest(ServletWrapper.java:746)
at <unknown class>.handleRequest(ServletWrapper.java:443)
at <unknown class>.invokeTarget(WebAppFilterChain.java:183)
at <unknown class>.doFilter(WebAppFilterChain.java:94)
at com.ibm.rules.decisioncenter.web.core.filters.SecurityCheckPointFilter.doFilter(SecurityCheckPointFilter.java:104)
at <unknown class>.doFilter(FilterInstanceWrapper.java:201)
at <unknown class>.doFilter(WebAppFilterChain.java:91)
at com.ibm.rules.decisioncenter.web.core.filters.SessionFilter.doFilter(SessionFilter.java:64)
at <unknown class>.doFilter(FilterInstanceWrapper.java:201)
at <unknown class>.doFilter(WebAppFilterChain.java:91)
at com.ibm.rules.decisioncenter.web.core.filters.HttpPUTRequestFilter.doFilterInternal(HttpPUTRequestFilter.java:85)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
at <unknown class>.doFilter(FilterInstanceWrapper.java:201)
at <unknown class>.doFilter(WebAppFilterChain.java:91)
at org.springframework.boot.web.servlet.support.ErrorPageFilter.doFilter(ErrorPageFilter.java:126)
at org.springframework.boot.web.servlet.support.ErrorPageFilter.access$000(ErrorPageFilter.java:64)
at org.springframework.boot.web.servlet.support.ErrorPageFilter$1.doFilterInternal(ErrorPageFilter.java:101)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
at org.springframework.boot.web.servlet.support.ErrorPageFilter.doFilter(ErrorPageFilter.java:119)
at <unknown class>.doFilter(FilterInstanceWrapper.java:201)
at <unknown class>.doFilter(WebAppFilterChain.java:91)
at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
at <unknown class>.doFilter(FilterInstanceWrapper.java:201)
at <unknown class>.doFilter(WebAppFilterChain.java:91)
at <unknown class>.doFilter(WebAppFilterManager.java:1002)
at <unknown class>.invokeFilters(WebAppFilterManager.java:1140)
at <unknown class>.handleRequest(WebApp.java:5049)
at <unknown class>.handleRequest(DynamicVirtualHost.java:314)
at <unknown class>.handleRequest(WebContainer.java:1007)
at <unknown class>.run(DynamicVirtualHost.java:279)
at <unknown class>.run(HttpDispatcherLink.java:1159)
at <unknown class>.wrapHandlerAndExecute(HttpDispatcherLink.java:428)
at <unknown class>.ready(HttpDispatcherLink.java:387)
at <unknown class>.handleDiscrimination(HttpInboundLink.java:566)
at <unknown class>.handleNewRequest(HttpInboundLink.java:500)
at <unknown class>.processRequest(HttpInboundLink.java:360)
at <unknown class>.complete(HttpICLReadCallback.java:70)
at <unknown class>.requestComplete(WorkQueueManager.java:504)
at <unknown class>.attemptIO(WorkQueueManager.java:574)
at <unknown class>.workerRun(WorkQueueManager.java:958)
at <unknown class>.run(WorkQueueManager.java:1047)
at com.ibm.ws.threading.internal.ExecutorServiceImpl$RunnableWrapper.run(ExecutorServiceImpl.java:238)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at java.lang.Thread.run(Thread.java:826)
Caused by: java.net.ConnectException: 接続を拒否されました (Connection refused)
at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350)
at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206)
at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188)
at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392)
at java.net.Socket.connect(Socket.java:607)
at org.apache.http.conn.socket.PlainConnectionSocketFactory.connectSocket(PlainConnectionSocketFactory.java:75)
at org.apache.http.impl.conn.DefaultHttpClientConnectionOperator.connect(DefaultHttpClientConnectionOperator.java:142)
... 61 more
[22/01/25 14:27:41:655 JST] 0000002d com.ibm.ws.logging.internal.impl.IncidentImpl I FFDC1015I: FFDC 発生事象が作成されました: "org.apache.http.conn.HttpHostConnectException: Connect to localhost:19081 [localhost/127.0.0.1, localhost/0:0:0:0:0:0:0:1] failed: 接続を拒否されました (Connection refused) com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest() 830" ロケーション: ffdc_22.01.25_14.27.41.0.log
[22/01/25 14:27:41:757 JST] 0000002d com.ibm.ws.logging.internal.impl.IncidentImpl I FFDC1015I: FFDC 発生事象が作成されました: "com.ibm.ws.webcontainer.webapp.WebAppErrorReport: org.apache.http.conn.HttpHostConnectException: Connect to localhost:19081 [localhost/127.0.0.1, localhost/0:0:0:0:0:0:0:1] failed: 接続を拒否されました (Connection refused) com.ibm.ws.webcontainer.filter.WebAppFilterChain.doFilter 82" ロケーション: ffdc_22.01.25_14.27.41.1.log
[22/01/25 14:27:41:787 JST] 0000002d com.ibm.ws.logging.internal.impl.IncidentImpl I FFDC1015I: FFDC 発生事象が作成されました: "com.ibm.ws.webcontainer.webapp.WebAppErrorReport: org.apache.http.conn.HttpHostConnectException: Connect to localhost:19081 [localhost/127.0.0.1, localhost/0:0:0:0:0:0:0:1] failed: 接続を拒否されました (Connection refused) com.ibm.ws.webcontainer.filter.FilterInstanceWrapper.doFilter 144" ロケーション: ffdc_22.01.25_14.27.41.2.log
ブラウザからhttp://xxx:9081/decisioncenter
にアクセスし、Decision Centerにログインします。
※参考: Db2のテーブル設定などが完了していないと、ログイン時に以下のようなエラーが表示されてログインに失敗します。
稼働確認
前の記事でSample Serverを使って実施したTutorialを流用して、今回作成したRES、Decision Centerでルールを扱えるかどうか確認してみます。
ここで稼働確認しようとしている環境の全体像は以下のイメージです。
RESの利用
RESへのルール・セットのデプロイ
Rule DesignerでDeployment Configの設定でTarget Serverを定義しますが、そこに今回作成したRESを追加登録します。
手順としては以下の辺り。
https://qiita.com/tomotagwork/items/446975617acfdb0eda5f#step-3-deploying-the-ruleset
server01という名前で今回のターゲットとなるRESを登録します。
で、デプロイ処理を進めますが、その際ターゲットとして上で追加したserver01を指定してデプロイを行います。
RESコンソールでルール・セットが登録されたことを確認します。
テスト実行
サンプル・アプリケーションが稼働するLiberty Serverとしては、Sample Server(odm81100)をそのまま使います。呼び出すルールの稼働環境として、今回新たに作成したRESのアドレスを指定します。
Decision Centerの利用
Decision Centerへのルール・セットのデプロイ
Rule DesignerからDecision Centerへのデプロイも行います。
手順としては以下の辺り。
https://qiita.com/tomotagwork/items/446975617acfdb0eda5f#task-7-publishing-to-decision-center
Rule DesignerからDecision Centerに接続してプロジェクトを同期します。