并发服务器---IO多路复用

单循环服务器:同一时刻只能处理一个客户端任务

并发服务器: 同一时刻,只能处理多个客户端的任务

实现方法:多进程 多线程 IO多路复用

IO多路复用:

1.阻塞io(fgets scanf recv getchar read)

想要两个io具有同步的方式 | CPU占有率低

2.非阻塞io

使用轮询的方式实现 | cpu占有率高

实现方式:

1.获取原文件描述符的属性fcntl()

2.为文件描述符添加非阻塞属性

3.设置文件描述符属性

fcntl()

常用

F_GETFL 获取 F_SETFL 设置

3.信号驱动io

异步通知的io方式,节省cpu | 只能监测少量io,以轮询的方式可监测多量io

实现方式:

1)为IO设备增加信号驱动属性

O_ASYNC

2)关联SIGIO信号到对应进程

fcntl(fd, F_SETOWN, getpid());

  1. 注册SIGIO处理函数

signal

4.io多路复用(多个io通过一个进程监测)

多进程和多线程的主要区别在于以下几个方面:
  1. 资源管理

    • 多进程:每个进程有自己的内存空间和资源,进程间通信(IPC)通常复杂且开销较大。
    • 多线程:线程共享同一进程的内存空间和资源,线程间通信较为简单且高效。
  2. 开销

    • 多进程:进程创建和销毁的开销较大,因为需要分配和管理独立的内存空间。
    • 多线程:线程创建和销毁的开销较小,因为它们共享进程的内存和资源。
  3. 独立性

    • 多进程:进程间相对独立,一个进程的崩溃不会直接影响到其他进程。
    • 多线程:线程之间较为紧密,一个线程的崩溃可能会影响整个进程中的其他线程。
  4. 使用场景

    • 多进程:适用于需要强隔离和独立运行的任务,如服务器处理多个客户端请求。
    • 多线程:适用于需要共享数据和资源的任务,如计算密集型的应用和需要快速响应的应用。
相关推荐
秋名山小桃子3 分钟前
Kunlun 2280服务器(ARM)Raid卡磁盘盘符漂移问题解决
运维·服务器
与君共勉121384 分钟前
Nginx 负载均衡的实现
运维·服务器·nginx·负载均衡
努力学习的小廉10 分钟前
深入了解Linux —— make和makefile自动化构建工具
linux·服务器·自动化
MZWeiei14 分钟前
Zookeeper基本命令解析
大数据·linux·运维·服务器·zookeeper
Arenaschi33 分钟前
在Tomcat中部署应用时,如何通过域名访问而不加端口号
运维·服务器
小张认为的测试33 分钟前
Linux性能监控命令_nmon 安装与使用以及生成分析Excel图表
linux·服务器·测试工具·自动化·php·excel·压力测试
waicsdn_haha41 分钟前
Java/JDK下载、安装及环境配置超详细教程【Windows10、macOS和Linux图文详解】
java·运维·服务器·开发语言·windows·后端·jdk
良许Linux1 小时前
0.96寸OLED显示屏详解
linux·服务器·后端·互联网
蜜獾云1 小时前
docker 安装雷池WAF防火墙 守护Web服务器
linux·运维·服务器·网络·网络安全·docker·容器
小屁不止是运维1 小时前
麒麟操作系统服务架构保姆级教程(五)NGINX中间件详解
linux·运维·服务器·nginx·中间件·架构