JProfiler 도움말

프로파일링을 위한 커맨드 라인 실행 파일

JProfiler에는 프로파일링 에이전트 설정 및 커맨드 라인에서 프로파일링 작업을 제어할 수 있는 여러 커맨드 라인 도구가 포함되어 있습니다.

실행 중인 JVM에 프로파일링 에이전트 로드하기

커맨드 라인 유틸리티 bin/jpenable을 사용하면, 버전 6 이상인 모든 실행 중인 JVM에 프로파일링 에이전트를 로드할 수 있습니다. 커맨드 라인 인자를 사용하면 사용자 입력 없이 자동화된 처리가 가능합니다. 지원되는 인자는 다음과 같습니다:

사용법: jpenable [옵션]

jpenable은 선택된 로컬 JVM에서 프로파일링 에이전트를 시작하여 다른 컴퓨터에서
연결할 수 있게 합니다. JProfiler GUI가 로컬에서 실행 중인 경우, 이 실행 파일을
실행하는 대신 JProfiler GUI에서 직접 attach할 수 있습니다.

* 인수가 주어지지 않으면, jpenable은 아직 프로파일되지 않은 로컬 JVM을
  발견하려고 시도하며, 명령줄에서 필요한 모든 입력을 요청합니다.
* 다음 인수를 사용하여 명령줄에서 사용자 입력을 부분적으로 또는 완전히
  제공할 수 있습니다:

  -d  --pid=<PID>     프로파일링할 JVM의 PID
  -n  --noinput       어떠한 경우에도 사용자 입력을 요청하지 않음
  -h  --help          이 도움말 표시
      --options=<OPT> 에이전트에 전달되는 디버깅 옵션

  GUI 모드: (기본값)
  -g  --gui           JProfiler GUI를 사용하여 JVM에 attach
  -p  --port=<nnnnn>  JProfiler GUI에서 연결을 수신할 프로파일링 에이전트의 포트
  -a  --address=<IP>  프로파일링 에이전트가 수신할 주소. 이 매개변수가 없으면,
                      localhost에서만 attach할 수 있습니다.
                      모든 주소에서 수신하려면 0.0.0.0을 사용하십시오.

  오프라인 모드:
  -o  --offline       JVM을 오프라인 모드에서 프로파일링
  -c  --config=<PATH> 프로파일링 설정이 있는 구성 파일의 경로
  -i  --id=<ID>       구성 파일의 세션 ID. 구성 파일에 단일 세션만
                      포함되어 있는 경우 필요하지 않습니다.

JVM은 jpenable과 동일한 사용자로 실행되어야 하며, 그렇지 않으면
JProfiler가 연결할 수 없습니다.
예외는 jpenable로 대화형으로 나열할 때 로컬 시스템 계정에서 실행되는 Windows 서비스입니다.

HPROF 스냅샷 저장하기

힙 스냅샷만 필요하다면, bin/jpdump 커맨드 라인 도구를 사용하여 프로파일링 에이전트를 VM에 로드하지 않고 HPROF 스냅샷을 저장할 수 있습니다:

사용법: jpdump [옵션]

jpdump는 로컬에서 실행 중인 JVM의 힙을 파일로 덤프합니다.
Hotspot VM은 HPROF 파일을 생성하고, OpenJ9 VM은 PHD 파일을 생성합니다.
HPROF 및 PHD 파일은 JProfiler GUI에서 열 수 있습니다.

* 인수가 주어지지 않으면, jpdump는 로컬에서 실행 중인 모든 JVM을 나열합니다.
* 다음 인수로 명령줄에서 사용자 입력을 부분적으로 또는 완전히 제공할 수 있습니다:
  전체 사용자 입력을 명령줄에서 제공할 수 있습니다:

  -p  --pid=<PID>    힙을 덤프할 JVM의 PID
                     PID가 지정되면 추가 질문은 없습니다.
  -a  --all          모든 객체를 저장합니다. 지정하지 않으면, 활성 객체만
                     덤프됩니다
  -f  --file=<PATH>  덤프 파일의 경로. 지정하지 않으면, 덤프 파일은
                     <VM 이름>.hprof로 현재 디렉토리에 작성됩니다.
                     파일이 이미 존재하면, 숫자가 추가됩니다.
  -h  --help         이 도움말 표시

JVM은 jpdump와 동일한 사용자로 실행되어야 하며, 그렇지 않으면
JProfiler가 연결할 수 없습니다.
예외는 jpdump로 대화형으로 나열할 때 로컬 시스템 계정에서 실행되는 Windows 서비스입니다.

이 방법은 프로파일링 에이전트를 로드하고 JProfiler 힙 스냅샷을 저장하는 것보다 오버헤드가 적습니다. 또한, 프로파일링 에이전트는 한 번 로드되면 언로드할 수 없으므로, 이 방법은 운영 환경에서 실행 중인 JVM에 적합합니다.

프로파일링 에이전트 제어하기

bin/jpcontroller 실행 파일을 인자 없이 시작하면, 로컬 머신에서 프로파일된 JVM에 연결을 시도합니다. 여러 프로파일된 JVM이 발견된 경우, 목록에서 하나를 선택할 수 있습니다.

jpcontroller는 프로파일링 설정이 지정된 JVM에만 연결할 수 있으므로, -agentpath VM 파라미터에 "nowait" 옵션이 설정된 경우에는 동작하지 않습니다. 이 옵션은 통합 마법사의 "Startup mode" 화면에서 즉시 시작, 나중에 JProfiler GUI로 연결 라디오 버튼을 선택하고 아직 JProfiler GUI가 에이전트에 연결되지 않은 경우에 설정됩니다. --offline 인자 없이 jpenable을 사용하는 경우에도 jpcontroller가 프로파일된 프로세스에 연결하기 전에 JProfiler GUI에서 연결이 필요합니다.

원격 컴퓨터의 프로세스에 연결하거나, JVM이 버전 6 이상의 HotSpot JVM이 아닌 경우, 프로파일된 JVM에 -Djprofiler.jmxServerPort=[port] VM 파라미터를 전달해야 합니다. 해당 포트에 MBean 서버가 게시되며, 선택한 포트를 jpcontroller의 인자로 지정할 수 있습니다. 추가적으로 -Djprofiler.jmxPasswordFile=[file] VM 파라미터를 사용하면 user password 형식의 키-값 쌍이 들어 있는 프로퍼티 파일을 지정하여 인증을 설정할 수 있습니다(공백 또는 탭으로 구분). 이 VM 파라미터들은 com.sun.management.jmxremote.port VM 파라미터에 의해 덮어써질 수 있습니다.

JMX 서버를 명시적으로 설정하면, 커맨드 라인 컨트롤러를 사용하여 jpcontroller host:port로 원격 서버에 연결할 수 있습니다. 원격 컴퓨터가 IP 주소로만 접근 가능한 경우, 원격 VM의 VM 파라미터에 -Djava.rmi.server.hostname=[IP address]를 추가해야 합니다.

기본적으로 jpcontroller는 대화형 커맨드 라인 유틸리티이지만, 수동 입력 없이 프로파일링 세션을 자동화할 수도 있습니다. 자동화된 실행에서는 [pid | host:port]를 전달하여 프로파일된 JVM을 선택하고, --non-interactive 인자를 추가합니다. 또한, 명령 목록은 stdin 또는 --command-file 인자로 지정된 커맨드 파일에서 읽어옵니다. 각 명령은 새 줄에서 시작하며, 빈 줄이나 "#"로 시작하는 주석 줄은 무시됩니다.

이 비대화형 모드에서의 명령은 JProfiler MBean의 메서드 이름과 동일합니다. 각 명령은 동일한 개수의 파라미터를 필요로 하며, 파라미터는 공백으로 구분합니다. 문자열에 공백이 포함된 경우에는 큰따옴표로 감싸야 합니다. 추가적으로, sleep <seconds> 명령이 제공되어 지정한 초만큼 대기할 수 있습니다. 이를 통해 녹화를 시작하고, 일정 시간 대기한 후 스냅샷을 디스크에 저장할 수 있습니다.

프로파일링 설정은 프로파일링 에이전트에 지정되어야 합니다. 이는 JProfiler UI로 연결할 때 이루어집니다. JProfiler UI로 한 번도 연결하지 않는 경우, 시작 커맨드에서 직접 지정하거나 jpenable로 수동 설정해야 합니다. 자세한 내용은 시작 시 프로파일링 설정 지정에 관한 도움말을 참고하세요.

jpcontroller에서 지원하는 인자는 아래와 같습니다:

사용법: jpcontroller [옵션] [host:port | pid]

* 인수가 주어지지 않으면, jpcontroller는 프로파일된
   로컬 JVM을 검색하려고 시도합니다
* 단일 숫자가 지정되면, jpcontroller는 프로세스 ID [pid]를 가진 JVM에
   연결을 시도합니다. 해당 JVM이 프로파일되지 않은 경우, jpcontroller는
   연결할 수 없습니다. 그런 경우, 먼저 jpenable 유틸리티를 사용하십시오.
* 그렇지 않으면, jpcontroller는 "host:port"에 연결하며, 여기서 port는
   프로파일된 JVM의 VM 매개변수 -Djprofiler.jmxServerPort=[port]에
   지정된 값입니다.

사용 가능한 옵션:
  -n --non-interactive      명령 목록이 stdin에서 읽혀지는 자동화된 세션을 실행합니다.
  -f --command-file=<PATH>  stdin 대신 파일에서 명령을 읽습니다. 이는
                            --non-interactive와 함께 사용할 수 있습니다.

비대화형 명령의 구문:
  RemoteControllerMBean (https://bit.ly/2DimDN5)의 javadoc을 참조하여
  작업 목록을 확인하십시오. 매개변수는 공백으로 구분되며, 공백이 포함된 경우
  인용부호로 묶어야 합니다. 예를 들어:

    addBookmark "Hello world"
    startCPURecording true
    startProbeRecording builtin.JdbcProbe true true
    sleep 10
    stopCPURecording
    stopProbeRecording builtin.JdbcProbe
    saveSnapshot /path/to/snapshot.jps

  sleep <seconds> 명령은 지정된 초 수만큼 일시 중지합니다.
  빈 줄과 #으로 시작하는 줄은 무시됩니다.