2021年07月

06

【てくさぽBLOG】WebSphere Hybrid Editionを導入してみた Vol.2 -WebSphere Liberty導入編-

こんにちは。
てくさぽBLOGメンバーの岡田です。

IBM WebSphere Hybrid Edition(以下 WSHE)の導入をAzure上で検証してみた3回シリーズの2回目になります。

本記事では前回実施したAzure上にインストールしたOpenShift4.5環境に、WebSphere Liberty Coreをインストールしていきます。

WebSphere Hybrid Editionを導入してみた Vol.1 -OpenShift導入編-
WebSphere Hybrid Editionを導入してみた Vol.2 -WebSphere Liberty導入編- *本編
WebSphere Hybrid Editionを導入してみた Vol.3 -ツール編-

1.WSHEというソフトウェアが無い?

そもそもWSHEとはどのようなソフトウェアなのでしょうか。
分かりづらいですが、WSHEライセンスを購入してもWSHEというソフトウェアが利用できるわけではありません。WSHEライセンスは以下のWebSphere ApplicationServer関連の主要な製品をまとめたものです。

WebSphere Application Serverは,従来型のWebSphere traditionalおよび,コンテナ環境にも対応したWebSphere Libertyの二種類のランタイムがあります。今回は、WebSphere Libertyランタイムをインストールしてみます。
                                        

2.作業用サーバーを用意する

今回、Azure上に構築したRHEL8サーバーに以下を導入します。*個々のインストール手順は省略

  • ocコマンド
  • podmanコマンド
  • helmコマンド

3.WebSphere Libertyのインストール

ここからは、Azure上のRHEL8サーバーにログインして行います。

(1)統合OCPレジストリーへのアクセス権を付与する

・OCPにログインします。

oc login -u kubeadmin -p  <パスワード> https://api.nicpwhecluster.xxx.com:6443

・oc get nodesでノードのホスト名を確認します。

$ oc get node
NAME STATUS ROLES AGE VERSION
nicpwhecluster-h8lq5-master-0 Ready master 4d23h v1.18.3+e574db2
nicpwhecluster-h8lq5-master-1 Ready master 4d23h v1.18.3+e574db2
nicpwhecluster-h8lq5-master-2 Ready master 4d23h v1.18.3+e574db2
nicpwhecluster-h8lq5-worker-japaneast-1 Ready worker 4d23h v1.18.3+e574db2
nicpwhecluster-h8lq5-worker-japaneast-2 Ready worker 4d23h v1.18.3+e574db2
nicpwhecluster-h8lq5-worker-japaneast-3 Ready worker 4d23h v1.18.3+e574db2

・今回はマスターノードの1つ「nicpwhecluster-h8lq5-master-0」で実行します。クラスタから内部経路を使ってレジストリにアクセスします。

$ oc debug nodes/nicpwhecluster-h8lq5-master-0
Starting pod/nicpwhecluster-h8lq5-master-0-debug …
To use host binaries, run `chroot /host`
Pod IP: 10.0.0.7
If you don’t see a command prompt, try pressing enter.
sh-4.2#

・ノード上でocやpodmanなどのツールにアクセスできるように次のコマンドを実行します。

sh-4.2# chroot /host
sh-4.4#

・アクセストークンを使用して、コンテナイメージ・レジストリにログインします。

sh-4.4# oc login -u kubeadmin -p <パスワード> https://api.nicpwhecluster.xxx.com:6443
The server uses a certificate signed by an unknown authority.
You can bypass the certificate check, but any data you send to the server could be intercepted by others.
Use insecure connections? (y/n): yLogin successful.You have access to 58 projects, the list has been suppressed. You can list all projects with ‘oc projects’Using project “default”.Welcome! See ‘oc help’ to get started.
sh-4.4#
sh-4.4# podman login -u kubeadmin -p $(oc whoami -t) image-registry.openshift-image-registry.svc:5000
WARNING! Using –password via the cli is insecure. Please consider using –password-stdin
Login Succeeded!
sh-4.4#

・動作確認します。レジストリdocker.ioからイメージをローカルに持ってきます。

sh-4.4# podman pull docker.io/hello-world
Trying to pull docker.io/hello-world…
Getting image source signatures
Copying blob 0e03bdcc26d7 done
Copying config bf756fb1ae done
Writing manifest to image destination
Storing signatures
bf756fb1ae65adf866bd8c456593cd24beb6a0a061dedf42b26a993176745f6b
sh-4.4#

・取得できたか確認します。

sh-4.4# podman images
REPOSITORY TAG IMAGE ID CREATED SIZE
quay.io/openshift-release-dev/ocp-v4.0-art-dev <none> e62c0ee30db5 3 weeks ago 505 MB
quay.io/openshift-release-dev/ocp-v4.0-art-dev <none> b920241dcb5e 3 weeks ago 331 MB
quay.io/openshift-release-dev/ocp-v4.0-art-dev <none> 14b9f9be4696 3 weeks ago 312 MB
(途中省略)
quay.io/openshift-release-dev/ocp-v4.0-art-dev <none> 088760d6a49a 3 weeks ago 912 MB
docker.io/library/hello-world latest bf756fb1ae65 13 months ago 20 kB
sh-4.4#

・レジストリに対してpodman pushを実行します。

sh-4.4# podman tag docker.io/hello-world image-registry.openshift-image-registry.svc:5000/openshift/hello-world
sh-4.4# podman push image-registry.openshift-image-registry.svc:5000/openshift/hello-world
Getting image source signatures
Copying blob 9c27e219663c done
Copying config bf756fb1ae done
Writing manifest to image destination
Storing signatures
sh-4.4#
(2)統合OCPレジストリーのエクスポーズ

・DefaultRoute を 「True」にします。

$ oc patch configs.imageregistry.operator.openshift.io/cluster –patch ‘{“spec”:{“defaultRoute”:true}}’ –type=merge
config.imageregistry.operator.openshift.io/cluster patched (no change)
$

・podmanでログインします。

$ HOST=$(oc get route default-route -n openshift-image-registry –template='{{ .spec.host }}’)
$ echo $HOST
default-route-openshift-image-registry.apps.nicpwhecluster.xxx.com
$
$ oc whoami -t
M3Dbj0zF2oK68yG21jf7WTV37XeWR8EKRagF62QJOL0
$
$ podman login -u kubeadmin -p <パスワード> –tls-verify=false $HOST
Login Succeeded!
(3)SecurityContextConstraints (SCC) の定義

https://github.com/IBM/charts/tree/master/stable/ibm-websphere-liberty内の記載から以下の赤枠箇所の内容を含んだyamlファイルを作成します。今回はibm-websphere-liberty-scc.yamlという名前で作成しました。

・oc applyコマンドでibm-websphere-liberty-scc を定義します。

$ oc apply -f ./ibm-websphere-liberty-scc.yaml
securitycontextconstraints.security.openshift.io/ibm-websphere-liberty-scc created
(4)プロジェクトwlp-sample作成

Websphere Liberty用にプロジェクトを作成します。今回は、Webコンソールから「wlp-sample」という名前で作成します。

(5)コンテナ・イメージのビルド

・server.xmlの用意
https://github.com/WASdev/ci.docker/blob/master/ga/latest/full/server.xml内の、36行あるserver.xmlの内容をコピーし、ファイルserver.xmlを作成します。

・以下の内容のDockerファイルを作成します。

FROM ibmcom/websphere-liberty:19.0.0.12-full-java8-ibmjava-ubi
COPY –chown=1001:0? server.xml /config/
RUN installUtility install –acceptLicense defaultServer

・コンテナ・イメージをビルドします。

$ podman build -f ./Dockerfile -t mylibertyapp:1.0
STEP 1: FROM ibmcom/websphere-liberty:19.0.0.12-full-java8-ibmjava-ubi
Getting image source signatures
Copying blob 58e1deb9693d done
Copying blob 78afc5364ad2 done
Copying blob 3325260754e7 done
Copying blob 4427719dd2c9 done
Copying blob c059e0bc6ac9 done
Copying blob 0169ad963667 done
Copying blob 6195cb089ab9 done
Copying blob 9f87c21e1265 done
Copying blob 725fc7f0231d done
Copying blob 0331a4de6fdc done
Copying blob bdab1c39af4a done
Copying blob f5b53ae0ca41 done
Copying config ce3acc7fda done
Writing manifest to image destination
Storing signatures
STEP 2: COPY –chown=1001:0 server.xml /config/
fbd6f3d9cba9a7a72ac7a0dc3e3011b6400fdb2fd3e21fa34959dfe1925af803
STEP 3: COPY –chown=1001:0 SampleWebApp.war /config/dropins/
d64e1ce4931688a84d354446fbd4fa9f4744ef65cdcb187f830a2c9ea114dff8
STEP 4: RUN installUtility install –acceptLicense defaultServer
Checking for missing features required by the server …
The server does not require any additional features. No features were installed.Start product validation…
Product validation completed successfully.
STEP 5: COMMIT mylibertyapp:1.0
515b092feddf7a2ebb165bbdab187bbfd54bf3bf09b55651b990b7da5b76f767
$

・作成されたイメージを確認します。

$ podman images | grep myliberty
localhost/mylibertyapp     1.0      515b092feddf      28 seconds ago     738 MB
$
(6)Buildしたコンテナイメージを統合OCPレジストリーにpush

・まず統合OCPレジストリーへログインします。

$ podman login default-route-openshift-image-registry.apps.nicpwhecluster.xxx.com -u kubeadmin -p 75tT5caixaa_Mm7K6HiVT6xvbyFWeoHf1Dp1soB-21Y –tls-verify=false
Login Succeeded!
$

・ビルドしたイメージに統合OCPレジストリーのホスト名とプロジェクトを示す名前を付与します。
実行したらpodman imagesコマンドで確認します。

$ podman tag mylibertyapp:1.0 default-route-openshift-image-registry.apps.nicpwhecluster.xxx.com/wlp-sample/mylibertyapp:1.0

$ podman images | grep myliberty
localhost/mylibertyapp 1.0 515b092feddf 5 minutes ago 738 MB
default-route-openshift-image-registry.apps.nicpwhecluster.xxx.com/wlp-sample/mylibertyapp 1.0 515b092feddf 5 minutes ago 738 MB
$

・統合OCPレジストリーへコンテナ・イメージを登録(push)します。

$ podman push default-route-openshift-image-registry.apps.nicpwhecluster.xxx.com/wlp-sample/mylibertyapp:1.0 –tls-verify=false
Getting image source signatures
Copying blob 995a5e8c59d9 done
Copying blob 9e4e9b467e1d done
Copying blob 18bd03b00625 done
Copying blob 33037ee11bc5 done
Copying blob 1d7ab3c032a8 done
Copying blob da31cc4e7dec done
Copying blob eeb6d8f926af done
Copying blob 1228a4ab5ec0 done
Copying blob 1235447b1b10 done
Copying blob 60d1e32eff28 done
Copying blob 6ab8cd79d784 done
Copying blob 86b23fed23f4 done
Copying blob 597be5f3fcff done
Copying blob 7dd002d4a36c done
Copying blob 6a5e24c477f6 done
Copying config 515b092fed done
Writing manifest to image destination
Copying config 515b092fed done
Writing manifest to image destination
Storing signatures
$

・コンテナ・イメージが統合OCPレジストリーにpushされたことを確認します。

$ oc get imagestream
NAME IMAGE REPOSITORY TAGS UPDATED
mylibertyapp default-route-openshift-image-registry.apps.nicpwhecluster.xxx.com/wlp-sample/mylibertyapp 1.0 55 seconds ago$ oc describe imagestream mylibertyapp
Name: mylibertyapp
Namespace: wlp-sample
Created: About a minute ago
Labels: <none>
Annotations: <none>
Image Repository: default-route-openshift-image-registry.apps.nicpwhecluster.xxx.com/wlp-sample/mylibertyapp
Image Lookup: local=false
Unique Images: 1
Tags: 11.0
no spec tag* image-registry.openshift-image-registry.svc:5000/wlp-sample/mylibertyapp@sha256:bc6bc8fac41fd59b42d37e02888a3348f057c5caa0d8b41fd74d9e9f4aabdab4
About a minute ago
$
(7)SCCをサービス・アカウントに付与(grant)

・(3)で作成したibm-websphere-liberty-sccをWebSphere Libertyが使用するサービス・アカウントに付与します。

$ oc project wlp-sample

$ oc adm policy add-scc-to-user ibm-websphere-liberty-scc -z mylibertyapp-ibm-websphe
clusterrole.rbac.authorization.k8s.io/system:openshift:scc:ibm-websphere-liberty-scc added: “mylibertyapp-ibm-websphe”
$

(8)WebSphere LibertyのPodをデプロイ

・Helm Chartから変数ファイルを抽出します。
*WebSphere Liberty用helm Chart(「ibm-websphere-liberty-1.10.0.tgz」)をhttps://github.com/IBM/charts/tree/master/repo/stable からダウンロードしておきます。

$ helm inspect values ./ibm-websphere-liberty-1.10.0.tgz > mylibertyapp.yaml

・抽出した変数ファイルをエディタで開いてパラメーターを修正します。今回は以下の2箇所を更新しました。

ー (変更前)license: “”  ⇒ (変更後)license: “accept”
ー (変更前)ssl: enabled: true ⇒ (変更後)ssl: enabled: false

・修正した変数ファイルを指定して「helm install」コマンドを実行し、デプロイします。

$ helm install mylibertyapp ./ibm-websphere-liberty-1.10.0.tgz -f ./mylibertyapp.yaml
NAME: mylibertyapp
LAST DEPLOYED: Mon Mar 1 08:26:17 2021
NAMESPACE: wlp-sample
STATUS: deployed
REVISION: 1
NOTES:
+ If you are running on IBM Cloud Kubernetes Service, get the application address by running these commands:
ibmcloud cs workers $(kubectl config current-context)
export NODE_IP=<Worker node public IP from the first command>
export NODE_PORT=$(kubectl get –namespace wlp-sample -o jsonpath=”{.spec.ports[0].nodePort}” services mylibertyapp-ibm-websphe)
echo Application Address: http://$NODE_IP:$NODE_PORTOtherwise, run the following commands:
export NODE_IP=$(kubectl get nodes -l proxy=true -o jsonpath=”{.items[0].status.addresses[?(@.type==\”Hostname\”)].address}”)
export NODE_PORT=$(kubectl get –namespace wlp-sample -o jsonpath=”{.spec.ports[0].nodePort}” services mylibertyapp-ibm-websphe)
echo Application Address: http://$NODE_IP:$NODE_PORT
$

・正常にデプロイできたか確認します。

$ helm list
NAME NAMESPACE REVISION UPDATED STATUS CHART APP VERSION
mylibertyapp wlp-sample 1 2021-03-01 08:26:17.876891227 +0000 UTC deployed ibm-websphere-liberty-1.10.0 19.0.0.6
$

・作成された主要なOCPリソースの一覧と状況を確認します。

$ oc get all -l app=mylibertyapp-ibm-websphe
NAME READY STATUS RESTARTS AGE
pod/mylibertyapp-ibm-websphe-76478c8fcd-ngqpp 1/1 Running 0 82sNAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
service/mylibertyapp-ibm-websphe NodePort 172.30.179.226 <none> 9080:30797/TCP 82sNAME READY UP-TO-DATE AVAILABLE AGE
deployment.apps/mylibertyapp-ibm-websphe 1/1 1 1 82sNAME DESIRED CURRENT READY AGE
replicaset.apps/mylibertyapp-ibm-websphe-76478c8fcd 1 1 1 82s
$
(9)手作業でRouteを定義し、WebSphere Libertyにアクセスします

・作成されたServiceを確認します。

$ oc get service
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
mylibertyapp-ibm-websphe NodePort 172.30.179.226 <none> 9080:30797/TCP 112s

・Routeを作成します。

$ oc expose service mylibertyapp-ibm-websphe
route.route.openshift.io/mylibertyapp-ibm-websphe exposed
$

・RouteのHOST名を確認します。

$ oc get route
NAME HOST/PORT PATH SERVICES PORT TERMINATION WILDCARD
mylibertyapp-ibm-websphe mylibertyapp-ibm-websphe-wlp-sample.apps.nicpwhecluster.xxx.com mylibertyapp-ibm-websphe http None
$

・最後に、Webページにアクセスしてみます。
ー コマンドの場合

$ curl -s http://mylibertyapp-ibm-websphe-wlp-sample.apps.nicpwhecluster.xxx.com
<!DOCTYPE html>
<html lang=”en” xml:lang=”en”>
<head>
<meta charset=”utf-8″ name=”viewport”
content=”width=device-width,initial-scale=1.0″>
<!–title data-externalizedString=”WELCOME_TITLE”></title–>
<title>WebSphere Liberty 19.0.0.12</title>
<style>
@font-face {
font-family: IBMPlexSans-Medium;
src: url(‘fonts/IBMPlexSans-Medium.woff’);
}
(以下、省略)

ー Webブラウザの場合

4.まとめ

いかがでしたでしょうか。
コンテナ版なのでインストールは簡単かな、と思っていたのですが実行するコマンドも多くて結構大変だった印象です。大まかには「コンテナイメージのビルド」⇒「OCPレジストリにプッシュ」⇒「Podのデプロイ」という流れなのですがそれぞれの工程ごとにいろいろなコマンドを打つ必要があるので、実際にやってみようと思われている方の参考になればと思います。

ここまでお読みいただきありがとうございました。
次回はWSHEで利用可能な各種ツール群をインストールしてみた内容をお伝えいたします。

 

お問い合わせ

この記事に関するご質問は下記までご連絡ください。

エヌアイシー・パートナーズ株式会社
技術支援本部

E-Mail:nicp_support@NIandC.co.jp
 

その他の記事

2026年02月18日

【開催レポート】IBM様主催 Bobathon in Tokyo - IBM Bobで何が生まれた?

公開日:2026-02-18 2月12日、日本IBM様 箱崎オフィスにて、弊社(NI+C Partners)のパートナー様を対象としたハッカソン「Bobathon(ボバソン)」を開催しました。 Bobathonでは、次世代AIエージェント型開発支援ツールである「IBM Bob」を活用。 USより来日したIBM Bobの開発責任者や、GlobalのTechリーダーをファシリテーターに、 Early Access版(早期アクセス版)のBobを使い倒す、非常に濃密で実践的なワークショップとなりました。 目次 イベント概要 IBM Bobで形にした驚きの活用アイデア パートナー様からのリアルな声 今後の展望とアクション お問い合わせ イベント概要 参加: 7社 17名 目的: IBM Bobを用いた自社利用の具体化、およびお客様への提案アイデアの磨き込み 手法: IBM Bobの実機を使用し、テーマに沿った実践的なプロトタイピングを実施 IBM Bobで形にした驚きの活用アイデア 各社チームに分かれ、Bobを操作しながら導き出された活用案は、どれも現場の課題に即した非常に具体的なものでした。 業務自動化: 紙の社内申請のデジタル化、RFP回答の自動補助、プロジェクトメンバーの最適アサイン 開発・モダナイズ: レガシーRPGコードの解析・モダナイズ支援、ETL構成の自動確認・移行 戦略・分析: 食品ロス防止の在庫分析、特許情報の収集・解析による知財戦略の高度化 スピード開発: キャンペーンサイトの短期間構築・運用 パートナー様からのリアルな声 実際にIBM Bobを触り、他社の活用法を目の当たりにした皆様からは、驚きと期待の声を多数いただきました。 他のパートナー様のアウトプットを見て、業務活用のイメージがぐんと広がりました 自分の中にはなかったアイデアに触れ、非常に刺激になりました 「ついに開発もここまで来たか!」と驚きました。実機を触ることで、想像以上に参考になるイベントでした 立場や業務によって、Bobの用途が無限に広がることを実感できました 今後の展望とアクション 今後は、検討いただいた内容をクライアントゼロとしてご活用いただくこと、および、実案件への提案展開を全力でご支援してまいります。 また、弊社は今後も、IBM様と協業し継続的な「Bobathon」の開催を予定しています。 IBM Bobの社内評価・PoC・導入ご支援 お客様への提案同行のご依頼 これらに関するご相談は、ぜひお気軽にお問い合わせください。 最後になりますが、ご参加いただいたパートナーの皆様、そして素晴らしいファシリテーションをいただいたIBMの皆様、本当にありがとうございました! お問い合わせ エヌアイシー・パートナーズ株式会社 技術企画本部 E-Mail:nicp_support@NIandC.co.jp .highlighter { background: linear-gradient(transparent 50%, #ffff52 90% 90%, transparent 90%); } .anchor{ display: block; margin-top:-20px; padding-top:40px; } .btn_A{ height:26px; } .btn_A a{ display:block; width:100%; height:100%; text-decoration: none; background:#eb6100; text-align:center; border:1px solid #FFFFFF; color:#FFFFFF; font-size:16px; border-radius:50px; -webkit-border-radius:50px; -moz-border-radius:50px; box-shadow:0px 0px 0px 4px #eb6100; transition: all 0.5s ease; } .btn_A a:hover{ background:#f56500; color:#999999; margin-left:0px; margin-top:0px; box-shadow:0px 0px 0px 4px #f56500; } .bigger { font-size: larger; }

2026年02月06日

【てくさぽBLOG】IBM watsonx OrchestrateでAIエージェント開発してみた(Part2)

公開日:2026-02-06 こんにちは。てくさぽBLOGメンバーの高村です。 前回の記事「【てくさぽBLOG】IBM watsonx OrchestrateでAIエージェント開発してみた(Part1)」では、昨年6月のアップデート後のwatsonx OrchestrateのUIを用いてサンプルエージェントを開発し、Salesforceから顧客情報および在庫情報を取得するところまでをご紹介しました。 Part2(本記事)では、生成AIツールとメールツールを使ったメールの作成・送信を実装し、AIエージェントの動作確認をデモ動画でご紹介いたします。 目次 サンプルエージェントのシナリオ サンプルエージェントの開発 さいごに お問い合わせ サンプルエージェントのシナリオ Part2の内容に入る前に、サンプルエージェントのシナリオをあらためてご紹介します。 サンプルエージェントのシナリオは、企画担当者が在庫商品を参照し、在庫情報に基づいて顧客へキャンペーンメールを送信する作業を想定しています。通常は担当者がデータベースで在庫を目視確認して対象商品を選定し、SFAで送信対象者を抽出、メール文面を作成してメールツールで送信するなど、複数システムをまたいで人手で作業するため、煩雑で時間と労力を要します。 watsonx Orchestrateを導入すれば、AIエージェントが在庫・顧客情報を取得し、在庫の多い商品のキャンペーン文面を生成、メールの作成・送信までを一気通貫で実行します。これにより、担当者の作業負荷軽減とリードタイム短縮、ミスの削減が期待できます。 Part1では、AIエージェントが「Salesforceからの顧客情報取得」と「在庫情報の取得」を実行するところまでをご紹介しました。Part2では、図のピンクで囲った部分である「生成AIによるキャンペーンメールのドラフト作成」と「メールツールによる送信」を開発します。最後に、Part1で作成した機能を含め、全体を通したAIエージェントのデモ動画をご紹介します。 サンプルエージェントの開発 生成AIプロンプトとメール作成・送信をAgentic workflowで実装する それでは、Part1の続きとしてエージェント開発を進めます。ここでは、Agentic workflow機能を使用します。 Agentic workflowとは複数ツールの組み合わせや生成AIプロンプト処理、ユーザからの入出力フォームなどフロー形式でカスタムツールとして作成することができます。今回は生成AIプロンプトを使用して商品のキャンペンーンメールを作成し、メールツールからメール作成・送信を行うフローを作成します。 watsonx Orchestrateにログインして、メニューバーのBuildからPart1で作成したSales agentをクリックして開きます。 エージェント開発画面が開きます。2026年1月のアップデートによりエージェントが使用するモデルのデフォルトがGPT-OSS 120B-OpenAI(via Groq)になりました。llama-3-2-90b-vision-instruct、llama-3-405b-instructは2026年3月末に withdrawalとなります。 Toolsetまでスクロールし、Add tool +をクリックします。 以下画面が表示されるのでAgentic workflowをクリックします。 任意のworkflow名を入力してStart buildingをクリックします。 下記の画面が表示されます。左のボックスには追加可能なアクティビティとツールの一覧が表示されます。画面中央のフロー図にツール、アクティビティを構成します。 左上にあるEdit detailsをクリックします。 Parametersタブをクリックし、フローのインプットとアウトプットの型を定義します。今回はstringでName,Descriptionは画面の様に設定しました。設定したらDoneをクリックします。 下記画面に戻るので、左のボックスにあるGenerative promptをクリックしてフロー図の中央に追加します。 プロプト設定画面が表示されます。左のプロンプトへのインプットではユーザが指定する商品名(テキスト)を変数として設定します。右のシステムプロンプトでは全体の会話の方針やトーンを入力し、ユーザプロンプトでは具体的な指示を指定します。また、プロンプトで使用するLLMはリストから選択でき、ここでは「llama-3-3-70b-instruct」を指定しています。 Add exampleタブでは例を追加することができます。以下の通り二つ例を追加しました。 Adjust LLM settingsタブでは最大/最小トークン数などを設定することができます。 Generate Previewをクリックすると、生成結果を確認できます。確認後は右上の×を押して保存します。これで、ユーザー指定のテキストからキャンペーンメールを生成するプロンプトが完成しました。 次に、ユーザーにキャンペーンメールの内容を確認してもらえるよう表示を構成します。左のボックスからUser activityを選び、Generative promptの下に挿入します。 Add +をクリックし、Collect from userからFormをクリックします。今回はFormを利用しますが、このほかにも日付やファイルアップロードなどのアクティビティを構成することができます。 左上の鉛筆マークをクリックして任意のアクティビティ名に変更します。次にAdd field + からCollect from userを選択し、Textをクリックします。 Requiredをオンにし、Input typeはMulti lineを選択します。さらに、BehaviorのInitial valueを有効化し、値にGenerative promptの出力変数を指定します。 左の「mail body」ボックスを選択し、ユーザー向けのインストラクションを設定します。Instructionsをオンにして、下記のガイドを入力し、Cancel buttonもオンにします。設定後は右上の×をクリックして保存します。 フロー図が下記画面の様に表示されます。 次に、件名をユーザーに入力してもらうフォームを作成します。下記の画面のように、User activity1の下にもう一つUser activityを挿入します。 Add +をクリックし、Collect from userからFormをクリックします。下記画面が表示されるので任意のフォーム名を入力し、Add field + からCollect from userを選択し、Textをクリックします。 任意のLabel名を入力し、Requiredをオン、Input typeはSingle lineを選択します。 左の「mail subject」ボックスを選択し、ユーザー向けインストラクションを設定します。Instructionsをオンにして下記のガイドを入力し、Cancel buttonもオンにします。設定後は右上の×をクリックして保存します。 フロー図は下記の画面のとおりです。 最後にメールを送信するためのツールを追加します。今回は、カスタム作成した Brevoを用いたメール送信ツールを使用します。User activity2の下に左ボックスのToolタブからsend_mail_brevoのツール挿入します。 追加したsend_mail_brevoノードをクリックしてInputsを設定します。contentはUser activity1の出力変数、subjectはUser activity2の出力変数を指定します。to_addressはAuto-map設定にして右上の✖をクリックして保存します。 下記の画面の様にフローが作成できました!Doneをクリックしてワークフローを保存します。 Agent builder画面に戻り、Toolsetまでスクロールすると作成したAgentic workflowが追加されています。以上でAgentic workflowの作成は完了です。 Behaviorを設定する Behaviorまでスクロールします。InstructionsにPart1作成したSalesforceのツール、Knowledge、本記事で作成したAgentic workflowをエージェントがどのように利用するか定義します。エージェントの役割と動作の流れを定義し、プレビューで挙動を確認しながら内容を繰り返し修正しました。 サンプルエージェントを使ってみる それでは、作成したエージェントを使ってみます!エージェントの動きは下記動画をご覧ください。 動画では、キャンペーンメールを送付する対象顧客情報をSalesforceから取得し、コンタクトリストを確認。その後、商品の在庫状況を参照して在庫の多い商品に合わせたキャンペーンメールを作成し、送信します。 動画の長さの関係上、二本に分けて紹介します。 1本目:Salesforceから顧客情報を取得し、コンタクトリストを確認 2本目:在庫情報を確認のうえ、在庫の多い商品のキャンペーンメールを作成・送信 2本目の動画がPart2で開発した内容になります。商品と顧客名を指定すると、AIが商品情報をもとにキャンペーンメールを生成し、顧客名に紐づくメールアドレスを自動入力して送信できます。Agentic Workflowで追加したUser Activityを使うことで、生成したメール本文の確認・修正・追記が可能です。このように、定型の流れや承認プロセスが必要な場合は、フロー化することでより確実に処理を実行できます。 さいごに Part1・Part2の2回にわたってサンプルエージェントの開発をご紹介しました。2025年6月のアップデートでUIや機能が刷新され、当初は戸惑いもありましたが、ご覧のとおりAIが自動で入力や抽出を行うため、よりエージェンティックに動作するエージェントを開発できます。 今回最も苦労したのは、Behaviorの調整です。わずかな文言の違いで動作が変わるため、確認と修正を繰り返してチューニングしました。今回のように1つのエージェントに複数ツールを組み込む場合は、Behavior設定が複雑化します。回避策として、機能ごとにエージェントを分割し、親エージェントから呼び出す構成も可能ですのでご検討ください。 事前定義ツールとしてはSalesforceのツールを2つ利用しました。要件に合うツールがあれば、認証情報を設定するだけですぐに利用できます。ただし多くのツールは基本機能が中心となるため、より細かな動作が必要であればカスタムツールを開発してご利用いただく必要があります。カスタムツール開発にはこちらの「【てくさぽBLOG】IBM watsonx OrchestrateのADKを使ってみた」でご紹介したADKという開発ツールキットが提供されていますので、是非ご活用ください。 また、コード開発に心強い味方がございます。「【てくさぽBLOG】IBM Bobで市民開発に挑戦」でご紹介したIBM Bobはwatsonx Orchestrateのツール、エージェントのコード作成やSaaS環境へのインポートなどを支援してくれます。注目度も高いと思いますので、こちらは改めて別の機会にご紹介できればと思います。 お問い合わせ この記事に関するご質問は以下の宛先までご連絡ください。 エヌアイシー・パートナーズ株式会社 技術企画本部 E-mail:nicp_support@NIandC.co.jp .highlighter { background: linear-gradient(transparent 50%, #ffff52 90% 90%, transparent 90%); } .anchor{ display: block; margin-top:-20px; padding-top:40px; } .btn_A{ height:26px; } .btn_A a{ display:block; width:100%; height:100%; text-decoration: none; background:#eb6100; text-align:center; border:1px solid #FFFFFF; color:#FFFFFF; font-size:16px; border-radius:50px; -webkit-border-radius:50px; -moz-border-radius:50px; box-shadow:0px 0px 0px 4px #eb6100; transition: all 0.5s ease; } .btn_A a:hover{ background:#f56500; color:#999999; margin-left:0px; margin-top:0px; box-shadow:0px 0px 0px 4px #f56500; } .bigger { font-size: larger; }

2026年01月22日

【てくさぽBLOG】IBM Bobで市民開発に挑戦

公開日:2026-01-22 こんにちは。てくさぽBLOGメンバー村上です。 2026年も、気づけばもう1月が駆け抜けていきそうですね。 さて今回は「IBM Bob」検証シリーズPart2をお届けします(Part1 はこちら)。 前回はBobの主要機能のひとつである「Explain機能(コード解析)」をご紹介しました。 今回はコード生成を行う機能「Generate機能」に注目し、アプリケーションの開発に挑戦した内容をお届けします。 目次 はじめに IBM Bob のGenerate機能で市民開発を試してみた Generate機能の他社製品との比較 さいごに お問い合わせ はじめに 現在、私たちのチームではIBM BobのPreview版(Early Access版)を利用し、Generate機能によってBobがどんなコード生成ができるのか、どこまでの領域をカバーできるのか、そして実際の業務がどれほど効率化されるのか、その実力と効果を検証しています。 これまでに実施したGenerate機能の検証例 ・IBM Bobでwatsonx Orchestrate(wxO)のAIエージェントを作成 ・Bobで生成したマークダウン形式のファイルをExcelへ出力するツールの作成 ・チーム内で利用している勤怠確認用のスプレッドシートを操作性の高い「出退勤管理アプリ」にする開発 今回はこの中から、他社製品との比較が行いやすく、IBM Bob ならではの特徴をより分かりやすく伝えられると考えた「出退勤管理アプリ」に焦点を当ててご紹介します。 IBM Bob がどこまで意図通りの開発ができるか、また、他製品と比較した内容も合わせてお届けします。 IBM Bob のGenerate機能で市民開発を試してみた 「出退勤管理アプリ」作成の過程や成果としてご紹介する内容は下記です。 プロンプトの強化:曖昧な指示を具体的に補完 チャットモードを利用した対話型開発 完成した成果物の紹介 プロンプトの強化による成果物の比較 1. プロンプトの強化:曖昧な指示を具体的に補完 まず、「出退勤管理アプリ」の完成イメージをBobに伝えます。 Bobのチャット画面に、下記のように要件を箇条書きで記載し、要件を書き終わったら「プロンプト強化機能(Enhance Prompt)」ボタンを押下しプロンプトを強化しました(プロンプトの強化についてはPart1のブログでも記載しています)。 上記のプロンプトが下記のプロンプトに強化されました。 チーム向け勤怠管理Webアプリケーションを以下の仕様で開発してください。   【基本機能】 メンバー全員が互いの勤怠状況を閲覧可能なチーム勤怠管理システムを構築します。 各メンバーは個人アカウントでログインし、自分の勤怠データのみ編集権限を持ち、他メンバーのデータは閲覧のみ可能とします。 【画面構成】 1. 当日勤怠一覧画面:本日の全メンバーの勤怠状況を一画面で一覧表示し、各メンバーの勤務場所、勤怠種別、勤務開始・終了時刻、備考を即座に把握できるダッシュボード形式とします 2. 個人別勤怠カレンダー画面:メンバーごとに過去の勤怠実績と未来の勤怠予定を時系列で確認・管理できるページを用意し、日付範囲を指定して表示できるようにします 【勤怠データ入力機能】 実績入力:毎日の勤務開始時と勤務終了時に手動で時刻を入力する機能を実装します。入力フォームはシンプルで素早く操作できるUIとします 予定入力:複数日分の勤怠予定を一括登録できる機能を実装し、登録後もいつでも個別または一括で変更・削除が可能とします 【勤務場所の選択肢】 - テレワーク - 聖路加オフィス - 外出 - その他 各勤怠記録に対してドロップダウンまたはラジオボタンで選択できるようにします 【勤怠種別の選択肢】 - 休(終日休暇) - AM休(午前休) - PM休(午後休) - 時間休 - FLEX(フレックス勤務) 勤務場所と同様に選択式で入力できるようにします 【備考欄】 各勤怠記録に自由記述可能な備考欄を設け、特記事項や補足情報を入力できるようにします 【認証・権限管理】 初期メンバー5名分のアカウントを作成し、各メンバーは個人名でログインします。 パスワード設定機能を実装し、初回ログイン時または設定画面から任意のパスワードに変更可能とします。編集権限は自分の勤怠データに限定し、他メンバーのデータは読み取り専用とします 【技術要件】 レスポンシブデザインでPCとモバイル端末の両方で快適に操作できるようにし、 データの永続化にはデータベースを使用してください。モダンなWebフレームワークを使用し、保守性と拡張性の高いコード構造で実装してください 「プロンプト強化機能」を利用することで、説明が不足している部分をBobが具体的に補完し、精度の高いプロンプトへとブラッシュアップしてくれます。 これにより、要件の意図を正しく反映させるための具体的な指示が整いました。 補足ですが、私は拡張機能として「Japanese Language Pack for Visual Studio Code」を導入し、IDEを日本語化して利用しています。 (拡張機能の適用方法はPart1のブログにしています) 2. チャットモードを利用した対話型開発 次に、IBM Bob のチャットモードを試してみました。今回利用したのは「Planモード」です。 Planモードを選択した理由は、まずBobが計画立案をしてくれ、その計画を人間側が理解・承認してから開発を進められると思ったためです。 Planモードを利用して先ほど強化したプロンプトをチャット画面から流すと、Bobが下記のように指示が漏れている部分を確認してくれました。 技術スタックの確認: このWebアプリケーションの技術スタックについて、どのような構成を希望されますか? 詳細な設定確認: 初期メンバー5名の名前を教えてください。ログイン時に使用するユーザー名として設定します。 このように、Bobが具体的な選択肢やデータの入力を促してくれるため、抜け漏れのない状態で計画を立て、実装へと進めることができます。 全ての要件が明確になると、Todoリストが作成されました。 このTodoリストを承認した後は、Bobがリストを上から順番に自動で進めてくれます。 プログラムを作成する工程まで行くと「Codeモードに切り替えます」と宣言があり、チャットモードがPlanモードからCodeモードに自動で切り替わり、実装フェーズへ移行しました。 この流れは非常にスムーズで、Bob の優秀さに感心しました。 ちなみに、私のPCにはNode.jsがインストールされていなかったのですが ・Node.jsのダウンロード、インストール方法 ・コマンド実行がうまくいかなかったときのトラブル対応 は、全てBobが教えてくれました。 教えてもらう相手が人間だと、ある程度調べてから聞かないと迷惑だよなぁ・・と思ってしまうような疑問でも、Bobになら遠慮せず聞くことができるので、スピードを落とさずに作業を進めることができました。 3. 完成した成果物の紹介 こうしたプロセスを経て完成した「出退勤管理アプリ」がこちらです。 市民開発への挑戦を決めた当初は、「どのような指示を出せばいいのか」と少し身構えていました。しかし、実際には細かな指示に悩む必要はなく、Bobがプロンプト強化機能やチャットモードを通じて、使い勝手の良いアプリケーションを自律的に構築してくれました。 完成した「出退勤管理アプリ」には、ユーザー別のログイン機能だけでなく、パスワード変更やチームメンバーが各自のPCからアクセスできる外部接続の仕様まで標準的に実装されており、その完成度の高さには正直驚かされました。 4. プロンプトの強化による成果物の比較 「1.プロンプトの強化」にて、プロンプトを強化してからアプリケーションを作成する方法を記載しましたが、試しに、プロンプトは強化せずに「出退勤管理アプリ」を作成してみました。 成果物にどのような違いが現れたかをご紹介します。 プロンプト強化前 指示が曖昧だった機能は実装されなかった プロンプト強化後 イメージしていた機能が全て実装された プロンプトを強化し指示の解像度を上げることが、そのままアプリケーションの完成度に直結することを実感した検証となりました。 Generate機能の他社製品との比較 さて、今回の検証では「他社製品ではどのような結果になるか」も合わせて検証しました。 正確に比較するため、他社製品もBobと全く同じプロンプトを用いて検証を行っています。 両者の操作感やアウトプットを細かい観点で比較し、Bobの特徴としてお伝えしたい部分を下記の表にまとめました。 比較項目 IBM Bob 他社製品 ドキュメント生成 基盤~運用に関するドキュメントを作成 ・基本設計書 ・詳細設計書(実装計画書) ・使い方ガイド(README) ・開発設計書 ・導入手順書(SETUP GUIDE) ・障害対応手順書(作業中のトラブル対応) 開発視点のドキュメントを作成 ・要件定義書 ・基本設計書 ・詳細設計書(実装計画書)   アーキテクチャのレベル 本番運用に耐えうる可用性・信頼性を考慮した構成 (フロントエンド・バックエンドの分離) すぐに動く構成 (フロントエンド・バックエンドを分離しない構成) デプロイの容易性 〇 ・プロンプト強化により不足情報が補完 ・選択肢(推奨案)が提示され対話を通じてステップバイステップで進められる △ ・プロンプト補完の機能は見当たらない ・選択肢が提示されることはなかった 今回の比較検証を通して、IBM Bobの自律型エージェントとしての高い実力を実感しました。 実運用に耐えうる構成を自動で選択してくれる点はとても心強いです。また、基盤から運用までを網羅する圧倒的なドキュメント生成力や、対話を通じて迷わず進められるデプロイ支援により、開発のハードルが下がるだけでなく、実装の透明性も高いレベルで担保されています。 作った後もチームや組織で説明・維持ができる、という安心感こそが、IBM Bobが組織利用を見据えたエンタープライズ向けの製品であると言える大きな理由なのだと感じました。 さいごに Part2となる今回のブログは、IBM Bobの「Generate機能」を使った市民開発をご紹介しました。 実際にBobと一緒にアプリケーションを作ってみて、やっぱりBobは頼りになる相棒でした。 (最近、Bobを実在する人のように「Bobさん」と呼んでしまうことがあります) 私は開発業務に深く携わった経験はほとんどありませんが、今回の検証を通じて、自分の手で形にできるワクワク感を肌で感じることができました。 これからも、この頼もしい相棒と一緒に業務の新しい形を探り、その可能性をパートナーの皆さまにもお届けしていきたいと思います。 お問い合わせ エヌアイシー・パートナーズ株式会社 技術企画本部 E-Mail:nicp_support@NIandC.co.jp .highlighter { background: linear-gradient(transparent 50%, #ffff52 90% 90%, transparent 90%); } .anchor{ display: block; margin-top:-20px; padding-top:40px; } .btn_A{ height:26px; } .btn_A a{ display:block; width:100%; height:100%; text-decoration: none; background:#eb6100; text-align:center; border:1px solid #FFFFFF; color:#FFFFFF; font-size:16px; border-radius:50px; -webkit-border-radius:50px; -moz-border-radius:50px; box-shadow:0px 0px 0px 4px #eb6100; transition: all 0.5s ease; } .btn_A a:hover{ background:#f56500; color:#999999; margin-left:0px; margin-top:0px; box-shadow:0px 0px 0px 4px #f56500; } .bigger { font-size: larger; }

2025年12月25日

“AI を学習用ではなく事業の現場に馴染ませる”
本格的なAI時代に誕生したIBM Power11の覚悟とは?

公開日:2025-12-25 本格的なAI時代の到来で、企業にとってIT基盤の存在感はこれまで以上に重みを増しています。IBM Power11は、そうした時代の要請に応えるべく誕生した真のエンタープライズ・サーバーです。堅牢な信頼性と高い処理性能に加え、外付けカードIBM Spyre Acceleratorによって、地に足がついたAIワークロードをすぐに実装できる実用性を備えるに至っています。既に先行ユーザーは、大きな業務効率化の効果を体感しており、このサーバーは単なるハードウェアを超えて、次世代の標準基盤となる期待を集めています。 今回は、日本アイ・ビー・エム(以下、IBM)テクノロジー事業本部 Powerテクニカル・セールス部長 釘井 睦和 氏をお迎えし、AI時代をリードするべくして誕生したIBM Power11の“覚悟”について伺いました。 出席者 ゲスト 日本アイ・ビー・エム株式会社テクノロジー事業本部Powerテクニカル・セールス部長釘井 睦和 氏 インタビュアー エヌアイシー・パートナーズ株式会社技術企画本部テクニカル・サポート部部長 広橋 稔 本格的なAI時代の到来で、さらに重みの増すIT基盤 広橋: 経営とITが不可分となった今日、企業のお客様が直面している課題としてどのようなものがあると考えておられますか。 釘井氏: 本格的にAIの時代が到来したことが非常に大きいと思います。企業競争力の維持を図る上で、もはや、AI活用を抜きに戦略を立てられないというところまで来ています。実践段階に入ってきたこともあり、アナリスト機関IDCによれば、これからはAIエージェントが自らアプリケーションを書くようになると予測されています。その結果、アプリケーションの数は爆発的に増加し、今後10億もの新しいアプリケーションが出現すると予測され、そのうち3分の1はAIによって開発される見込みです。こうなってくると、アプリケーションを支えるインフラは、これまでにないスピードと規模でアプリケーション増加への対応と高い可用性を求められます。計画停止すら許されないミッションクリティカルな業務が増えていくことでしょう。そのような世界では、油断をするとシステムのサイロ化やデータ爆発も起きやすくなるため、その対策も必要です。 その一方で、ランサムウェア攻撃を筆頭に、セキュリティリスクも劇的に高まっており、対策強化も喫緊の課題です。だからといって、ITばかりに予算を使うわけにはいきませんから、そこはコスト最適化を図る目線も要求されます。さらに、少子高齢化社会の進行で、IT人材も確保しづらい状況が続いているため、より少ない人員でより多くのことをカバーできるかといった観点での運用効率化も恒常的なテーマとなっています。つまり、今日の企業が対峙している課題は文字どおり山積しているといえます。 広橋: 確かに、日ごろパートナー企業やエンドユーザー企業のお悩みを聞く中で、こうしたお話はよく伺います。特にAI活用については、意欲を持ちつつも、プレッシャーも感じておられるようです。 AI時代のニーズに応える真のエンタープライズ・サーバー 釘井氏: こうした中、今年登場したIBM Power11は、本格的なAI時代のニーズに応える、真のエンタープライズ・サーバーとして位置づけられています。このサーバーは、単なるハードウェアを超えたまさに“企業の中枢を支える基盤”として設計されており、Powerとして従来から定評のある堅牢性と可用性をさらに進化させつつ、計画停止をほぼ不要とする自律的な運用機能や強靭なセキュリティを標準装備しました。また、最新のDDR5メモリと強化されたI/Oアーキテクチャにより、高負荷のトランザクション処理や大規模データ解析なども余裕を持ってこなすとともに、AI推論も得意とします。IBM Power11は、企業がAI時代に向けて加速できるようIBMが考え抜いたフルスタックのイノベーションです。 広橋: IBM Power11を特徴づけるキーワードをいくつか挙げていただけますか。 釘井氏: 一つは、「0」(ゼロ)です。これは、エンドツーエンドの自動化を実現し、計画的なダウンタイムを0にする、つまり、無停止運転を可能にすることを意味します。 従来はメンテナンスウィンドウを設けて実施していたファームウェア更新、I/Oアダプタ更新、仮想化ソフトウェア更新などを、IBM Power 11ではAutomated Platform Maintenance(APM、プラットフォーム自動保守)機能として、管理コンソールであるIBM Hardware Management Console(HMC)からワンクリックまたは準自動で実行可能です。環境をチェックする更新前準備、パッチ配布、ワークロードの退避・復帰を一連のフローで自動化できるため、停止せずに更新できるというわけです。 また、運用データを横断的に集約し、watsonxですぐに実行できる提案と自動化を結びつける、アプリケーション運用向けのAIオートメーション基盤 IBM Concertがあります。Concert for Powerでは、Powerインフラの脆弱性を検出して、現行バージョンに照らして優先度をAI算定、その後に推奨手順を提示し、必要に応じて更新をゼロ計画停止で実行するところまで担います。ここでいう実行とは、HMC/PowerVMが担う処理をConcertが呼び出して一気通貫に自動実行することを意味しています。 広橋: サーバー停止は業務に支障を及ぼしかねず、利用部門や経営層からの圧力も大きいため、情報システム部門としてはなるべく回避したい運用ですから、安定して動き続けてくれるならそれに越したことはないですね。 釘井氏: はい。もう1つのキーワードは「

back to top