Linux网络编程基础<多进程并发服务器>

news/2024/4/29 11:12:18/文章来源:https://blog.csdn.net/liqifff/article/details/126903201

一、应用场景

  • 最简单的socket示列代码只能一个客户端连接一个服务器,并不支持多个客户端对服务器的连接,为了能让多个客户端进行连接所以需要多进程或者多线程处理

二、思路解析

服务器端的程序是俩个套接字socket创建一个lfd,accept创建一个cfd阻塞连接套接字
在这里插入图片描述
所以只需要在fork创建的子线程里面处理与客户端的数据通信,在父进程处理连接客户端的数量处理,也就是回收进程资源。

Socket();		//创建监听套接字lfd
Bind();			//绑定服务器地址结构
Listen();		//设置监听上限
while(1){cfd=Accept();pid=fork();if(pid==0){close(lfd);		//子进程用不到lfdread(cfd);数据处理;write(cfd);}else if(pid>0){close(cfd);		//父进程用不到cfd}
}

总结:

子进程:c

  1. close(lfd);
  2. read();
  3. 数据处理;
  4. wirte();

父进程:

  • 注册信号捕捉函数:SIGNAL;
  • 在回调函数中完成子进程回收:while(waitpid());

三、示列demo

重要API

  • socket套接字
    socket、bind、listen、accept、connect

  • 文件API
    open、read、write、close

  • 进程API
    sigaction waitpid waitppid在这里插入图片描述在这里插入图片描述

多进程并发服务器未带回收进程处理

#include <sys/types.h>
#include <sys/socket.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netinet/ip.h>
#include <stdio.h>
#include <error.h>
#include <string.h>
#include <unistd.h>
#include <stdlib.h>
#include <strings.h>
#include <sys/wait.h>
#include <ctype.h>
#include <signal.h>#define SERIVER_PORT 9999int main(void)
{pid_t pid;int lfd, cfd;int ret, i;struct sockaddr_in myseriver;struct sockaddr_in myclient;int myclient_len = 0;char buf[100] = {0};lfd = socket(AF_INET, SOCK_STREAM, 0);if (lfd < 0){perror("socket is error");exit(1);}myseriver.sin_family = AF_INET;myseriver.sin_port = htons(SERIVER_PORT);myseriver.sin_addr.s_addr = htonl(INADDR_ANY);ret = bind(lfd, (struct sockaddr *)&myseriver, sizeof(myseriver));if (ret < 0){perror("bind is error");exit(1);}ret = listen(lfd, 128);if (ret < 0){perror("listen is error");exit(1);}myclient_len = sizeof(myclient);while (1){cfd = accept(lfd, (struct sockaddr *)&myclient, &myclient_len);if (cfd < 0){perror("accept is error");exit(1);}pid = fork();if (pid == 0){close(lfd);printf("childinit is success");while (1){ret = read(cfd, buf, sizeof(buf));if (ret == 0){close(cfd);exit(1);}for (i = 0; i < ret; i++)buf[i] = toupper(buf[i]);write(cfd, buf, ret);write(STDOUT_FILENO, buf, ret);}}else if (pid < 0){perror("fork is error");exit(1);}else{close(cfd);}}
}

多进程并发服务器带回收进程处理

#include <sys/types.h>
#include <sys/socket.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netinet/ip.h>
#include <stdio.h>
#include <error.h>
#include <string.h>
#include <unistd.h>
#include <stdlib.h>
#include <strings.h>
#include <sys/wait.h>
#include <ctype.h>
#include <signal.h>#define SERIVER_PORT 9999void back_child(int signum)
{while((waitpid(0,NULL,WNOHANG))>0);return;
}int main(void)
{pid_t pid;int lfd, cfd;int ret, i;struct sockaddr_in myseriver;struct sockaddr_in myclient;int myclient_len = 0;char buf[100] = {0};lfd = socket(AF_INET, SOCK_STREAM, 0);if (lfd < 0){perror("socket is error");exit(1);}myseriver.sin_family = AF_INET;myseriver.sin_port = htons(SERIVER_PORT);myseriver.sin_addr.s_addr = htonl(INADDR_ANY);ret = bind(lfd, (struct sockaddr *)&myseriver, sizeof(myseriver));if (ret < 0){perror("bind is error");exit(1);}ret = listen(lfd, 128);if (ret < 0){perror("listen is error");exit(1);}myclient_len = sizeof(myclient);while (1){cfd = accept(lfd, (struct sockaddr *)&myclient, &myclient_len);if (cfd < 0){perror("accept is error");exit(1);}pid = fork();if (pid == 0){close(lfd);printf("childinit is success");while (1){ret = read(cfd, buf, sizeof(buf));if (ret == 0){close(cfd);exit(1);}for (i = 0; i < ret; i++)buf[i] = toupper(buf[i]);write(cfd, buf, ret);write(STDOUT_FILENO, buf, ret);}}else if (pid < 0){perror("fork is error");exit(1);}else{struct sigaction act;act.sa_handler = back_child;sigemptyset(&act.sa_mask); act.sa_flags = 0;ret = sigaction(SIGHUP, &act, NULL);if (ret != 0){perror("signal is error");}close(cfd);}}
}

四、效果展示

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_9326.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

外置编码矩阵神经网络all you need

🍿*★,*:.☆欢迎您/$:*.★* 🍿 目录 背景 正文 总结 背景描述

数据结构刷题:第十三天

目录 一&#xff0c;二叉搜索树中的搜索 1&#xff0c;递归 复杂度分析 2&#xff0c;迭代 复杂度分析 二&#xff0c;二叉搜索书中的插入操作 1&#xff0c;模拟 思路与算法 复杂度分析 一&#xff0c;二叉搜索树中的搜索 700. 二叉搜索树中的搜索 - 力扣&#xff08;L…

阿里P8大佬,整理的从零构建企业级容器集群实战笔记,真涨薪神器

前言 微服务架构时代对我们的基础设施管理提出了非常大的挑战&#xff0c;DevOps和持续交付成为了基本能力要求。没有近两年容器技术的快速发展&#xff0c;这些能力可能仍然只属于少数技术实力强大的互联网公司。容器技术的应用从真正意义上催化了我们在基础设施管理上的革命…

最小系统板 STM32入门,呼吸灯实现(STM32F103C6T6)

Hi, I’m Shendi 接着前一篇 https://blog.csdn.net/qq_41806966/article/details/126894938 这一次使用库来进行 LED 灯的开关&#xff0c;及延时的实现 呼吸灯实现 之前使用直接修改地址的方式实现点灯&#xff0c;这次用 GPIO 实现点灯&#xff0c;并加上延迟&#xff0…

傅立叶及其python应用

前言 本文是傅立叶及其python应用系列的第三篇文章对应的仓库地址为https://github.com/yuanzhoulvpi2017/tiny_python/tree/main/Fourier_Series 介绍 第二篇主要介绍了傅立叶的核心&#xff1a;“傅里叶级数就是函数在某个函数空间中各个基底的投影和“&#xff0c;然后基…

Day27、使用DQL命令查询数据

1、DQL语言 1.1、DQL(Data Query Language&#xff0c;数据查询语言) 1&#xff09;查询数据库数据&#xff0c;如SELECT语句 2&#xff09;简单的单表查询或多表的复杂查询和嵌套查询 3&#xff09;数据库语言中最核心、最重要的语句 4&#xff09;使用频率最高的语句 1.2、SE…

Linux小白学习

Linux学习 虚拟机 安装Linux镜像下载简单命令含义 一、虚拟机安装 参考视频&#xff1a;https://www.bilibili.com/video/BV1dS4y1e7rH?share_sourcecopy_web&vd_source0d57c2e2317ebb16893c37677d1b8931 二、Linux镜像下载 网盘下载地址&#xff1a; 链接&#xff1a;h…

如何设计一个可扩展的登录功能

本文主要分享了如何设计一个可扩展的登录功能。 一、多种登录方式&#xff08;需要有一个唯一值来绑定各种登录方式&#xff0c;目前业界用的比较多的是手机号&#xff09; 1.用户名密码登录 最原始的登录方式&#xff0c;这种登录方式与注册功能是分开的&#xff0c;业界慢慢…

网课查题公众号搭建教程(内附接口、源码)

网课查题公众号搭建教程(内附接口、源码) 本平台优点&#xff1a;免费查题接口搭建 多题库查题、独立后台、响应速度快、全网平台可查、功能最全&#xff01; 1.想要给自己的公众号获得查题接口&#xff0c;只需要两步&#xff01; 2.题库&#xff1a;题库后台http://daili.j…

Windows11+Ubuntu 3系统如何安全地删掉最后一个Ubuntu系统?

文章目录Windows11Ubuntu 3系统如何安全地删掉最后一个Ubuntu系统&#xff1f;3系统是什么&#xff1f;第一步&#xff1a;删掉Ub16第二步&#xff1a;重启进入grub命令行第三步&#xff1a;从grub命令行中手动启动ubuntu20第四步&#xff1a;进入Windows11更新开机启动项grub配…

LeetCode 0304. 二维区域和检索 - 矩阵不可变

【LetMeFly】304.二维区域和检索 - 矩阵不可变 力扣题目链接&#xff1a;https://leetcode.cn/problems/range-sum-query-2d-immutable/ 给定一个二维矩阵 matrix&#xff0c;以下类型的多个请求&#xff1a; 计算其子矩形范围内元素的总和&#xff0c;该子矩阵的 左上角 为…

3、Android 活动Activity(4)(为活动补充附加信息)

在意图之外给活动添加额外的信息&#xff0c; 首先可以把字符串参数放到字符串资源文件中&#xff0c;待App运行之时再从资源文件读取字符串值&#xff1b; 接着还能在AndroidManifest.xml中给指定活动配置专门的元数据&#xff0c;App运行时即可获取对应活动的元数据信息&…

C#使用winform做一个开关小游戏

成品展示 游戏原理&#xff1a; 游戏时&#xff0c;任意点击一个格子&#xff0c;其自身状态改变&#xff0c;且上下左右四个格子的状态也进行变化&#xff0c;即&#xff1a;原来是开的变成关的&#xff0c;原来是关的变成开的。 制作过程 1.建项目会的吧。 2.设置游戏窗…

TCP重传,滑动窗口,流量控制,拥塞控制

重传机制 超时重传快速重传SACKD-SACK 超时重传 RTT 就是 数据从网络一端传送到另一端所需要的时间&#xff0c;也就是包的往返时间。 超时重传时间以 RTO 表示&#xff0c;应该略大于RTT。 如果超时重发的数据&#xff0c;再次超时时有需要重传&#xff0c;TCP的策略是超…

[需求管理-2]:什么是需求以及需求的收集与识别

目录 第1章 什么是需求识别 第2章 需求的来源 2.1 外部需求&#xff08;收集&#xff09; 2.2 内部需求&#xff08;开发&#xff09; 第3章 需求的层次 第4章 需求的形式 4.1 提问题&#xff08;针对业务层次需求、原始性需求&#xff09;&#xff1a;第一性原理 4.2 …

视觉SLAM十四讲_4李群与李代数

本文为b站视频的一个笔记 在SLAM中&#xff0c;我们经常要解下面一个问题 FminJ(T)Σi1N∣∣zi−Tpi∣∣2F minJ(T) \Sigma_{i1}^N||z_i - Tp_i||^2FminJ(T)Σi1N​∣∣zi​−Tpi​∣∣2 这个问题中, T是位姿变量。对于求最小值问题&#xff0c;我们第一步就要求函数对于变量…

Java小白踩坑录上

文章目录1、Java小白踩坑录 - String和char2、Java小白踩坑录 - Random 揭秘3、Java小白踩坑录 - B计划之Java资源如何释放&#xff1f;4、Java小白踩坑录 - 反射到底有多慢&#xff1f;5、Java小白踩坑录 - 数组 & List6、Java小白踩坑录 - Java类型的七十二变揭秘7、Java…

IDEA生成带参数和返回值注解

文章目录步骤说明打开IDEA进入 - 设置 - 编辑器 - 活动模板现象一&#xff1a;IDEA提示悬空的注解现象二&#xff1a;IDEA提示标签说明已丢失使用范围设置注解使用步骤说明 打开IDEA进入点击左上角 - 文件 - 设置 - 编辑器 - 活动模板 新建活动模板 填写模板文本 编辑变量 …

2.canal服务器配置及java客户端

【README】 1.本文总结自 B站《尚硅谷-canal》&#xff1b; 2.canal 介绍&#xff0c;可以参考 GitHub - alibaba/canal: 阿里巴巴 MySQL binlog 增量订阅&消费组件 3. canal服务器配置包括 mysql配置&#xff0c;canal配置等&#xff1b; 4.mysql服务器&#xff0c;ca…

完美且简要,如此输出风控中的重要数据指标曲线(如KS等)

先前&#xff0c;我们用excel给大家演示过一个KS的计算方式。 ks值是在模型中用于区分预测正负样本分隔程度的评价指标。每个样本的预测结果化对应的一个个分数&#xff0c;从最低分到最高分&#xff0c;输出为正负样本的累积分布。Ks值为这个两个正负样本中&#xff0c;最大差…