并发服务器

news/2024/9/18 20:57:46/ 标签: 服务器, 运维

一、服务器

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

2.并发服务器:同一时刻,可以处理多个客户端的任务;

3.TCP并发服务器

(1)多进程:

(2)多线程:

多进程并发服务器

  1. 基本概念:

    • 采用多个进程来处理客户端请求,每个请求由一个独立的进程处理。
    • 通常使用操作系统的进程创建机制(如 fork)来生成新进程。
  2. 优点:

    • 进程间隔离:每个进程有独立的内存空间,进程崩溃不会影响其他进程,提高了稳定性和安全性。
    • 可利用多核处理器:在多核 CPU 上,多个进程可以并行执行,充分利用 CPU 性能。
  3. 缺点:

    • 创建和销毁进程的开销较大,相较于线程切换性能较差。
    • 进程间通信(IPC)相对复杂,性能较低。
    • 使用内存多,资源开销大。

多线程并发服务器

  1. 基本概念:

    • 采用多个线程来处理客户端请求,每个请求由一个独立的线程处理。
    • 线程共享同一进程的内存空间。
  2. 优点:

    • 线程创建和切换的开销较小,因此处理请求的响应速度更快。
    • 内存占用效率高,多个线程共享进程的内存空间。
    • 线程间通信相对简单,可以直接使用共享变量。
  3. 缺点:

    • 线程之间的同步和数据共享需要额外的机制,容易引起竞态条件、死锁等问题。
    • 由于共享内存,崩溃的线程可能会导致整个进程崩溃。
    • 不同操作系统对线程的支持和调度策略不同,可能会影响性能。
  4. 多进程和多线程区别:

    1. 效率角度
    多线程效率高(创建、任务切换)
    2. 安全角度
    多进程比多线程安全(进程空间独立)
    3. 资源消耗
    进程资源消耗比线程多
    4. 通信
    进程:IPC 线程:全局变量(互压锁、信号量(同步) -------- 》锁)

(3)IO多路复用

二、IO模型

1.阻塞IO:fgets、scanf、read、recv、getchar

(1)实现多个IO同步的效果

(2)cpu占有率低

2.非阻塞IO

(1)使用轮询的方法实现

(2)cpu占有率高

实现步骤:获取原文件描述符的属性->增加非阻塞属性->设置新属性

  fcntl

#include <fcntl.h> int fcntl(int fd, int cmd, ... /* arg */ );

参数说明:fd:文件描述符,指向要进行操作的打开文件的描述符。

  • cmd:要执行的命令,可以是以下之一:

    • F_GETFD:获取文件描述符的标志。
    • F_SETFD:设置文件描述符的标志。
    • F_GETFL:获取文件状态标志。
    • F_SETFL:设置文件状态标志(例如,设置为非阻塞模式)。
    • F_GETLK:获取文件锁的状态。
    • F_SETLK:设置文件锁。
    • F_SETLKW:设置文件锁(如果锁被其他进程占用,则会阻塞)。
  • arg:可选参数,具体取决于 cmd 的值。如果 cmd 是 F_SETFDF_SETFL,则它是要设置的值;如果是 F_GETLK 或 F_SETLK,则它是指向一个 struct flock 的指针。

返回值:成功时返回 0 或文件描述符的一个标志值。失败时返回 -1,并设置 errno 以指示错误类型。

3.信号驱动IO

(1)异步通知的IO方式,节省CPU;

(2)只能监测少量IO;

        增加异步属性->关联信号和当前的进程->注册信号处理函数

4.IO多路复用

(1)多个IO复用一个进程;


http://www.ppmy.cn/news/1518805.html

相关文章

为什么搜索引擎可以检索到网站?

搜索引擎和爬虫&#xff0c;基于百度举例 为什么搜索引擎可以快速检索到所有对应页面&#xff1f; 搜索引擎能够快速检索到所有对应页面&#xff0c;主要归功于以下几个方面&#xff1a; 爬虫技术&#xff1a;自动遍历互联网上的网页。索引&#xff1a;将爬取的网页内容转换…

游戏出海,燃动全球,“安全”如何通关?

泼天的富贵落在了游戏圈&#xff0c;用事实打脸了男人消费不如狗的谬论。 这几天&#xff0c;无论是游戏圈内人还是圈外人&#xff0c;无人不知晓《黑神话&#xff1a;悟空》。这部头顶「3A国产游戏之光」的作品自6月8日预售以来&#xff0c;全平台销量超过800万份&#xff0c;…

【自动驾驶】控制算法(六)前馈控制与航向误差

写在前面&#xff1a; &#x1f31f; 欢迎光临 清流君 的博客小天地&#xff0c;这里是我分享技术与心得的温馨角落。&#x1f4dd; 个人主页&#xff1a;清流君_CSDN博客&#xff0c;期待与您一同探索 移动机器人 领域的无限可能。 &#x1f50d; 本文系 清流君 原创之作&…

【最新华为OD机试E卷】空栈压数(200分)-多语言题解-(Python/C/JavaScript/Java/Cpp)

🍭 大家好这里是春秋招笔试突围 ,一枚热爱算法的程序员 ✨ 本系列打算持续跟新华为OD-E/D卷的三语言AC题解 💻 ACM金牌🏅️团队| 多次AK大厂笔试 | 编程一对一辅导 👏 感谢大家的订阅➕ 和 喜欢💗 🍿 最新华为OD机试D卷目录,全、新、准,题目覆盖率达 95% 以上,…

【机器学习】10. 朴素贝叶斯

贝叶斯理论 P ( H ∣ E ) P ( E ∣ H ) P ( H ) P ( E ) P(H|E) \frac{P(E|H)P(H)}{P(E)} P(H∣E)P(E)P(E∣H)P(H)​ 两个假设&#xff1a; 类别之间相互独立每个类别同等重要 P(E1 | yes) E1 个数 / yes 个数 0 频率问题 上述理论会遇到某个类别为0的情况&#xff0c;导致…

【Qt应用】Qt编写简易文件管理系统

目录 引言 一、准备工作 二、设计思路 三、创建项目和基本界面 四、目录浏览功能 实现效果 五、文件操作功能 5.1 设置添加文件与删除文件按钮 5.2 添加文件槽函数 5.3 删除文件槽函数 5.4 实现效果 六、文件搜索功能 6.1 准备工作 6.2 搜索按钮槽函数 6.3 实现…

Java中的注解(Annotation)

Java中的注解&#xff08;Annotation&#xff09;是一种用于在代码中添加元数据的机制。它们可以被用来为类、方法、变量、参数等元素添加额外的信息&#xff0c;这些信息在编译时或运行时可以被读取和使用。注解本身不会直接影响代码的执行&#xff0c;但可以通过反射等机制在…

汽车三元浸出液回收钯铑

汽车三元催化器是减少汽车尾气排放的关键部件&#xff0c;它含有铂、钯、铑等贵金属。这些金属在汽车尾气净化过程中起着重要作用&#xff0c;但使用一段时间后会因中毒、烧结等原因而失活。回收这些贵金属不仅可以减少环境污染&#xff0c;还能节约宝贵的资源。以下是汽车三元…

使用C标准库中的printf输出

1、增加文件系统调用 对系统调用进行了调整&#xff0c;一是将所有的系统调用实现转移 从头文件转移到C文件中&#xff1b; 二是增加几个有关文件打开和关闭的接口 主要是将系统调用做成单独的app库&#xff0c;这个库可以供其它所有的应用程序使用 2、导入newlib库&#xff…

CleanClip for Mac v2.2.0 剪贴板历史管理软件正式激活版

CleanClip 是一款专为 Mac 用户设计的强大剪贴板历史管理工具。它能够自动保存您复制的内容,让您轻松访问和管理剪贴板历史记录,大大提高工作效率。 下载地址&#xff1a;CleanClip for Mac v2.2.0 剪贴板历史管理软件正式激活版 主要特点 自动保存剪贴板历史 CleanClip 会自…

基于麻雀SSA优化BP神经网络多输入多输出的数据回归预测Matlab程序SSA-BP 含预测新数据程序

基于麻雀SSA优化BP神经网络多输入多输出的数据回归预测Matlab程序SSA-BP 含预测新数据程序 文章目录 一、基本原理1. SSA&#xff08;麻雀搜索算法&#xff09;2. BP&#xff08;反向传播神经网络&#xff09;3. SSA-BP回归预测的整合 二、实验结果三、核心代码四、代码获取五、…

disk manager操作教程 如何使用Disk Manager组件 Mac如何打开ntfs格式文件

macOS系统有一个特别明显的弱点&#xff0c;即不能对NTFS格式磁盘写入数据。想要适合Mac系统使用来回转换磁盘格式又十分麻烦&#xff0c;这该怎么办呢&#xff1f;Tuxera ntfs for mac作为一款Mac完全读写软件&#xff0c;大家在安装该软件后&#xff0c;能充分使用它的磁盘管…

python自动化脚本:让工作自动化起来

Python是一种流行的编程语言&#xff0c;以其简洁和易读性而闻名。它提供了大量的库和模块&#xff0c;使其成为自动化各种任务的绝佳选择。 我们将探讨9个Python脚本及其代码&#xff0c;可以帮助您自动化各种任务并提高工作效率。无论您是开发人员、数据分析师还是只是想简化…

跨境多账号登录如何防止IP、cookie和设备关联?

在当今数字化时代&#xff0c;拥有某个平台的多个账号是必要的&#xff0c;但如何防止这些账号之间产生关联&#xff0c;进而导致封号&#xff0c;却是一个需要谨慎对待的问题。 一、 多账号关联的主要因素 1. IP地址 2. Cookie和缓存 3. 设备指纹 二、如何防关联&#xff…

Vue——认识day06_class与style绑定

在Vue中&#xff0c;可以使用v-bind指令来将CSS样式动态地绑定到HTML元素上。有两种方式可以实现CSS与style的绑定&#xff1a; 对象语法&#xff1a;可以将一个包含CSS属性和值的对象传递给v-bind&#xff0c;将对象的属性与HTML元素的style属性进行绑定。例如&#xff1a; …

20.神经网络 - 搭建小实战和 Sequential 的使用

神经网络 - 搭建小实战和 Sequential 的使用 在 PyTorch 中&#xff0c;Sequential 是一个容器&#xff08;container&#xff09;类&#xff0c;用于构建神经网络模型。它允许你按顺序&#xff08;sequential&#xff09;添加不同的网络层&#xff0c;并将它们串联在一起&…

手机FM LNA方案设计

一 概述 关于手机FM的使用&#xff0c;较为传统的则是在打开FM应用前先插入有线耳机才能使用FM应用。然而随着智能手机的进步以及有线耳机日益被无线蓝牙耳机所代替&#xff0c;内置FM LNA方案被应用的越来越多&#xff0c;无需插入有线耳机&#xff0c;复用例如GSM天线也能实…

JavaScript初级——键盘事件

1、 onkeydown —— 按键被按下 —— 如果一直按着某个键不松手&#xff0c;则事件会一直触发 —— 连续触发时&#xff0c;第一次和第二次之间会间隔稍微长一点&#xff0c;其他的会非常的快&#xff0c;这种设计是为了放置误操作的发生 2、 onkeyup —— 按键被松…

Substance 3D Stager for Mac/Win:高效三维场景设计利器

Substance 3D Stager是Adobe推出的一款专为Mac和Windows用户设计的三维场景设计和渲染软件&#xff0c;它以其高效、直观的特点&#xff0c;在数字艺术、游戏开发、影视特效等领域赢得了广泛的认可。 核心功能 直观的操作界面&#xff1a;Substance 3D Stager提供了优秀的视觉…

NTP时间服务器是什么?功能是什么?京准电钟

NTP时间服务器是什么&#xff1f;功能是什么&#xff1f;京准电钟 NTP时间服务器是什么&#xff1f;功能是什么&#xff1f;京准电钟 时间同步技术必定将是整个大数据处理系统的重要支撑和保障。时间同步技术使数据产生与处理系统的所有节点具有全局的、统一的标准时间&#x…