Prayer

在一般中寻求卓越
posts - 1256, comments - 190, trackbacks - 0, articles - 0
  C++博客 :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理

socket返回值递增之线程与进程的讨论

Posted on 2009-01-21 16:17 Prayer 阅读(599) 评论(0)  编辑 收藏 引用 所属分类: SOCKET
   (标题似乎优点语无伦次,确实不知道怎么用几个字说清楚,看下面的吧!!)
============================================================

负一. 分别讨论在两个进程与两个线程之间同时调用socket时,返回值fd的递增方式


零. 为什么讨论这个问题?
    现在正在写一个端口扫描程序,需要用到非阻塞connect,由于系统提供的select最大描述字个数为1024(Linux是这么多,其他系统使用输出FD_SETSIZE得到),012号描述字给了标准输入输出错误流,所以fd从3开始递增。为了实现更快的端口扫描,必须同时打开几千个描述字,又由于有个1024的问题,所以必须使用多线程或者多进程来实现。这里要讨论的是在线程或进程中能各自不影响的递增吗?

一. 不同进程之间同时调用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下执行,会在两个SHELL得到各自的结果
      (3)结果
          两个SHELL上得到了相同的结果,也就是说,fd的值都是从3开始递增的(而不是交叉),如下:
(由于两个结果相同,只列出一个)

zuii@william-desktop:~/c/hack$ ./fdnum
fd=3
fd=4
fd=5
fd=6
fd=7
fd=8
fd=9


      (4)测试结论
          在不同进程之间同时调用socket返回值各自不影响,所以端口扫描程序可以使用多进程实现加快速度!

二.同一进程的不同线程之间同时调用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)结果

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)测试结论
          很显然,输出结果是相互影响的,所以端口扫描不能用多线程来实现!

三.结论
      (1). 不同进程打开描述字互不影响
      (2). 同一进程中不同线程打开描述字相互影响
      (3). 端口扫描程序可以用多进程来实现更快的扫描


只有注册用户登录后才能发表评论。
【推荐】超50万行VC++源码: 大型组态工控、电力仿真CAD与GIS源码库
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理