Linux实现多进程服务端Socket通信

本文介绍了如何在Linux上创建一个多进程服务器,该服务器能够同时处理来自多个客户端的Socket连接请求。程序流程包括:创建并绑定套接字,监听连接,通过accept创建子进程处理每个客户端,子进程负责数据通信,父进程包含消息处理程序以防止僵尸进程。提供了一个程序实例,并展示了运行结果,包括服务端和多个客户端的交互情况。
摘要由CSDN通过智能技术生成

目录

程序流程

程序实例

运行结果


本例主要是让服务器能够同时处理多个客户端的连接请求。

程序流程

1. 创建基本的套接字,并绑定地址信息、设置监听;

2. 循环accept来接收连接请求,每接收一个连接请求,就创建一个子进程;

3. 在子进程中进行客户端与服务端的数据通信;

4. 在父进程中定义一个消息处理程序,用来等待子进程结束,从而防止僵尸进程的产生。

程序实例

#include<iostream>
#include<unistd.h>
#include<string.h>
#include<arpa/inet.h>
#include<errno.h>
#include<signal.h>
#include<sys/socket.h>
#include<sys/wait.h>

using namespace std;

#define SERV_IP "127.1.2.3"
#define SERV_PORT 8888

struct socket_info   //将文件描述符与地址结构体绑定在一起
{
	struct sockaddr_in sktaddr;
	int fd;
};


void sigChild(int sig)   //消息处理函数,当子进程退出时执行,用来回收子进程,防止僵尸进程
{
	while(waitpid(-1,NULL,WNOHANG) > 0);   //最后一个参数用WNOHANG,意味父进程非阻塞式等待子进程结束
}

int main()
{
	
  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值