signal(SIGCHLD, sig_handler) 와 같이 했을때요...

0
points

리눅스에서 C 로 프로그램을 만드는데요...
부모 프로세서에 signal(SIGCHLD, sig_handler)로 자식 프로세서를 모니터 하는데요...동시에 40~50 개 정도의 자식 프로세서가 죽으면 5~6개가 sig_handler로 가질 못하는 경우가 발생을 합니다.

여러가질 테스트를 해봤는데....제가 보기엔 5~6개를 놓치는거 같은데요...^^;;

그래서 fork 시킨 부모 프로세서에서 주기적으로 waitpid 를 해서 좀비를 없애고 있는데요...

위와 같은 경우가 생길수가 있는건가요? ㅠ.ㅠ

죄다 잘 잡는 방법이 있다면 알려주심 감솨감솨하겠습니다요..꾸벅.

시그날.

0
points

은 큐잉이 되질 않더 군요.

그래서 보통 다응과 같이 합니다. 저는..

while (wait (NULL) > 0) ;

Child 시그날은..

0
points

동시에 여러개가 발생할 수 있으므로..

위에 올리신 분처럼 시그날 핸들러에서 wait() 함수나 waitpid() 함수를 이용하여 현재 발생한 모든 이벤트를 처리해주고 나가야 할 것 같습니다.

제가 사용하는 방법입니다.[code:1]/***********

0
points

제가 사용하는 방법입니다.

/****************************************************************************************************
 * 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);
}

댓글 보기 옵션

원하시는 댓글 전시 방법을 선택한 다음 "설정 저장"을 누르셔서 적용하십시오.