[질문] 시그널발생시 실행되는 프로그램 죽는현상..
void sig_handler(int signo); void *thread_func(void *data); int main() { ... ... ... ... 데몬화 시키는 작업 signal(SIGUSR1, (void *)sig_handler); while(1) pause(); // or sleep(2); return 0; } void sig_handler(int signo) { ... ... thread_id = pthread_create(&p_thread, NULL, thread_func, NULL); if ( thread_id < 0 ) LogFile(...); pthread_detach(p_thread); } void *thread_func(void *data) { ... ... ... pthread_exit(0); }
위 코드는 대략적인 코드입니다.
이 프로그램은 데몬으로 대기하고 있다가 어떠한 프로그램이 시그널을 보내게 되면
스레드를 생성하게되고 스레드에서 처리를 하는 작업을 하게 됩니다.
그런데 이 프로그램에 이상한 문제가 있습니다.
정상적으로 동작을 하는데 어느순간 메모리 점유율이 0으로 떨어지면서 죽습니다.
while [ 1 ] ; do ps -aux | grep KillSession | grep -v vi | grep -v grep ; sleep 1 ; done
root 18517 0.0 0.0 34620 472 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 472 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 472 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 100 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 104 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 104 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 104 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 100 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 104 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 104 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 44 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 44 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 44 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 44 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 0 ? SW 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 4 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 0 ? SW 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 4 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 4 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 4 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 0 ? SW 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 4 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 4 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 4 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 0 ? SW 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 4 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 4 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 0 ? SW 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 4 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 0 ? SW 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 4 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 4 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 4 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 0 ? SW 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 0 ? SW 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 4 ? S 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 0 ? SW 17:16 0:01 ./KillSession
root 18517 0.0 0.0 34620 0 ? SW 17:16 0:01 ./KillSession
대략 프로그램을 실행시키고 1시간 ~ 2시간 정도가 되면 저런 현상이 발생하는거 같습니다.
이현상이 왜일어나는지 조언 부탁드리겠습니다..
댓글 달기