비정상 종료 될수가 있는건지요?
글쓴이: ningoi / 작성시간: 목, 2008/03/20 - 2:55오후
... pid_t nPid; if ((nPid = fork()) == 0) { write_log(&g_log,"Create Process : %s\n",cFullNameArray); if(strcmp(szVia,"") == 0 && strcmp(szMode,"") == 0 && strcmp(szLine, "") == 0) nRet = execl(szProcessName,szProcessName, (char *)0); else nRet = execl(szProcessName,szProcessName, szVia, szMode, szLine, (char *)0); if(nRet < 0) write_log(&g_log, "[ERR] %s Create Process Fail (%d)\n",cFullNameArray,errno); exit(1); } else if(nPid > 0) { } else { write_log(&g_log, "[ERR] Process Fork Error()!;\n"); } ...
운영체제는 솔라리스 입니다.
단순 미들웨어 형식으로 만들어보고 있는데요..
저렇게 해서
메인 프로세스 1개 , 자식 프로세스 7개 정도가 백그라운드로 떠서 데이터를 이전하고, 수정하는 역할을 하는건데요..
(메인 프로세스는 7개의 자식 프로세스들이 죽으면 다시 띄워줍니다.)
어느날 갑자기 비정상적인 종료가 이루어져서요....
아무리 생각해도 프로그램들이 죽일 이유가 없는데 죽었더군요.
시그널 처리는
signal(SIGINT,sig_int);
signal(SIGTERM,sig_term);
signal(SIGQUIT,sig_quit);
signal(SIGSEGV,sig_segv);
signal(SIGCHLD,sig_chld);
signal(SIGUSR1,sig_usr1);
이렇게 했는데요...
로그에 아무것도 남기지도 않고 죽었습니다.
이럴경우가 혹시 있나요? 전 아무리 생각해도 답이 안나와서 이렇게 질문을 띄웁니다.
Forums:
생성된 core 파일이
생성된 core 파일이 없나요? dbx 실행파일명 core 로 구동해서 stack 추적을 해보시기 바랍니다.
---------
간디가 말한 우리를 파괴시키는 7가지 요소
첫째, 노동 없는 부(富)/둘째, 양심 없는 쾌락
셋째, 인격 없는 지! 식/넷째, 윤리 없는 비지니스
이익추구를 위해서라면..
다섯째, 인성(人性)없는 과학
여섯째, 희생 없는 종교/일곱째, 신념 없는 정치
---------
간디가 말한 우리를 파괴시키는 7가지 요소
첫째, 노동 없는 부(富)/둘째, 양심 없는 쾌락
셋째, 인격 없는 지! 식/넷째, 윤리 없는 비지니스
이익추구를 위해서라면..
다섯째, 인성(人性)없는 과학
여섯째, 희생 없는 종교/일곱째, 신념 없는 정치
답변 감사합니다.
아쉽게도 core도 생성되지 않았습니다.
아래 코드에서 죽을
아래 코드에서 죽을 수는 있습니다.
szVia, szMode, szLine 들 중 하나라도 NULL이면 Seg fault 납니다.
(이미 앞에서 NULL 체크는 했을것으로 보입니다만)
헌데 seg signal을 설치한 관계로 core 만들어지지 않을 수도 있겠네요.
그렇다고 해도 fork() 이후라 부모 프로세스 까지 죽을 이유는 없을 것 같습니다.
역시나 core을 생성하게 한 다음(시그널 핸들러 설치를 몇개 주석 처리하세요) core 파일로
분석해 보세요.
---------
간디가 말한 우리를 파괴시키는 7가지 요소
첫째, 노동 없는 부(富)/둘째, 양심 없는 쾌락
셋째, 인격 없는 지! 식/넷째, 윤리 없는 비지니스
이익추구를 위해서라면..
다섯째, 인성(人性)없는 과학
여섯째, 희생 없는 종교/일곱째, 신념 없는 정치
---------
간디가 말한 우리를 파괴시키는 7가지 요소
첫째, 노동 없는 부(富)/둘째, 양심 없는 쾌락
셋째, 인격 없는 지! 식/넷째, 윤리 없는 비지니스
이익추구를 위해서라면..
다섯째, 인성(人性)없는 과학
여섯째, 희생 없는 종교/일곱째, 신념 없는 정치
댓글 달기