12月4日に続き、Advent Calendarに参加してみる
最近、いろいろとIBM WebSphere Libertyのモニタリングについて調べることがあり、今回このテーマでブログを書くことにしました。DynatraceのOneAgentは、Javaのアプリであればコードを一切変更せずに、フルスタックの監視(サーバサイドの監視やWebアプリケーションの監視)を始めることができます。Javaのアプリケーションはありとあらゆるところで動いていると思いますが、大きな企業などではSIerさんが中心となってJavaアプリを作り、運用することが多いと思います。大手SIerさんの中で、IBMさんがその役割を担っている場合、Javaアプリケーションのプラットフォームとして、IBM WebSphere Libertyがよく使われていると思います(私見です)。今回はこのプラットフォーム上で動くサンプルのJavaアプリケーションのパフォーマンスメトリクスをJMX経由で取得する方法をまとめようと思います。
Extension、って何?
DynatraceはOneAgentと呼ばれるエージェント経由で、インフラからWebアプリケーションに至るまでの全ての情報を収集します。このシナリオの前提は、OneAgentがホストにインストールできることが条件になります。しかしながら、実際の監視の現場では、OneAgentがインストール出来ない環境もあると思います。そのようなケースでも、監視対象のデータが収集できるようにするための、Dynatraceのソリューションのことを「Extension」と呼びます。Extensionには2種類あり、
- Dynatrace社が提供するもの
- Dynatrace Hubから自由にダウンロードできます(ただし、データの収集には相応のライセンスが必要)
- 自由に自分で作成できるもの
- ユーザが自由にExtensionを作成することができ、それらは「Custom Extension」と呼ばれます(ただし、データの収集には相応のライセンスが必要)
今回は、前者のカテゴリーに属する「IBM WebSphere Liberty」のWebパフォーマンスメトリクスを取得するExtensionを紹介しようと思います。
IBM WebSphere Liberty Extensionで取得できるデータとWebSphere側の事前準備
このExtensionを使うと取得できるメトリクスは、全部で「14」個あります。
-
Servlet (2)
- Request count
- Response time
-
Request timing (3)
- Active requests
- Slow requests
- Hung requests
-
Thread pool (2)
- Active threads
- Pool size
- JVM (7)
これらのデータは、ホストにインストールされた OneAgnet のEEC(Extension Execustion Controller)を介して、JavaのJMXインターフェイス経由で取得されます。そのため、事前にEECの機能がOneAgentがインストールされたホスト上で有効になっているか確認しましょう。下記の場合、"docker" というホストのSettingsでEECを有効にしています。
先ほど説明した IBM WebSphere liberty のメトリクスに関する詳細情報は、IBM社のWebSphere libertyのヘルプガイドに細かく記載されていますので、合わせて確認しましょう(リンクを埋め込んでおきました)。
あと、これらのデータ収集は、JavaのJMXインターフェイスを介して行われるため、WebSphereのJavaアプリを立ち上げる際に server.xml
ファイルの <feature> セクションで JMXとローカルで接続できる localConnector-1.0
Feature を有効にしておく必要があります。この内容についても、IBM社のWebSphereの "Connecting to Liberty by using JMX" ガイドを見るとよいと思います。
さらに、個別にWebSphere libertyの14個のメトリクスを取得するためには、追加で下記2つの Feature も <feature>に追加しておく必要があります。IBM社のマニュアルを読むと、monitor-1.0
が定義されていれば14個全てのメトリクスが取れそうですが、テストしたところ明示的に requestTimging-1.0
を追加しておかないと、Request timing のメトリクスは取れませんでした。。。以下、私のテスト環境の server.xml
の抜粋です。
<server description="Sample Liberty server">
<featureManager>
<feature>microProfile-3.3</feature>
<feature>localConnector-1.0</feature> <<<< これ
<feature>monitor-1.0</feature> <<<< これ
<feature>requestTiming-1.0</feature> <<<< これ
</featureManager>
IBM WebSphere liberty extension のインストール
では、ここからDynatrace側のExtensionインストールに関するパートになります。順番にみていきましょう。
- Extensionのインストール
まずは、自身のテナント(もしくは、ManagedのEnvironment)のInfrastructure Observability > Extensions
に飛び、右上のAdd to environment
をボタンをクリックし、当該Extensionをインストールします。
- Extensionの設定の投入
Extensionのインストールが終わったら、設定を投入しましょう。Versionsと書かれたセクションの右側にあるAdd monitoring configuration
をクリックします。
次のページに遷移すると、どのホストで動いているOneAgent経由で IBM WebSphere Libertyのメトリクスを取るか、候補が現れますので自分が取りたい対象のホストをクリックします。その際、一番右側に表示されるExtension Execusion Controller
がEnabled
になっていることを確認して下さい。ここでは「podman」というホストを選択しています。で、「Next step」をクリックします。
そうすると設定した内容が、JSONファイルで表示されます。ここはその表示のみのページですので、そのまま「Next step」ボタンをクリックして、次のページに移動します。
このページでは、Extesionに名称を設定するだけです。分かりやすい名称を付けてください。ここでは「IBM WebSphere Liberty for Podman」と入力しています。画面青枠部分が取得対象のメトリクスになりますが、ここで全てのメトリクスグループに「チェック」が入っていることを確認しておきましょう(デフォルトで全てにチェックが入っています)。終わったら、Extensionの設定を有効化する「Activate」ボタンをクリックします。
そうすると、最初の設定画面に戻り、今投入した設定がOneAgent側に伝わりその間は「Status」がPending
と表示されています。その処理が終わり、データが取れるようになるとOK
に変わります。しばらくここで待ちましょう(画面は自動更新されないため、適宜ブラウザのリロードボタンをクリックして、画面を再ロードして下さい)。
しばらくして、ブラウザをリロードすると、このようにStatusが「OK」に変わります。こうなったら、データ取得OKという状態です。
- トラブルシューティング
もしステータスが「Pending」状態の場合は、OneAgentのJavaのcode modueleのログを確認してみて下さい。デフォルトでは、/var/log/dynatrace/oneagent/java
配下にあります。ファイル名はJavaアプリを起動する際のIBM WebSphere Liberty server name
やPIDに依存するため、これと全く同じという訳ではありませんので、ご注意ください。
ubuntu@podman:/var/log/dynatrace/oneagent/java$ ls -la
total 68
drwxrwxrwt 2 101000 ubuntu 4096 Dec 6 09:57 .
drwxrwxrwt 13 root dtuser 4096 Dec 6 09:57 ..
-rw------- 1 101000 ubuntu 61410 Dec 6 12:58 ruxitagent_WebSphere_Liberty_defaultServer_1.0.log
このログに対して、検索を行い「Installing」という文字列が出ていれば、このExtensionが正しくインストールされている状態です。もし、「Uninstalling」という文字列も同時にあった場合は、上手くいっていない状態なのでサポートチケットを上げてください。2行目のログが今回のインストール作業で表示されたものです。
ubuntu@podman:/var/log/dynatrace/oneagent/java$ sudo less ruxitagent_WebSphere_Liberty_defaultServer_1.0.log | grep Installing
2024-12-06 01:03:47.563 UTC [00000021] info [java ] [metrics ] Installing monitoring config of JMX extension 'com.dynatrace.extension.jmx-ws-liberty' (version 2.0.0)
2024-12-06 03:58:45.439 UTC [00000021] info [java ] [metrics ] Installing monitoring config of JMX extension 'com.dynatrace.extension.jmx-ws-liberty' (version 2.0.0)
JMXメトリクスの確認
- WebSphere Libertyのメトリクス取得状況の確認
実際にJMX経由でLibertyのメトリクスが取得できているか、Dynatraceの「Metrics」を開いて確認しましょう。Tag=JMXでフィルタ可能です。ここで14個のメトリクスが表示されれば完璧です。
- ダッシュボードとプロセスグループインスタンスでの取得メトリクスを確認
Extensionをインストールすると、デフォルトで関連するメトリクスを表示するダッシュボードも合わせてインストールされます(ここで言うダッシュボードは、Dashboard Classicです)いいですね、ダッシュボードも、OKです。
- ホスト配下のプロセス画面での確認
プロセス画面では、直接今回取得したLibertyのメトリクスは見えません。プロセス名の右側にある「...」をクリックして、「Metrics and logs analysys」に飛んでください。
ここをクリックすると、プロセスのUnified Viewに飛ぶことができ、ここで今回のExtensionを通じて取得したメトリクスがキレイに描画される実装になっています。
パチパチ、お疲れ様でした。
まとめ
いかがだったでしょうか?DynatraceのOneAgentはとてもパワフルで、Javaアプリであれば自動的にフルスタック監視が始められ、JVMの情報もすべて吸い上げてくれます。それだけでも十分すごいのですが、やはりプロダクト独自の内部メトリクス(今回の場合であれば、IBM WebSphere Liberty内のパフォーマンスメトリクス)も活用したうえで性能をきちんと把握したいというニーズもあります。このようなニーズにお応えすべく、Dynatraceでは誰もが簡単に使えるExtensionと呼ばれるシステムを持ち合わせていますので、是非活用してみてください!!
参考情報
今回の検証で使用したアプリ情報をまとめておきます。
- OS
- Ubuntu 24.04
ubuntu@podman:~/Scalable-web-app-liberty$ cat /etc/os-release
PRETTY_NAME="Ubuntu 24.04.1 LTS"
NAME="Ubuntu"
VERSION_ID="24.04"
VERSION="24.04.1 LTS (Noble Numbat)"
VERSION_CODENAME=noble
ID=ubuntu
ID_LIKE=debian
HOME_URL="https://www.ubuntu.com/"
SUPPORT_URL="https://help.ubuntu.com/"
BUG_REPORT_URL="https://bugs.launchpad.net/ubuntu/"
PRIVACY_POLICY_URL="https://www.ubuntu.com/legal/terms-and-policies/privacy-policy"
UBUNTU_CODENAME=noble
LOGO=ubuntu-logo
ubuntu@podman:~/Scalable-web-app-liberty$
- Javaアプリ
- https://github.com/IBM-Cloud/Scalable-web-app-liberty
- Dockerファイルを編集し、OpenLiberty.ioからイメージをダウンロードするのではなく、icr.ioから websphere-libertyイメージをダウンロードして、コンテナを build しました
ubuntu@podman:~/Scalable-web-app-liberty$ cat Dockerfile
# Package the application as a war file
FROM docker.io/maven:3.6.3-ibmjava-8-alpine AS builder
LABEL maintainer="IBM Java Engineering at IBM Cloud"
COPY pom.xml ./
COPY src src/
RUN mvn clean package
# Copy the war file over to the open liberty image
#FROM openliberty/open-liberty:kernel-java8-openj9-ubi
FROM icr.io/appcafe/websphere-liberty:kernel-java8-openj9-ubi <<< ここ
COPY --from=builder --chown=1001:0 src/main/liberty/config/ /config/
COPY --from=builder --chown=1001:0 target/*.war /config/apps/
RUN configure.sh
ubuntu@podman:~/Scalable-web-app-liberty$
- Container
- Podman
- runtime = crun
ubuntu@podman:~/Scalable-web-app-liberty$ podman version
Client: Podman Engine
Version: 4.9.3
API Version: 4.9.3
Go Version: go1.22.2
Built: Thu Jan 1 09:00:00 1970
OS/Arch: linux/amd64
ubuntu@podman:~/Scalable-web-app-liberty$
まだ、Dynatraceを触ったことがない方、このブログを見てやってみたいと思われた方は、下記フリートライアルにてお試し下さい。↓↓↓
Dynatraceフリートライアル → https://www.dynatrace.com/ja/trial/