nginx 추적 및 디 버 깅

1346 단어 nginxgdb
디 버 깅 을 통 해 문 제 를 편리 하 게 포 지 셔 닝 하여 bug 를 해결 할 수 있 습 니 다.
본 고 는 주로 책 에서 언급 한 내용 을 정리 하고 구체 적 인 세부 사항 은 천천히 갱신 할 것 이다. 왜냐하면 세부 사항 은 천천히 읽 는 과정 에서 겪 은 것 이기 때문이다.
추적 과 디 버 깅 은 주로 6 개 부분 으로 나 뉜 다.
1. GDB 디 버 깅 이용:
구체 적 인 디 버 깅 방법 은 Nginx 학습 의 14 - GDB 디 버 깅 Nginx 초기 시험 을 참고 할 수 있다. ,그리고 'Nginx 심층 분석' 작가 의 블 로그: 클릭 하여 링크 열기
사실 지난 절 방법 을 통 해 eclipse 를 통 해 코드 를 쉽게 디 버 깅 할 수 있 습 니 다. 물론 gdb 는 명령 행 을 통 해 더욱 유연 합 니 다.
파 라 메 터 를 가지 고 gdb 디 버 깅 에 들 어 갑 니 다:
4. 567913. 들 어간 후에 중단 점 / 단일 디 버 깅 / 관찰 점 설정 등 구체 적 인 디 버 깅 기술 이다.
2. 로그 정보 로 Nginx 추적 하기:
printf 는 소형 프로그램의 인쇄 기능 함수 라 는 것 을 알 고 있 습 니 다. 그러나 프로그램 이 대형 이 되면 printf 는 그다지 유연 하지 않 습 니 다. 따라서 대형 시스템 은 서로 다른 등급 의 출력 통 제 를 제공 합 니 다. 예 를 들 어 Liux 커 널 / NS3 네트워크 시 뮬 레이 션 도구 등 입 니 다. 설정 파일 에 로그 메시지 의 디 렉 터 리 와 단 계 를 설정 한 다음 프로그램 에서 ngx 를 호출 합 니 다.log_xxx () 시리즈 함수 면 됩 니 다.
3. strace / pstack 디 버 깅 프로그램 이용:
이 두 명령 을 통 해 프로그램 이 실행 과정 에서 시 작 된 시스템 함수 호출 과 동적 라 이브 러 리 함수 호출 을 볼 수 있 습 니 다. 그리고 pstack 자체 가 gdb 를 이용 한 셸 스 크 립 트 입 니 다.
4. 파일 추가 디 버 깅:
하나의 단원 테스트 의 개념, 예 를 들 어 우리 가 어떤 알고리즘 을 써 서 하나의 함 수 를 실현 했다. 그것 의 정확성 을 검증 하기 위해 main 함수 에서 출력 을 구성 하고 출력 해 야 한다. 이런 추가 테스트 코드 는 바로 말뚝 테스트 이다. 또한 eclipse 에서 도 말뚝 테스트 를 할 수 있다. 클릭 하여 링크 를 열 수 있다.
5. 특수 응용 프로그램 테스트:
자신 이 socket 통신 을 쓰 는 클 라 이언 트 는 특정한 상황 에서 만 실 행 될 수 있 는 코드 를 테스트 합 니 다.

좋은 웹페이지 즐겨찾기