Linux C 网络编程——5. 并发服务器

来源:互联网 发布:mac版yy显示进频道失败 编辑:程序博客网 时间:2024/04/29 20:06

1. 原理

Linux C 网络编程——4. 简单TCP Socket程序中实现了一个最基本的基于TCP的CS通信,

这里介绍一种可以允许Server端可以同时处理多个请求(并发服务器)。

原理:每次accept服务器调用fork(),创建一个子进程处理请求。


2. 实现

只需要修改上一篇文章中的Server.c的while循环即可

[cpp] view plaincopy
  1. while(1)  
  2. {  
  3.     addr_len = sizeof( caddr );    
  4.     connfd = accept( listenfd, (struct sockaddr*)&caddr, &addr_len );   
  5.       
  6.     n = fork();  
  7.       
  8.     if( n == -1 )  
  9.     {  
  10.         perror("call to fork");  
  11.         exit(1);  
  12.     }  
  13.     else if( n == 0 )  //child process   
  14.     {  
  15.         close( listenfd );  
  16.           
  17.         while(1)  
  18.         {  
  19.             n = recv( listenfd, buf, 100, 0  );    
  20.                 
  21.             printf("Recive from %s : %d \n",  inet_ntop( AF_INET, &caddr.sin_addr, str, sizeof(str) ), ntohs(caddr.sin_port) );    
  22.         
  23.             for(i=0; i<n; i++)    
  24.             {    
  25.                 buf[i] = toupper( buf[i] );    
  26.             }    
  27.         
  28.             //write( connfd, buf, n+1 );    
  29.             send( connfd, buf, n+1, 0 );    
  30.                 
  31.             printf("Send : %s \n", buf);    
  32.             close( connfd );    
  33.         }//while  
  34.   
  35.     }//  
  36.     else        // father process  
  37.     {  
  38.         close( connfd );  
  39.     }  
  40. }//while  -- father  


3. 参考

[1] Linux C编程一站式学习

[2] Linux 环境下C编程指南

0 0
原创粉丝点击