민스씨의 일취일장

VisualVM | Java 애플리케이션의 모니터링 도구 with Docker 본문

Projects/MetaPay

VisualVM | Java 애플리케이션의 모니터링 도구 with Docker

읻민스 2024. 8. 7. 17:08
반응형

VisualVM 사용하며 겪은 시행착오와 사용 방법에 대한 글입니다.

VisualVM이란?

VisualVM은 Java 애플리케이션을 위한 성능 모니터링 및 프로파일링 도구이다.

VisualVM 사용방법

VisualVM은 응용프로그램으로, 간단하게 다운만 받으면 바로 실행할 수 있다.

설치

아래 링크에서 자신의 OS에 맞는 VisualVM을 다운 받으면 된다.

 

VisualVM: Download

First Steps Unzip the downloaded archive. The archive already contains the top-level visualvm directory. Start VisualVM by invoking the binary appropriate for your OS:visualvm\bin\visualvm.exe or visualvm/bin/visualvm You may provide additional options to

visualvm.github.io

visualVM 웹사이트 모습이다.
visualVM [출처: https://visualvm.github.io/]

Dockerfile 수정

JMX포트 설정을 추가해주면서, 모니터링으로 사용할 포트도 추가로 열어준다.

...
EXPOSE 8080 9010
...
# JMX Port Setting
ENV JAVA_OPTS="-Dcom.sun.management.jmxremote \
               -Dcom.sun.management.jmxremote.port=9010 \
               -Dcom.sun.management.jmxremote.rmi.port=9010 \
               -Dcom.sun.management.jmxremote.authenticate=false \
               -Dcom.sun.management.jmxremote.ssl=false \
               -Djava.rmi.server.hostname=localhost"
...

Docker Container 실행

도커 컨테이너 실행할 때 포트 매핑을 한 개 더 추가해준다.

docker run -d -p 8081:80 -p 9010:9010 --name container-name image-name

VisualVM에서 Container 서버 접속

VisualVM



Add Remote Host를 선택하는 모습이다.
Add Remote Host
9010 포트를 설정한 모습이다.
9010 포트 설정



연결 안됨

localhost로 아무리 연결해도 되지 않는다.

해결방법

  • Dockerfile 수정

hostname을 localhost에서 0.0.0.0으로 변경해준다.

...
EXPOSE 8080 9010
...
# JMX Port Setting
ENV JAVA_OPTS="-Dcom.sun.management.jmxremote \
               -Dcom.sun.management.jmxremote.port=9010 \
               -Dcom.sun.management.jmxremote.rmi.port=9010 \
               -Dcom.sun.management.jmxremote.authenticate=false \
               -Dcom.sun.management.jmxremote.ssl=false \
               -Djava.rmi.server.hostname=0.0.0.0"
...

다시 한 번 VisualVM에서 Container 서버 접속

이번엔 Local이 아닌 Remote에서 추가해준다.

Add JMX Connection
Remote Setting
Add JMX Connection 세팅하는 모습이다.
Add JMX Connection
Port 9010 추가

 

다시 한 번 Docker Container 실행

이제 다시 도커 컨테이너를 실행시켜 준다.

docker run -d -p 8081:80 -p 9010:9010 --name container-name image-name

연결 성공

그럼 아래와 같이 자동으로 연결된 모습을 확인할 수 있다.

VisualVM이 연결에 성공한 모습이다.
VisualVM 연결 된 모습
VisualVM 모니터링 모습이다.VisualVM 모니터링 모습이다.
VisualVM 모니터링

728x90
반응형