메뉴 건너뛰기

리눅스 관련 모음

본문시작

조회 수 38184 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

국산 통나무 수공예 남원제기, 남원목기

자료가 도움이 되셨다면
혼수용품제수용품 필요시
남원제기 공식 홈페이지 http://남원제기.kr
남원목기 공식 홈페이지 http://otchil.kr
에서 구매 해 주세요
정성껏 모시겠습니다.
 

아파치 프로세스가 가끔씩 또는 자주 error log에 segmentation fault 메세지를 남기면서 죽는 경우는 보통 아파치 모듈에 에러가 있는 경우입니다.
보통 아파치는 여러 개의 모듈이 로딩되고 모듈 자체에서 다시 외부 모듈을 호출하는 경우도 있기 때문에 디버깅을 하기가 쉽지 않습니다.

아파치 프로세스가 죽으면서 error log에 아래와 같은 메세지를 남깁니다.
[Thu Jul 03 16:41:43 2008] [notice] child pid 26827 exit signal Segmentation fault (11)

core 파일 생성을 위해서 httpd.conf 에 아래 내용을 추가합니다.
CoreDumpDirectory /tmp # core 파일을 /tmp에 생성

이제 아파치 프로세스가 죽게되면 error log 메세지가 아래와 같이 바뀌고 /tmp 디렉토리에 core 파일이 생성됩니다.
[Thu Jul 03 17:09:05 2008] [notice] child pid 27723 exit signal Segmentation fault (11), possible coredump in /tmp

만약 core 파일이 생성되지 않을 경우에는 아파치 데몬 소유자의 core limit을 변경해 줍니다. (bash shell에서)
ulimit -c unlimited

이제 gdb를 실행합니다.
gdb /usr/local/httpd/bin/httpd /tmp/core

관련된 파일이 로딩되고 나면, back trace로 어디서 문제가 생겼는지 확인합니다.
(gdb) bt
#0  0x4019f6bf in chunk_free (ar_ptr=0x402537a0, p=0xffffffec) at malloc.c:3226
#1  0x4019f424 in __libc_free (mem=0x82320e4) at malloc.c:3155
#2  0x406b00c3 in zif_zend_aescryptstring () from /usr/local/libexec/api/libaesapi.so
#3  0x405947b3 in execute (op_array=0x825df24)
    at /usr/local/libexec/wwwsrc/php-4.4.4/Zend/zend_execute.c:1675
#4  0x40594957 in execute (op_array=0x825ddd4)
    at /usr/local/libexec/wwwsrc/php-4.4.4/Zend/zend_execute.c:1719
#5  0x40594957 in execute (op_array=0x825da0c)
    at /usr/local/libexec/wwwsrc/php-4.4.4/Zend/zend_execute.c:1719
...

여기서는 zend_aescryptstring 가 php 확장 모듈이기 때문에 3번 프레임의 내용을 확인합니다.

(gdb) frame 3
#3  0x405947b3 in execute (op_array=0x825df24)
    at /usr/local/libexec/wwwsrc/php-4.4.4/Zend/zend_execute.c:1675
1675    /usr/local/libexec/wwwsrc/php-4.4.4/Zend/zend_execute.c: No such file or directory.
        in /usr/local/libexec/wwwsrc/php-4.4.4/Zend/zend_execute.c
(gdb) print (char *)executor_globals.active_op_array->filename (해당 모듈을 호출한 php 파일을 출력합니다.)
$1 = 0x8252e8c "/usr/local/mainwww/webII/lib/class.CryptCookie2.php"
(gdb) print (char *)executor_globals.active_op_array->function_name
$2 = 0x8259c5c "_decrypt" (php 파일 내에서 모듈을 호출한 함수 이름)
(gdb) print (char *)(executor_globals.function_state_ptr->function)->common.function_name
$3 = 0x406b04c0 "zend_aescryptstring" (php 모듈의 함수 이름)

이제 문제가 된 zend_aescryptstring 함수를 찾아서 디버깅하면 됩니다 ^^


참고 자료:
http://bugs.php.net/bugs-generating-backtrace.php
http://httpd.apache.org/dev/debugging.html

   

  1. Sendmail 스패머 IP 차단 쉘스크립트 v2

    Date2012.12.06 By햇빛소년 Views20108
    Read More
  2. sendmail + dovecot 설정

    Date2011.05.11 By햇빛소년 Views42414
    Read More
  3. SELinux/audit2allow

    Date2012.06.11 By햇빛소년 Views33239
    Read More
  4. selinux 퍼미션 에러 audit2allow 로 쉽게 ....

    Date2014.02.28 Category에러해결 By햇빛소년 Views3470
    Read More
  5. selinux 관련 명령모음.

    Date2012.06.07 By햇빛소년 Views36271
    Read More
  6. SELinux Lockdown Part One: SELinux Users

    Date2012.06.07 By햇빛소년 Views35101
    Read More
  7. selinux troubleshooting 해결 명령

    Date2016.02.28 Category에러해결 By햇빛소년 Views797
    Read More
  8. segmentation fault가 발생할 때 디버깅 방법

    Date2012.01.05 By햇빛소년 Views38184
    Read More
  9. rsync 백업 설정이 확실하게 되었는데도 백업이 되지 않는 다면.....

    Date2013.06.30 Category에러해결 By햇빛소년 Views15930
    Read More
  10. rsync 를 이용한 원격 서버 백업하기.

    Date2013.07.01 Category에러해결 By햇빛소년 Views15571
    Read More
  11. rpm 파일 삭제시 에러 - specifies multiple packages 해결방법

    Date2012.06.20 By햇빛소년 Views27734
    Read More
  12. route 및 iptables를 이용한 리눅스 특정 IP 접속 차단하는 법

    Date2016.06.14 Category설정 및 사용법 By햇빛소년 Views2483
    Read More
  13. rndc: connection to remote host closed 네임서버오류

    Date2011.04.10 By햇빛소년 Views55311
    Read More
  14. rndc-confgen — rndc key generation tool

    Date2013.05.31 Category설치관련 By햇빛소년 Views17372
    Read More
  15. RHEL 7 / CentOS 7 : Disable Firewalld and use iptables

    Date2016.02.15 CategoryCentOS 7 By햇빛소년 Views1082
    Read More
  16. rewrite 도메인 포워딩

    Date2013.06.22 Category설치관련 By햇빛소년 Views15155
    Read More
  17. redis 2.8.19 설치하기

    Date2015.02.27 Category설치관련 By햇빛소년 Views1584
    Read More
  18. Red Hat / CentOS IPv6 Network Configuration

    Date2012.05.30 By햇빛소년 Views28092
    Read More
  19. pyzor: check failed: internal error, python traceback seen in response 드디어 해결

    Date2012.06.20 By햇빛소년 Views28387
    Read More
  20. procmail: Lock failure on "spamassassin.lock"

    Date2012.06.16 By햇빛소년 Views27019
    Read More
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 Next
/ 10