signal(SIGCHLD, sig_handler) 와 같이 했을때요...
글쓴이: unexpected / 작성시간: 수, 2003/09/03 - 6:38오후
리눅스에서 C 로 프로그램을 만드는데요...
부모 프로세서에 signal(SIGCHLD, sig_handler)로 자식 프로세서를 모니터 하는데요...동시에 40~50 개 정도의 자식 프로세서가 죽으면 5~6개가 sig_handler로 가질 못하는 경우가 발생을 합니다.
여러가질 테스트를 해봤는데....제가 보기엔 5~6개를 놓치는거 같은데요...^^;;
그래서 fork 시킨 부모 프로세서에서 주기적으로 waitpid 를 해서 좀비를 없애고 있는데요...
위와 같은 경우가 생길수가 있는건가요? ㅠ.ㅠ
죄다 잘 잡는 방법이 있다면 알려주심 감솨감솨하겠습니다요..꾸벅.
Forums:


시그날.
은 큐잉이 되질 않더 군요.
그래서 보통 다응과 같이 합니다. 저는..
Child 시그날은..
동시에 여러개가 발생할 수 있으므로..
위에 올리신 분처럼 시그날 핸들러에서 wait() 함수나 waitpid() 함수를 이용하여 현재 발생한 모든 이벤트를 처리해주고 나가야 할 것 같습니다.
제가 사용하는 방법입니다.[code:1]/***********
제가 사용하는 방법입니다.
/**************************************************************************************************** * Function Name: xproc_signal * * Argument List: nSignalNo[I] - * pfHandler[I] - SIG_DFL, SIG_IGN, handler * * Return Value: 0 if OK, -1 on error * * Description: signal 처리 함수 ****************************************************************************************************/ int xproc_signal(int nSignalNo, void (*pfHandler)(int)) { struct sigaction sSetAction, sGetAction; sSetAction.sa_handler = pfHandler; sigemptyset(&sSetAction.sa_mask); sSetAction.sa_flags = 0; /* for SunOS */ #ifdef SA_INTERRUPT sSetAction.sa_flags |= SA_INTERRUPT; #endif if(sigaction(nSignalNo, &sSetAction, &sGetAction) < 0) return -1; else return 0; } /**************************************************************************************************** * Function Name: xproc_zombie * * Argument List: none * * Return Value: 0 if OK, -1 on error * * Description: child process가 zombie process로 전환되는 것을 방지한다. ****************************************************************************************************/ static void xproc_zombie_handler(int nSignalNumber) { while(waitpid(-1, NULL, WNOHANG) > 0) xproc_sleep_milli(10); } int xproc_zombie(void) { #ifdef SIGCLD if(xproc_signal(SIGCLD, xproc_zombie_handler) < 0) return -1; #endif #ifdef SIGCHLD if(xproc_signal(SIGCHLD, xproc_zombie_handler) < 0) return -1; #endif return 0; }-- 여기서부터.. 편집모드로 덧붙인 내용입니다. --
위 코드에서 사용된 xproc_sleep_milli() 함수는 밀리초 단위로 sleep하도록
nanosleep() 함수를 wrapping한 함수입니다.
/**************************************************************************************************** * Function Name: xproc_sleep_milli * * Argument List: nMilliSecond[I] * * Return Value: none * * Description: 주어진 시간(1/1000초)동안 process의 수행을 멈춘다. ****************************************************************************************************/ void xproc_sleep_milli(unsigned long nMilliSecond) { struct timespec sTimeSpec; sTimeSpec.tv_sec = nMilliSecond / 1000; sTimeSpec.tv_nsec = (nMilliSecond % 1000) * 1000000; nanosleep(&sTimeSpec, NULL); }s(˘∼˘*)z,·´″"`°³о$ √(´∀`√)... (˘ヘ˘ㆀ)a
댓글 달기