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]/***********
제가 사용하는 방법입니다.
-- 여기서부터.. 편집모드로 덧붙인 내용입니다. --
위 코드에서 사용된 xproc_sleep_milli() 함수는 밀리초 단위로 sleep하도록
nanosleep() 함수를 wrapping한 함수입니다.
s(˘∼˘*)z,·´″"`°³о$ √(´∀`√)... (˘ヘ˘ㆀ)a
댓글 달기