keycloak~jconsole監控wildfly和jboss

keycloak運行在wildfly(jboss)中,如果希望查詢它在jboss中的運行情況,如堆內存,線程,GC等,可以通過jconsole進行遠程監控。
參考:
https://goldmann.pl/blog/2013/04/16/jmx-connections-to-jboss-as/
https://www.cnblogs.com/tangculijizyw/p/9108015.html
https://groups.google.com/g/keycloak-user/c/eMHYfgmOQXU

注意

通過jconsole連接keycloak時,我們從keycloak中將jboss-cli-client.jar(放到jconsole.bat同級目錄的bin/client下面)文件下載到windows客戶端,從keycloak下載的jconsole.bat來啓動它,如果使用JVM自帶的jconsole是無法連接jboss服務器的,這一點我測試了很多次才發現。

添加遠程監控的步驟

以容器化部署keycloak爲例

  • 添加jms.cli
embed-server --server-config=standalone-ha.xml --std-out=echo
batch
/profile=full/subsystem=jmx/remoting-connector=jmx:add(use-management-endpoint=true)
run-batch
stop-embedded-server
  • Dockerfile裏複製它
ADD jms.cli /opt/jboss/startup-scripts/
  • Dockerfile裏添加管理員用戶信息,用來登錄遠程jboss
RUN  /opt/jboss/keycloak/bin/add-user.sh test 123456
  • Docker啓動時添加環境 變化 ,注意0.0.0.0表示使用所有可用IP,如果是127.0.0.1表示只有本機訪問
docker run --name keycloak -d -p 8080:8080 -p 9990:9990  -e JAVA_OPTS="-Xms512M -Xmx1024M  -XX:MaxHeapSize=1024M  -Djboss.bind.address.management=0.0.0.0"  keycloak/self
  • 使用jconsole來連接遠程JBOSS
JMX URL: service:jmx:http-remoting-jmx://192.168.4.26:9990
Username: `test`
Password: `123456`

注意,你的jconsole應該是從keycloak容器裏複製出來的,需要有jboss-cli-client.jar這個jar的,它的目前目錄的bin/client目錄下(默認%JBOSS_HOME/bin/client下面)。

通過jboss的UI界面去查看

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章