문서
원본 보기13 JMX 에이전트
개요
JMX 모니터링은 Java 애플리케이션의 JMX 카운터를 모니터링하는 데 사용할 수 있습니다.
JMX 모니터링은 "Zabbix Java gateway"라는 Zabbix 데몬 형태로 Zabbix에서 기본적으로 지원됩니다.
호스트의 특정 JMX 카운터 값을 검색하기 위해, Zabbix 서버는 Zabbix Java gateway에 쿼리를 보내고, Java gateway는 JMX management API를 사용하여 관심 있는 애플리케이션을 원격으로 쿼리합니다.
자세한 내용과 설정은 Zabbix Java gateway 섹션을 참조하세요.
Java gateway와 모니터링되는 JMX 애플리케이션 간의 통신은 방화벽으로 차단되어서는 안 됩니다.
Java 애플리케이션에서 원격 JMX 모니터링 활성화
Java 애플리케이션은 추가 소프트웨어를 설치할 필요가 없지만, 원격 JMX 모니터링을 지원하려면 아래 지정된 명령줄 옵션과 함께 시작해야 합니다.
최소한의 요구사항으로, 보안이 적용되지 않은 로컬 호스트에서 단순한 Java 애플리케이션을 모니터링하며 시작하고 싶다면, 다음 옵션으로 시작하세요:
java \
-Dcom.sun.management.jmxremote \
-Dcom.sun.management.jmxremote.port=12345 \
-Dcom.sun.management.jmxremote.authenticate=false \
-Dcom.sun.management.jmxremote.ssl=false \
-Dcom.sun.management.jmxremote.registry.ssl=false \
-jar /path/to/your/application.jar
이것은 Java가 로컬 호스트에서만 포트 12345를 통해 들어오는 JMX 연결을 수신하도록 하며, 인증이나 SSL을 요구하지 않도록 지정합니다.
다른 인터페이스에서의 연결을 허용하려면, -Djava.rmi.server.hostname 파라미터를 해당 인터페이스의 IP로 설정하세요.
보안에 대해 더 엄격하게 하고 싶다면, 사용할 수 있는 다른 많은 Java 옵션이 있습니다. 예를 들어, 다음 예제는 더 다양한 옵션 세트로 애플리케이션을 시작하고 로컬 호스트뿐만 아니라 더 넓은 네트워크에 개방합니다.
java \
-Djava.rmi.server.hostname=192.168.3.14 \
-Dcom.sun.management.jmxremote \
-Dcom.sun.management.jmxremote.port=12345 \
-Dcom.sun.management.jmxremote.authenticate=true \
-Dcom.sun.management.jmxremote.password.file=/etc/java-6-openjdk/management/jmxremote.password \
-Dcom.sun.management.jmxremote.access.file=/etc/java-6-openjdk/management/jmxremote.access \
-Dcom.sun.management.jmxremote.ssl=true \
-Dcom.sun.management.jmxremote.registry.ssl=true \
-Djavax.net.ssl.keyStore=$YOUR_KEY_STORE \
-Djavax.net.ssl.keyStorePassword=$YOUR_KEY_STORE_PASSWORD \
-Djavax.net.ssl.trustStore=$YOUR_TRUST_STORE \
-Djavax.net.ssl.trustStorePassword=$YOUR_TRUST_STORE_PASSWORD \
-Dcom.sun.management.jmxremote.ssl.need.client.auth=true \
-jar /path/to/your/application.jar
이러한 설정의 대부분(또는 전부)은
$JRE/lib/management/management.properties (또는 시스템에서
해당 파일이 있는 위치)에서 지정할 수 있습니다.
SSL을 사용하고 싶다면, Java 게이트웨이가 키 스토어와 트러스트 스토어를
어디에서 찾을지 알 수 있도록 -Djavax.net.ssl.* 옵션을 추가하여
startup.sh 스크립트를 수정해야 함을 주의하세요.
자세한 설명은 JMX를 사용한 모니터링 및 관리를 참조하세요.
Zabbix 프론트엔드에서 JMX 인터페이스와 아이템 구성하기
Java 게이트웨이가 실행되고, 서버가 게이트웨이의 위치를 알고 있으며, 원격 JMX 모니터링을 지원하는 Java 애플리케이션이 시작되었다면, 이제 Zabbix GUI에서 인터페이스와 아이템을 구성할 차례입니다.
JMX 인터페이스 구성
관심 있는 호스트에서 JMX 유형 인터페이스를 생성하는 것으로 시작합니다.

모든 필수 입력 필드는 빨간색 별표로 표시됩니다.
JMX 에이전트 아이템 추가
관심 있는 각 JMX 카운터에 대해 해당 인터페이스에 연결된 JMX 에이전트 아이템을 추가합니다.
아래 스크린샷의 키는
jmx["java.lang:type=Memory","HeapMemoryUsage.used"]입니다.

모든 필수 입력 필드는 빨간색 별표로 표시됩니다.
JMX 아이템에 특별한 정보가 필요한 필드는 다음과 같습니다:
| 타입 | 여기서 JMX 에이전트를 설정합니다. |
| 키 | jmx[] 아이템 키는 세 개의 매개변수를 포함합니다:객체 이름 - MBean의 객체 이름 속성 이름 - 점으로 구분된 선택적 복합 데이터 필드 이름을 가진 MBean 속성 이름 고유한 간단 설명 - 호스트에서 동일한 객체 이름과 속성 이름을 가진 여러 JMX 아이템을 허용하는 고유 설명 (선택 사항) JMX 아이템 키에 대한 자세한 내용은 아래를 참조하세요. jmx.discovery[] 하위 수준 검색 아이템을 사용하여 MBean 및 MBean 속성을 검색할 수 있습니다. |
| JMX 엔드포인트 | 사용자 정의 JMX 엔드포인트를 지정할 수 있습니다. JMX 엔드포인트 연결 매개변수가 JMX 인터페이스와 일치하는지 확인하세요. 이는 기본 JMX 엔드포인트에서 수행된 것처럼 {HOST.*} 매크로를 사용하여 달성할 수 있습니다. {HOST.*} 매크로와 사용자 매크로가 지원됩니다. |
| 사용자 이름 | Java 애플리케이션에서 인증을 구성한 경우 사용자 이름(최대 255자)을 지정합니다. 사용자 매크로가 지원됩니다. |
| 비밀번호 | Java 애플리케이션에서 인증을 구성한 경우 비밀번호(최대 255자)를 지정합니다. 사용자 매크로가 지원됩니다. |
"true" 또는 "false" 중 하나인 부울 카운터를 모니터링하려면 정보 타입을 "숫자 (부호 없음)"으로 지정하고 전처리 탭에서 "부울을 십진수로" 전처리 단계를 선택합니다. 서버는 부울 값을 각각 1 또는 0으로 저장합니다.
JMX 항목 키 상세 정보
단순 속성
MBean 객체명은 Java 애플리케이션에서 정의하는 문자열에 불과합니다. 반면 속성명은 더 복잡할 수 있습니다. 속성이 기본 데이터 타입(정수, 문자열 등)을 반환하는 경우에는 걱정할 것이 없으며, 키는 다음과 같은 형태가 됩니다:
jmx[com.example:Type=Hello,weight]
이 예제에서 객체명은 "com.example:Type=Hello"이고, 속성명은 "weight"이며, 반환되는 값 타입은 아마도 "Numeric (float)"일 것입니다.
복합 데이터를 반환하는 속성
속성이 복합 데이터를 반환할 때는 더 복잡해집니다. 예를 들어: 속성 이름이 "apple"이고 "weight", "color" 등과 같은 매개변수를 나타내는 해시를 반환한다고 가정해봅시다. 키는 다음과 같이 보일 수 있습니다:
jmx[com.example:Type=Hello,apple.weight]
이것이 속성 이름과 해시 키가 점 기호를 사용하여 구분되는 방식입니다. 마찬가지로, 속성이 중첩된 복합 데이터를 반환하는 경우 부분들이 점으로 구분됩니다:
jmx[com.example:Type=Hello,fruits.apple.weight]
표 형식 데이터를 반환하는 속성
표 형식 데이터 속성은 하나 또는 여러 개의 복합 속성으로 구성됩니다. 이러한 속성이 속성 이름 매개변수에 지정되면 이 아이템 값은 JSON 형식으로 속성의 완전한 구조를 반환합니다. 표 형식 데이터 속성 내부의 개별 요소 값은 전처리를 사용하여 검색할 수 있습니다.
표 형식 데이터 속성 예제:
jmx[com.example:type=Hello,foodinfo]
아이템 값:
[
{
"a": "apple",
"b": "banana",
"c": "cherry"
},
{
"a": "potato",
"b": "lettuce",
"c": "onion"
}
]
점 기호와 관련된 문제
지금까지는 좋습니다. 하지만 속성 이름이나 해시 키에 점 기호가 포함되어 있다면 어떻게 될까요? 다음은 예시입니다:
jmx[com.example:Type=Hello,all.fruits.apple.weight]
이는 문제가 됩니다. 속성 이름이 "all"이 아니라 "all.fruits"라는 것을 Zabbix에게 어떻게 알려줄까요? 이름의 일부인 점과 속성 이름과 해시 키를 구분하는 점을 어떻게 구별할까요?
이는 가능합니다. 이름의 일부인 점을 백슬래시로 이스케이프 처리하면 됩니다:
jmx[com.example:Type=Hello,all\.fruits.apple.weight]
마찬가지로, 해시 키에 점이 포함되어 있다면 이스케이프 처리합니다:
jmx[com.example:Type=Hello,all\.fruits.apple.total\.weight]
기타 이슈
속성명에서 백슬래시 문자는 이스케이프 처리되어야 합니다:
jmx[com.example:type=Hello,c:\\documents]
JMX 아이템 키에서 다른 특수 문자 처리에 대해서는 아이템 키 형식 섹션을 참조하세요.
실제로 이것이 전부입니다. 즐거운 JMX 모니터링을 하세요!
비원시형 데이터 타입
toString() 메서드를 오버라이드하는 비원시형 데이터 타입을 반환하는 커스텀 MBeans를 사용할 수 있습니다.
JBoss EAP 6.4에서 커스텀 엔드포인트 사용하기
커스텀 엔드포인트를 사용하면 기본 RMI가 아닌 다른 전송 프로토콜과 함께 작업할 수 있습니다.
이 가능성을 설명하기 위해, 예시로 JBoss EAP 6.4 모니터링을 구성해 보겠습니다. 먼저 몇 가지 가정을 해보겠습니다:
- 이미 Zabbix Java gateway를 설치했습니다. 그렇지 않다면 문서에 따라 설치할 수 있습니다.
- Zabbix 서버와 Java gateway가
/usr/local/접두사로 설치되었습니다 - JBoss가 이미
/opt/jboss-eap-6.4/에 설치되어 있고 독립 실행형 모드로 실행 중입니다 - 이 모든 구성 요소가 동일한 호스트에서 작동한다고 가정하겠습니다
- 방화벽과 SELinux가 비활성화되었습니다(또는 적절히 구성됨)
zabbix_server.conf에서 몇 가지 간단한 설정을 해보겠습니다:
JavaGateway=127.0.0.1
StartJavaPollers=5
그리고 zabbix_java/settings.sh 구성 파일(또는 zabbix_java_gateway.conf)에서:
START_POLLERS=5
JBoss가 표준 관리 포트에서 수신 대기하는지 확인하세요:
$ netstat -natp | grep 9999
tcp 0 0 127.0.0.1:9999 0.0.0.0:* LISTEN 10148/java
이제 Zabbix에서 JMX 인터페이스 127.0.0.1:9999로 호스트를 생성해보겠습니다.

이 버전의 JBoss가 RMI 대신 JBoss Remoting 프로토콜을 사용한다는 것을 알고 있으므로, JMX 템플릿에서 아이템의 JMX 엔드포인트 매개변수를 다음과 같이 대량 업데이트할 수 있습니다:
service:jmx:remoting-jmx://{HOST.CONN}:{HOST.PORT}

구성 캐시를 업데이트해보겠습니다:
/usr/local/sbin/zabbix_server -R config_cache_reload
먼저 오류가 발생할 수 있습니다.

"지원되지 않는 프로토콜: remoting-jmx"는 Java gateway가 지정된 프로토콜을 사용하는 방법을 모른다는 의미입니다. 다음 내용으로 ~/needed_modules.txt 파일을 생성하여 이를 수정할 수 있습니다:
jboss-as-remoting
jboss-logging
jboss-logmanager
jboss-marshalling
jboss-remoting
jboss-sasl
jcl-over-slf4j
jul-to-slf4j-stub
log4j-jboss-logmanager
remoting-jmx
slf4j-api
xnio-api
xnio-nio
그런 다음 다음 명령을 실행하세요:
for i in $(cat ~/needed_modules.txt); do find /opt/jboss-eap-6.4 -iname "${i}*.jar" -exec cp '{}' /usr/local/sbin/zabbix_java/lib/ \; ; done
이렇게 하면 Java gateway에 jmx-remoting과 함께 작업하는 데 필요한 모든 모듈이 포함됩니다. 남은 것은 Java gateway를 재시작하고 잠시 기다린 다음, 모든 작업을 올바르게 수행했다면 JMX 모니터링 데이터가 Zabbix에 도착하기 시작하는 것을 확인하는 것입니다(참조: 최신 데이터).