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

2024-08-27 23:36

本文主要是介绍并发服务器---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());
3) 注册SIGIO处理函数
signal

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

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

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

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

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

    • 多进程:适用于需要强隔离和独立运行的任务,如服务器处理多个客户端请求。
    • 多线程:适用于需要共享数据和资源的任务,如计算密集型的应用和需要快速响应的应用。

这篇关于并发服务器---IO多路复用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1113098

相关文章

基于Python打造一个可视化FTP服务器

《基于Python打造一个可视化FTP服务器》在日常办公和团队协作中,文件共享是一个不可或缺的需求,所以本文将使用Python+Tkinter+pyftpdlib开发一款可视化FTP服务器,有需要的小... 目录1. 概述2. 功能介绍3. 如何使用4. 代码解析5. 运行效果6.相关源码7. 总结与展望1

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI

CentOS 7部署主域名服务器 DNS的方法

《CentOS7部署主域名服务器DNS的方法》文章详细介绍了在CentOS7上部署主域名服务器DNS的步骤,包括安装BIND服务、配置DNS服务、添加域名区域、创建区域文件、配置反向解析、检查配置... 目录1. 安装 BIND 服务和工具2.  配置 BIND 服务3 . 添加你的域名区域配置4.创建区域

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

Redis中高并发读写性能的深度解析与优化

《Redis中高并发读写性能的深度解析与优化》Redis作为一款高性能的内存数据库,广泛应用于缓存、消息队列、实时统计等场景,本文将深入探讨Redis的读写并发能力,感兴趣的小伙伴可以了解下... 目录引言一、Redis 并发能力概述1.1 Redis 的读写性能1.2 影响 Redis 并发能力的因素二、

Windows Server服务器上配置FileZilla后,FTP连接不上?

《WindowsServer服务器上配置FileZilla后,FTP连接不上?》WindowsServer服务器上配置FileZilla后,FTP连接错误和操作超时的问题,应该如何解决?首先,通过... 目录在Windohttp://www.chinasem.cnws防火墙开启的情况下,遇到的错误如下:无法与

Windows server服务器使用blat命令行发送邮件

《Windowsserver服务器使用blat命令行发送邮件》在linux平台的命令行下可以使用mail命令来发送邮件,windows平台没有内置的命令,但可以使用开源的blat,其官方主页为ht... 目录下载blatBAT命令行示例备注总结在linux平台的命令行下可以使用mail命令来发送邮件,Win