Chinaunix首页 | 论坛 | 博客
  • 博客访问: 523792
  • 博文数量: 118
  • 博客积分: 10028
  • 博客等级: 上将
  • 技术积分: 1820
  • 用 户 组: 普通用户
  • 注册时间: 2007-11-07 18:46
文章分类

全部博文(118)

文章存档

2009年(12)

2008年(106)

我的朋友

分类: C/C++

2008-05-23 22:41:09

 
   (标题似乎优点语无伦次,确实不知道怎么用几个字说清楚,看下面的吧!!)
============================================================

负一. 分别讨论在两个进程与两个线程之间同时调用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). 端口扫描程序可以用多进程来实现更快的扫描




阅读(1129) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~