[질문] 데몬프로그램 이상 현상입니다. 조언좀 부탁드립니다.
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); }
위 코드는 대략적인 코드입니다.
이 프로그램은 데몬으로 대기하고 있다가 어떠한 프로그램이 시그널을 보내게 되면
스레드를 생성하게되고 스레드에서 처리를 하는 작업을 하게 됩니다.
그런데 이 프로그램에 이상한 문제가 있습니다.
어느정도 시간이 지난후에 메모리 점유율이 4와 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시간 정도가 되면 저런 현상이 발생합니다.
이현상이 왜일어나는지 조언 부탁드리겠습니다..
댓글 달기