/etc/inittab에 프로세스를 등록했는데 기동을 하지 않습니다..
글쓴이: 낙엽 / 작성시간: 금, 2004/05/21 - 11:37오후
유저 프로세스를 /etc/inittab에 등록을 해두었고,
SA:23:respawn:/home/bugyo/test/test arg1 arg2
init q 한 뒤에 프로세스가 기동하는지 보았습니다.
프로세스는 스레드를 4개 가지고 있고, tcp connection을 대기중에 있다가 커넥션이 왔을 때, 요구하는 작업을 해주는 일을 합니다.
inittab에 등록하지 않고 동작시에는 잘 동작합니다만,.. inittab에 등록해서 이 프로세스가 죽었을 시에 다시 재기동 시켜주려 했습니다만.. 잘 안되는군요.
이 프로세스는 DB에 커넥트하지도 않습니다.
inittab에 등록했다가 respawn을 off로 바꾸고 init q하고
다시 inittab에서 off를 respawn으로 수정하고 다시 init q 를 몇번을 시도해 보았지만 기동이 되지 않더군요.
혹시 제가 모르는 다른 절차를 밟아야 하는건가요?
Forums:
첨부해서..
위 프로세스에서는 스레드 외에도 signal을 등록해서 사용하며,
shared memory, pipe 등을 모두 사용합니다.
혹시 inittab에 등록하는데 제약사항이 있나해서 소소한 내용도 올려봅니다..
ps> 테스트 파일로 위 프로세스와 같은 형식으로 스레드를 몇개 생성해서 돌려보니 그건 inittab에서 동작하더군요.. shared memory, signal, pipe, 소켓 등을 사용하는것이 inittab에서 동작하는데 제약이 있는건가요?
원인은 발견했습니다만..
원인은 dump를 떠서 확인했습니다.
이 프로그램에서 어떤 library를 포함해서 컴파일을 하는데요.. 그 library를 찾을 수 없다는 메시지가 나옵니다.
inittab에서 > dumpmsg 로 떠서 확인한 메시지 입니다.
ld.so.1: /home/bugyo/test: fatal: libFt.so: open failed: No such file or directory
libFt.so 는 이 프로그램에서 사용하는 라이브러리구요.. Makefile에 포함시켜서 컴파일 되었습니다. 혹시 이것을 libFt.a 파일을 포함시켜서 컴파일 해야 할런지?
libFt.a 를 넣어서 컴파일 했는데도 안되는군요.. -_- 도대체 뭐
libFt.a 를 넣어서 컴파일 했는데도 안되는군요.. -_- 도대체 뭐가 문제인지..
환경변수....
LD_LIBRARY_PATH 등의 환경 변수가 설정되지 않아서 그런거 같네요....
inittab에 의해서 실행되는 데몬은 계정이 root이고 아마도 PATH, LD_LIBRARY_PATH 등이 설정되어 있지 않을 겁니다.
대부분은 필요한 환경변수를 export 하고, 데몬을 실행하는 스크립트를 작성하여 inittab에 등록합니다.
좀더 쉽게 하는 방법도 있죠....
만약 해당 데몬이 꼭 root 계정에서 실행되야 하는게 아니고, 특정 사용자 계정의 쉘에서는 문제없이 동작한다는 가정을 하면 다음과 같이 inittab에 등록하면 될겁니다.
SA:23:respawn:su - user_account -c "/home/bugyo/test/test arg1 arg2"
위와 같이 하면 user_account 계정으로 로그인한후 test 라는 프로그램을 실행합니다.
세상은 하나..........
root로 실행하는데, root environment 에도 LD_LIBR
root로 실행하는데, root environment 에도 LD_LIBRARY_PATH 등.. 필요한 환경변수들은 이미 다 정의해 두었습니다.. 혹시 몰라서 소스상에서도 getenv로 확인해서 없으면 다시 재정의 하고있구요..
root 계정이 아닌 개발계정으로 동작시켜도 마찬가지 입니다.. 이거 미치겠군요.. 어제 새벽부터 지금까지 -_-;;;
메시지를 먼저 확인해보시기 바랍니다.
우선 root 유저로 들어가서 확인해보시고, 실행이 되는지 확인해보세요.
그리고 ldd 로 어떤 라이브러리를 링크하는지 정확하게 확인하고
그 위치에 해당 라이브러리가 똑같이 있는지 버전까지 확인해보세요.
PS) 그런데 머신은 리눅스인가요? 만일 솔라리스 64비트라면 라이브러리 위치를 LD_LIBRARY_PATH_64 에서 검색해서 사용하므로 환경이 조금 다릅니다.
========================================
* The truth will set you free.
댓글 달기