[완료] 소켓의 소유권 상속 금지 방법?
글쓴이: 철이^^v / 작성시간: 금, 2008/08/22 - 4:09오후
안녕하세요.
어떤 프로세스에서 서버 소켓을 만들고 난뒤 자식 프로세스를 만들었습니다.
그리고 부모 프로세스만 먼저 실행을 종료한 경우에, 살아있는 자식 프로세스가 서버 소켓에 대한 소유권을 가지게 되던데요,
이를 금지할수 있는 방법이 없을까요?
#include <stdio.h> #include <errno.h> #include <stdlib.h> #include <string.h> #include <sys/types.h> #include <unistd.h> #include <sys/socket.h> #include <arpa/inet.h> #include <fcntl.h> int create_dummy_socket(int port) { int status, sockfd; struct sockaddr_in servaddr; int iOptVal; if ((sockfd = socket(PF_INET, SOCK_DGRAM, 0)) < 0) { return -1; } memset(&servaddr, 0, sizeof(servaddr)); servaddr.sin_family = AF_INET; servaddr.sin_port = htons(port); servaddr.sin_addr.s_addr = INADDR_ANY; if ((status = bind(sockfd, (struct sockaddr*)&servaddr, sizeof(servaddr))) != 0) { perror("socket binding error! "); return -1; } } int main(int argc, char *argv[]) { if (create_dummy_socket(8888) < 0) { exit(0); } system("sh"); }
이 프로그램을 컴파일해서 수행시킨후에 "netstat -lnp | grep :8888" 을 해보면, 처음에는 부모 프로세스가 해당 소켓을 open 한것으로 나옵니다.
그 뒤에 해당 부모 프로세스만 죽여버리고 다시 "netstat" 으로 확인해 보면, 자식 프로세스인 "sh" 가 해당 소켓의 권한을
상속하고 있습니다. 자식 프로세스까지 죽여야 해당 소켓이 release 되는데요, 부모 프로세스가 죽을때 소켓도 같이 release 되게 할수 있는 방법이 없을까요?
Forums:
http://udrepper.livejournal.c
http://udrepper.livejournal.com/20407.html
그런데 2.6.27부터 된다는군요.
전통적으로는 새로 fork하고 나서 0, 1, 2를 제외한 모든 fd를 걍 닫아버리도록하는 방법을 많이씁니다.
----
데스크탑 프로그래머를 꿈꾸는 임베디드 삽질러
----
데스크탑 프로그래머를 꿈꾸는 임베디드 삽질러
fork()하고 execxxx()
fork()하고 execxxx() 하기전에 불필요한 파일디스크립터들은 닫아(close) 주세요.
아하.. 그렇담 몇번 fd까지 닫아야 하는지 어떻게 알수있나요?
ganadist 님이 알려주신 방법은 커널 버젼관계로 좀 힘들것 같네요... (2.6.18 이라 ^^;)
자신이 생성한 모든 서버소켓을 다 닫으려면 그 목록을 알아야 할것 같은데요.
(관리 안한 잘못이 있긴 하지만 -.-a)
혹시, 현재 open 된 디스크립터 목록이라던지 최대값을 다른 방법으로 얻어오는 방법이 있나요?
아니면, 그냥 3번부터 파일 디스크립터 최대값까지 for loop 를 돌면서 close() 를 호출하나요?
멋진 방법을 알고 계시다면 부탁드립니다.
sysconf 이나 getrlimit로
sysconf 이나 getrlimit로 최대값을 얻을 수 있습니다.
----
데스크탑 프로그래머를 꿈꾸는 임베디드 삽질러
----
데스크탑 프로그래머를 꿈꾸는 임베디드 삽질러
오~ 감사합니다
덕분에 좋은 함수들 몇가지를 새로 배우게 되었네요.
막연히 '/proc//fd 를 뒤지면 되는건가?' 라고 생각중이였는데 말이죠.
답변 주신 여러분들 모두 감사드립니다.
댓글 달기