Posted on 2009-01-21 16:17
Prayer 閱讀(702)
評論(0) 編輯 收藏 引用 所屬分類:
SOCKET
(標題似乎優(yōu)點語無倫次,確實不知道怎么用幾個字說清楚,看下面的吧??!)
============================================================
負一. 分別討論在兩個進程與兩個線程之間同時調(diào)用socket時,返回值fd的遞增方式零. 為什么討論這個問題? 現(xiàn)在正在寫一個端口掃描程序,需要用到非阻塞connect,由于系統(tǒng)提供的select最大描述字個數(shù)為1024(Linux是這么多,其他系統(tǒng)使用輸出FD_SETSIZE得到),012號描述字給了標準輸入輸出錯誤流,所以fd從3開始遞增。為了實現(xiàn)更快的端口掃描,必須同時打開幾千個描述字,又由于有個1024的問題,所以必須使用多線程或者多進程來實現(xiàn)。這里要討論的是在線程或進程中能各自不影響的遞增嗎?
一. 不同進程之間同時調(diào)用socket (1)測試代碼如下:
/* Running in 2 different shell,(catch the same result) */ #include <stdio.h> #include <stdlib.h> #include <sys/types.h> #include <sys/socket.h>
#define MAXNUM 10
int main(int argc,char **argv) { int fd[MAXNUM]; int i; for(i=3;i<MAXNUM;i++) { if((fd[i]=socket(AF_INET,SOCK_STREAM,0))==-1) { printf("Socket %d error!\n",i); exit(-1); } printf("fd=%d \n",fd[i]); sleep(1); } return 0; }
|
(2)測試方法
編譯好后,分別同時在兩個SHELL下執(zhí)行,會在兩個SHELL得到各自的結(jié)果
(3)結(jié)果
兩個SHELL上得到了相同的結(jié)果,也就是說,fd的值都是從3開始遞增的(而不是交叉),如下:
(由于兩個結(jié)果相同,只列出一個)
zuii@william-desktop:~/c/hack$ ./fdnum fd=3 fd=4 fd=5 fd=6 fd=7 fd=8 fd=9
|
(4)測試結(jié)論
在不同進程之間同時調(diào)用socket返回值各自不影響,所以端口掃描程序可以使用多進程實現(xiàn)加快速度!
二.同一進程的不同線程之間同時調(diào)用socket (1)測試代碼如下:
/* Use 2 thread */ #include <stdio.h> #include <stdlib.h> #include <sys/types.h> #include <sys/socket.h> #include <pthread.h>
#define MAXNUM 10
void *sub_thread() { int fdd[MAXNUM],i; for(i=3;i<MAXNUM;i++) { if((fdd[i]=socket(AF_INET,SOCK_STREAM,0))==-1) { printf("Socket %d error!\n",i); exit(-1); } printf("fdd=%d \n",fdd[i]); sleep(1); }
} int main(int argc,char **argv) { int fd[MAXNUM]; int i,res; pthread_t threadid; void *ExitResult;
if((res=pthread_create(&threadid,NULL,sub_thread,NULL))!=0) { perror("Thread creation failed"); exit(-1); } for(i=3;i<MAXNUM;i++) { if((fd[i]=socket(AF_INET,SOCK_STREAM,0))==-1) { printf("Socket %d error!\n",i); exit(-1); } printf("fd=%d \n",fd[i]); sleep(1); } if((res=pthread_join(threadid,&ExitResult))!=0) { perror("Thread join failed"); exit(-1); } return 0; }
|
(2)編譯,運行(一個進程)
(3)結(jié)果
zuii@william-desktop:~/c/hack$ ./fdnum2 fdd=3 fd=4 fdd=5 fd=6 fdd=7 fd=8 fdd=9 fd=10 fdd=11 fd=12 fdd=13 fd=14 fdd=15 fd=16
|
(4)測試結(jié)論
很顯然,輸出結(jié)果是相互影響的,所以端口掃描不能用多線程來實現(xiàn)!
三.結(jié)論
(1). 不同進程打開描述字互不影響
(2). 同一進程中不同線程打開描述字相互影響
(3). 端口掃描程序可以用多進程來實現(xiàn)更快的掃描