2014-12-22 1 views
1

DynaTrace로 언젠가 보내고 있습니다. 크로스 jvm 계측 관련 기능에 깊은 인상을 받았습니다. 간단히 말해서, DynaTrace는 통계 정보가있는 추적 코드를 생성하는 Java 코드를 계측 할 수 있습니다. 이것은 새로운 것이 아닙니다. 정말 재미있는 기능이 있습니다. 외부 JVM 호출이 실행되면 DynaTrace가이 새 추적을 호출자 (즉, 원격 세션 Bean, 웹 서비스, 원격 RMI 등)에 연결할 수 있습니다. 어떻게 가능할까요? 이 기능을 구현하는 방법을 모르겠다. 어떤 아이디어?크로스 JVM 계측

고맙습니다.

답변

0

이 정보는 일반적으로 MXBeans를 사용하여 추출됩니다. 이러한 bean은 표준 런타임 정보에 액세스하기위한 표준 API를 제공합니다. 마찬가지로 이러한 응용 프로그램은 종종 특정 클래스에 대한 클래스 로더를 검색하고 하드 코딩 된 액세스로 관련 정보를 추출합니다. 따라서 자주 사용되지 않는 솔루션이 모니터링 도구에서 지원되지 않는 경우가 있습니다.

2

Dynatrace는 실제로 콩의 정보에 의존하지 않습니다. 귀하의 질문에 정확하게 말씀 하셨듯이, 우리는 시장의 다른 도구들과 같은 Byte Code Instrumentation을 사용하고 있습니다. Servlet, Axis, JMS, JDBC 등의 특정 프레임 워크의 주요 메소드를 구현합니다. 예를 들어 HTTP 기반 통신을 사용하여 한 JVM에서 다른 JVM으로 호출하는 시나리오에서 우리는 HTTP 요청은 물론 다른 JVM의 수신 측에도 적용됩니다. 발신 측에서는 현재 PurePath의 ID와 함께 추가 HTTP 헤더를 첨부합니다. PurePath는 당사의 특허 기술입니다. 따라서 모든 PurePath (= 모든 단일 트랜잭션)는 고유 한 ID를 얻습니다. 이 ID는 요청과 함께 이동합니다 (예 : HTTP 요청으로 HTTP HEADER로 지정). 수신 측 (두 번째 JVM)에서 HTTP 헤더를 검사하여 수집 한 모든 데이터가 해당 PurePath에 속해 있음을 확인합니다. 이렇게하면 Beans와 같은 것에 의존하지 않고, 또는 타임 스탬프를 기반으로 데이터를 상관하지 않고 실제 엔드 투 엔드 추적을 수행 할 수 있습니다.

의미가 있습니까? 질문이 있으시면 알려주십시오. 또한 몇 가지 동영상을 녹화하고 기술 및 제품 자체를 설명하기 위해 YouTube에 올렸습니다. http://bit.ly/dttutorials

+0

안녕하세요, Andreas, 답변 해 주셔서 감사합니다. HTTP 요청을 예제로 사용하지만 RMI, 웹 서버 및 기타 원격 호출 기술에 대해서도 JVM 간 메커니즘이 작동한다고 가정합니다. RMI/EJB 호출의 경우에는 mothid 서명을 변경하지 않으므로 ID를 원격 JVM으로 전송하는 방법은 무엇입니까? – Alex

+0

수정하십시오. 메소드 서명을 변경하지 않습니다. 발신자에게서 수신자에게 "PurePath ID"를 전달하는 다른 방법을 찾아 냈습니다. RMI, JMS, Thread Pooling에 대해 사실입니다. 다른 프로토콜에 대해 구현 한 모든 기술적 세부 사항을 공유 할 수는 없지만 간단히 시도해보십시오. 수정하지 않고도 작동한다는 것을 알 수 있습니다. 그것은 한 쪽을 측량 할 때만 아무것도 망가 뜨리지 않습니다. 모두 잘 테스트되고 사용자의 대규모 시스템에서 실행됩니다. 시도 해봐. 30 일 무료 평가판 프로그램을 실행합니다. http://bit.ly/dttrial –

+0

안녕하세요 Andreas, 다시 답변 해주세요. 상용 제품의 기술적 구현을 ​​공유 할 수 없다는 것을 이해합니다. 하지만 그것은 일반적인 설명인데도 내가 찾고있는 정보입니다. – Alex