一、引言
在网络编程中,服务器需要同时处理多个客户端的连接请求。多进程服务器是实现并发处理的经典方案之一。本文将详细介绍如何使用Linux系统调用实现一个完整的多进程TCP服务器,包括套接字创建、绑定、监听、接收连接以及进程管理等核心技术。
二、多进程服务器架构原理
2.1 基本架构
多进程服务器采用"父进程监听+子进程通信"的模式:
- 父进程:负责创建监听套接字,持续接收新的客户端连接
- 子进程:每个子进程独立处理一个客户端的通信请求
这种架构的优势在于各客户端之间互不干扰,某个客户端的异常不会影响其他客户端的服务。
三、完整代码实现
3.1 服务器端完整代码
#include<stdio.h>#include<stdlib.h>#include<string.h>#include<unistd.h>#include<arpa/inet.h>#include<sys/wait.h>#definePORT9999#defineBUFFER_SIZE1024#defineMAX_LISTEN128// 子进程通信函数voidworking(intcfd){charbuf[BUFFER_SIZE];while(1){// 清空缓冲区memset(buf,0,sizeof(buf));// 接收客户端数据(阻塞函数)intlen=read(cfd,buf,sizeof(buf));if(len==0){// 客户端断开连接printf("客户端断开了连接...\n");break;}elseif(len==-1){// 读取错误perror("read error");break;}else{// 正常接收数据printf("客户端say: %s\n",buf);// 回复客户端(原样返回)write(cfd,buf,len);}}// 关闭通信文件描述符close(cfd);printf("子进程通信结束,关闭连接\n");}intmain(){// 1. 创建监听套接字intlfd=socket(AF_INET,SOCK_STREAM,0);if(lfd==-1){perror("socket error");exit(1);}printf("监听套接字创建成功,fd = %d\n",lfd);// 2. 绑定地址和端口structsockaddr_inaddr;addr.sin_family=AF_INET;// IPv4协议addr.sin_port=htons(PORT);// 端口号转网络字节序addr.sin_addr.s_addr=INADDR_ANY;// 绑定所有可用IP (0.0.0.0)intret=bind(lfd,(structsockaddr*</