cgi 질문입니다.. (오라클 연관)
페도라코어3에 오라클10g를 설치하여 사용하고 있습니다.
기말 과제 때문에 proc와 qDecoder로 cgi 프로그래밍을 해야 하는데요..
마지막에 gcc로 컴파일할 때 -lclntsh 명령만 주면 500 인터널 서버 에러가 발생해 버립니다.
원인을 추적하다가 간단한 예제를 만들어봤는데요
#include "qDecoder.h"
int main(){
qContentType("html/text");
printf("hi");
return 0;
}
이런 간단한 프로그램 만들어서 컴파일을 하는데요,,
gcc -I/usr/local/include -o test.cgi test.c /usr/local/lib/libqDecoder.a
이렇게 하면 에러 안 뜨고 브라우저에서도 hi라고 뜹니다.
그런데
gcc -I/usr/local/include -L($ORACLE_HOME)/lib -lclntsh -o test.cgi test.c /usr/local/lib/libqDecoder.a
이렇게 lclntsh 옵션만 들어가면 여지없이 500 인터널 서버가 뜹니다. 컴파일 에러도 없고 쉘에서 실행해도 에러 없습니다..
lclntsh 옵션 말구, lm 같은 옵션은 넣어도 아무 이상 없이 잘 돌아갑니다.
그래서 에러 로그를 추적해 봤습니다.
처음에는
[Thu Dec 07 01:14:55 2006] [error] [client 127.0.0.1] /var/www/html/project/select.cgi: error while loading shared libraries: libclntsh.so.10.1: cannot open shared object file: No such file or directory
이렇게 뜨길래, 아 라이브러리 패스를 못 찾는가보다 하고 오라클 lib 디렉토리에서 libclntsh.so.10.1 파일을 /usr/lib 디렉토리로 복사하고 퍼미션도 아예 777로 줘버렸습니다.
그리고 나서 다시 실행하니 여전히 에러고 뜨는데 이번에는
[Thu Dec 07 01:17:39 2006] [error] [client 127.0.0.1] /var/www/html/project/select.cgi: error while loading shared libraries: libclntsh.so.10.1: failed to map segment from shared object: Permission denied
이렇게 뜹니다.. 분명히 퍼미션을 777로 줬는데 말이죠.. ㅜㅜ
그리고 premature end of script header라고도 에러 로그가 뜨는데, 앞에서 그냥 컴파일했을땐 잘 되는 걸로 봐서는 위에 libclntsh문제가 확실한 듯 합니다.
이거 때문에 환장할 지경입니다.
과제하려면 다른 라이브러리 함수 써야 해서 -lclntsh 옵션을 꼭 줘야 하거든요..
ld.so.conf 파일이라든지, LD_LIBRARY_PATH 설정 같은건 다 해줬습니다..
고수님들의 도움 부탁드리겠습니다. ㅜㅜ
전 잘돌아가는데..
전 잘돌아가는데...
아마 환경변수 문제일겁니다.
아파치 conf 셋팅 합니다.
SetEnv ORACLE_HOME /backup/oracle/product/9.0.1
등등등..
..................
----------------------------------------------------------------------------
댓글 달기