파일 포인터를 못 가져와요 ㅠ.ㅠ
SUN 환경에서 Unix C로 프로그래밍을 하고 있습니다.
통상 사용하는 fopen에서 문제가 발생해 속을 썩이네요 ;;
다음과 같이 사용하고 있습니다.
====================================================
FILE *fpAA;
if((fpAA = fopen("aa.txt","a+")) == NULL)
{
printf(" error no : %d ", errno);
}
printf(" open fd : %d ", fpAA);
...
fprintf(~~~)
...
if(fpAA != NULL){
fprintf(fpAA, "\n");
fflush(fpAA);
printf(" close fd : %d ", fpAA);
fclose(fpAA);
}
====================================================
이러한 소스를 계속적으로 반복합니다.
(데이터가 수신되면 호출 되어 저장하는 방식입니다.)
그런데 문제는...
20분간 정상적으로 파일 잘 열어서 쓰다가...
20분이 조금 지나면
파일 포인터를 못 가져온다는 errno 35를 찍어버리고는
그 이후로는 계속 errno 35를 찍으면서 저장을 못 하는 상황이 발생합니다.
위의 printf 문에서처럼 fd를 잘 가져오고 닫는지 검사해밨는데
에러 나기 직전까지 동일한 fd를 열고 닫고 하더라구요...
errno 35는 ENOMSG라는 에러던데...
무슨 문제가 발생한 걸까요...ㅠ.ㅠ
혹...
한 Process 당 열수 있는 file 수가 어떻게 설정되어 있는지 알 수 있을까요?
감사합니다.
파일을 사용하고 flose로 닫아 주는데도 프로세스당 열 수 있는 fd의 갯수가 중요한가요?
실제 printf로 찍어본 바로는 에러가 나기 전까지는 동일한 fd 값을 열고 닫고 하더라구요...
기본 설정에서 수정한게 없으니 dafault 값인 256으로 추정됩니다...
fd가 제한이 있다면 20분의 시간동안 정상적으로 종료되지 않은 fd값이 누적되어 에러가 발생할 수 있다고 추측할 수 있지만, 근본적인 해결책은 되지 않는것 같아서 다른 원인을 찾아보고 있습니다.
제시해준 방법도 간과하지 않고 열시미 삽질 해 보겠습니다 ^^
의견 감사드립니다~
죄송합니다..
본문을 자세히 보지 못했습니다...
순간 쓰레드를 사용하지 않나 싶어서.. 그런 생각을 하게 되었습니다..
도움이 되지 못해 죄송합니다...
혹시나 해서 답글 남깁니다.
혹시 데이터를 받아오는 부분에 msgrcv를 쓰셨다면 가장 마지막 인자(msgflg)에 IP_NOWAIT 옵션을 주지 않고 호출해 보시기 바랍니다.
오타났군요. orz
IP_NOWAIT가 아니라 IPC_NOWAIT입니다.
넵..
errno 35(ENOMSG)로 나는걸로 보아
메시지 수신쪽에 문제가 있는것 같았습니다...
삽질하고 결과 알려드리겠습니다 ^^
감사합니다~
댓글 달기