<ph type="x-smartling-placeholder"></ph>
현재 Apigee Edge 문서를 보고 있습니다.
Apigee X 문서. 정보
이 주제에서는 네트워크 도구, JVM 도구, 진단 로그를 설명합니다. Apigee Edge에서 네트워크 및 JVM 관련 문제를 해결해 보세요.
TCP/IP 패킷 스니퍼 (tcpdump) 유틸리티
tcpdump 도구는 다음과 같은 작업을 할 수 있는 명령줄 패킷 스니퍼 도구입니다. 네트워크를 통해 수신되거나 전송되는 TCP/IP 패킷을 캡처하거나 필터링합니다. 사용 가능 Linux/Unix 기반 운영체제에서 사용할 수 있습니다 yum을 사용하여 이 유틸리티를 설치할 수 있습니다. 다음과 같습니다.
yum install tcpdump
tcpdump 도구는 네트워크 또는 SSL 관련 문제를 해결하는 데 유용합니다. 예를 들면 다음과 같습니다.
- 502 잘못된 게이트웨이 오류 (EOF 예외로 인해 발생)
- 503 서비스를 사용할 수 없음 오류
- SSL 핸드셰이크 실패
이러한 문제를 해결하려면 먼저 확인할 수 있습니다 Edge의 경우 다음 쌍 중 하나일 수 있습니다.
- 클라이언트 앱 및 라우터
- 라우터 및 메시지 프로세서
- 메시지 프로세서 및 백엔드 서버
문제가 있는 구성 요소 쌍을 식별하면 네트워크 패킷을 캡처하고 구성 요소 중 하나 또는 모두에 tcpdump를 사용하는 것이 좋습니다.
tcpdump를 사용하여 특정 호스트와 주고받은 패킷 캡처
다음 tcpdump 명령어를 사용하여 업데이트하고 해당 정보를 지정된 파일에 저장합니다.
tcpdump -i any -s 0 host <IP address> -w <File name>
각 항목의 의미는 다음과 같습니다.
매개변수 | 설명 |
-i | (인터페이스)는 패킷을 캡처해야 하는 인터페이스를 지정합니다. 사용 "any" 값을 사용하면 모든 인터페이스에서 패킷을 캡처할 수 있습니다. |
-s | (snarf/snaplen)은 캡처할 각 패킷의 양을 지정합니다. 0 값 사용 전체 패킷을 캡처할 수 있습니다. |
IP 주소 | 패킷을 캡처하려는 호스트의 IP 주소입니다. |
파일 이름 | tcpdump가 있어야 하는 파일의 이름입니다. |
예
메시지 프로세서와 백엔드 간에 패킷을 캡처한다고 가정해 보겠습니다. 서버:
- 메시지 프로세서 머신에 로그인합니다.
- 원하는 백엔드 서버의 IP 주소 (22.22.22.22라고 가정)를 결정합니다. 사용하여 패킷을 캡처합니다
다음 명령어를 사용하여 특정 IP를 사용하는 호스트의 네트워크 패킷을 캡처합니다. 주소:
tcpdump -i any -s 0 host 22.22.22.22 -w rmp-123.pcap
백엔드 서버가 여러 IP 주소로 확인되는 경우 백엔드의 호스트 이름을 사용합니다. tcpdump 명령어로 설정할 수 있습니다.
tcpdump -i any -s 0 host <Hostname> -w rmp-123.pcap
IP 주소가 다른 여러 백엔드 서버가 있는 경우 (22.22.22.22, 33.33.33.33 44.44.44.44)을 사용해야 하는 경우 아래의 tcpdump 명령어를 사용합니다.
tcpdump -i any -s 0 host 22.22.22.22 or host 33.33.33.33 or host 44.44.44.44 -w rmp-123.pcap
tcpdump 분석
tcpdump 명령어 또는 GUI 기반 도구인 Wireshark를 사용하여 tcpdump를 보거나 분석할 수 있습니다.
참조
- <ph type="x-smartling-placeholder"></ph> tcpdump 설명 페이지
- <ph type="x-smartling-placeholder"></ph> TCPdump 명령어 - 네트워크 스니퍼 도구
- Wireshark
힙 덤프
힙 덤프는 Java 프로세스의 메모리 스냅샷입니다. 여기에는 힙 덤프가 실행되는 시점에 힙에 있는 Java 객체 및 클래스에 대한 정보 수집됩니다. 일반적으로 몇 100MB에서 몇 초에 이르는 매우 큰 크기입니다. GB
힙 덤프는 메시지 프로세서와 같은 Java 프로세스에서 다음을 표시할 때 매우 유용합니다.
- 높은 메모리 사용량
- OutofMemoryError
Java 프로세스의 힙 덤프 생성
Java는 jmap이라는 유틸리티를 제공하며 이 유틸리티를 사용하면 메모리를 생성할 수 있습니다. 통계 또는 힙 덤프의 출력을 생성하는 데 사용됩니다.
다음 jmap 명령어를 사용하여 Java 프로세스의 힙 덤프를 생성합니다.
sudo -u apigee <JAVA_HOME>/bin/jmap -dump:live,format=b,file=<filename> <pid>
각 항목의 의미는 다음과 같습니다.
매개변수 | 설명 |
JAVA_HOME | Java의 설치 디렉터리임 |
filename | 힙 덤프를 기록할 파일 이름입니다. |
pid | 헤드 덤프를 캡처해야 하는 Java 애플리케이션의 프로세스 ID입니다. |
예
메시지 프로세서 mp-east가 메모리 사용량이 높거나 OutOfMemory 오류가 발생합니다. ps 명령어를 사용하여 메시지 프로세서의 프로세스 ID를 확인 Unix 운영체제 24569라고 가정해 보겠습니다.
다음과 같이 jmap 유틸리티를 실행하여 힙 덤프를 생성합니다.
sudo -u apigee <JAVA_HOME>/bin/jmap -dump:live,format=b,file=mp-east-heapdump.bin 24569
힙 덤프 분석
힙 덤프는 Eclipse MAT (Memory Analyzer Tool)를 사용하여 분석하면 잠재적인 메모리 누수 또는 메모리 사용량 높은 자바 객체를 파악할 수 있습니다
참조
<ph type="x-smartling-placeholder"></ph> 힙 덤프 수집 방법
<ph type="x-smartling-placeholder"></ph> jmap 유틸리티
<ph type="x-smartling-placeholder"></ph> jmap 설명 페이지
<ph type="x-smartling-placeholder"></ph> 메모리 분석기 도구 (MAT)
스레드 덤프
스레드 덤프는 실행 중인 Java 프로세스의 모든 스레드 상태에 대한 스냅샷입니다. 이 각 스레드의 상태는 스택 트레이스라고 하는 스택 콘텐츠와 함께 표시됩니다. 일부 스레드는 실행 중인 Java 애플리케이션의 일부가 되고 다른 스레드는 JVM 내부 스레드.
스레드 덤프는 애플리케이션의 각 스레드 활동에 관한 정보를 보여줍니다. 이 정보는 다음과 같은 경우에 매우 유용할 수 있습니다.
- CPU 급증, 느린 응답 시간, 응답하지 않는 Java 등의 문제를 진단합니다. 응용 프로그램
- 애플리케이션 및 JVM 성능 최적화
스레드 덤프 생성
Java 프로세스에 대한 스레드 덤프는 아래와 같이 jstack 유틸리티를 사용하여 생성할 수 있습니다. 아래:
sudo -u apigee <JAVA_HOME>/bin/jstack -l <pid> > <filename>
각 항목의 의미는 다음과 같습니다.
매개변수 | 설명 |
JAVA_HOME | Java의 설치 디렉터리입니다. |
pid | 스레드 덤프를 캡처하려는 Java 애플리케이션의 프로세스 ID입니다. |
filename | 스레드 덤프가 기록될 파일 이름입니다. |
예
메시지 프로세서에서 프로세스 ID 37320의 스레드 덤프 생성 mp-east를 사용하는 경우 다음 명령어를 사용합니다.
sudo -u apigee <JAVA_HOME>/bin/jstack -l 37320 > /opt/apigee/edge-message-processor/mp-east-threadDump.txt
위의 예에 따라 프로세스의 스레드 덤프는 /opt/apigee/edge-message-processor/mp-east-threadDump.txt 파일
스레드 덤프 분석
vi (Linux), 메모장 (Windows)과 같은 텍스트 편집기에서 스레드 덤프를 볼 수 있습니다. 자세한 내용은 Thread Dump를 참조하세요. 확인할 수 있습니다
참조
- <ph type="x-smartling-placeholder"></ph> jstack 유틸리티
- <ph type="x-smartling-placeholder"></ph> 스레드 덤프 분석: CPU 고사용량 문제
- <ph type="x-smartling-placeholder"></ph> Java 스레드 덤프를 분석하는 방법