오라클 lib 'clntsh'를 링크하였을때 alarm()이 안되는 이유?
글쓴이: ssanighe / 작성시간: 수, 2006/08/02 - 2:15오후
소스코드에 아래와 같이 alarm을 설정하였는데
signal이 발생되어도 handler가 호출되지 않습니다.
이것 저것 해보다가 compile시 link option 중에 -lclntsh를 삭제해 주니깐,
alarm이 잘 처리가 되네요.
clntsh가 뭘 하는 lib인지도 잘 모르겠고, 왜 이런 현상이 이러나는지도 감이 안잡힙니다.
도와주세요-
signal(SIGALRM, sig_alarm_handler); alarm(5); for(i=0;i<30;i++) { printf("%d\n", i); sleep(1); }
Forums:
추측컨데
alarm이라는 이름에 함수가 libclntsh.a에 redefine 되어있는것 같습니다.
system 함수인 alarm의 이름을 바꿔 줄 수는 없고, clntsh도 oracle lib 라서 함수명 변경이 불가능 하네요.
1. alarm이라는 함수가 libclntsh.a에 선언되었다고 확인할 수 있는 방법이 있나요?
2. 이럴땐 어떻게 해야하죠-_ㅠ
간단한 답변입니다.
1. nm -a libclntsh.a | grep alarm
libclntsh.a를 dynamic loading하신걸로 봐서 웬지 AIX일것같다는 생각이 듭니다만 그럴때는
dump -HTv libclntsh.a
2. 일단 간단히는 strace/truss같은 시스템콜추적기를 이용하여 프로세스를 수행한 다음에
kill -s ALRM 를 날려서 실제로 alarm signal에 대한 루틴이 수행되는지 확인하는것부터 시작할것같은데요.
homeless
감사합니다.
여러모로 정말 많은 도움이 되었습니다.
sleep()이 시그널을 잡아먹더군요.
ㅠ_ㅠ
tusc, nm 너무 유용하네요.
왜 이런걸 몰랐을까요.
왜 libclntsh.a 를 link할때만, sleep이 SIG_ALRM을 잡아먹는지는 더 알아봐야 겠지만,
머 sleep()과 alarm() 같이 안쓴다면, 머 문제는 해결된 셈입니다.
감사합니다!
헉... 쓰고보니... ㅡ.ㅡ;;
sleep은 원래 SIGALRM과 같이 사용하면 안됩니다.
POSIX1b에서 정의하는 nanosleep외의 어떠한 종류의 sleep(usleep포함)도 시그널로부터 안전하지않습니다.
homeless
덧붙여...
연속해서 3개나 답글을 달게 되는군요 :-)
libclntsh는 오라클 클라이언트 라이브러리입니다. 님께서 작업하시는 소스가 oracle db에 접속해서 뭔가 하는 거라면 꼭 필요한거죠.
homeless
댓글 달기