项目学习地址:【牛客网C++服务器项目学习】

day12

本该日更的项目学习进度,因为个人原因导致了拖更。虽然该专栏并没有读者,但是我觉得打乱了自己的计划,属实不该。由于课程【4.20】多进程服务器开发之后的学习笔记在pad上,暂时还没来得及迁移。这篇文章记录的是第五章项目学习的内容。

day x

1. 服务器编程基本框架

项目的改进点在 网络存储单元

这个课不可能能够涉及到完整的服务器开发,还需要自己去钻研和学习

两种高效的事件处理模式

准备知识:

阻塞、非阻塞:阻塞是指进程/线程在调用某些阻塞函数后未获得需要的资源时,被放入等待队列中等待的一种状态描述。例如,调用read函数进行数据读取时,进程/线程会被阻塞,一直等到内核将数据准备好,再把数据从内核缓冲区拷贝到用户的程序缓冲区后,read函数才会返回。

阻塞 I/O 好比,你去饭堂吃饭,但是饭堂的菜还没做好,然后你就一直在那里等啊等,等了好长一段时间终于等到饭堂阿姨把菜端了出来(数据准备的过程),但是你还得继续等阿姨把菜(内核空间)打到你的饭盒里(用户空间),经历完这两个过程,你才可以离开。

非阻塞 I/O 好比,你去了饭堂,问阿姨菜做好了没有,阿姨告诉你没,你就离开了,过几十分钟,你又来饭堂问阿姨,阿姨说做好了,于是阿姨帮你把菜打到你的饭盒里,这个过程你是得等待的。

同步、异步:同步和异步相较于【阻塞/非阻塞】是一种抽象的概念。它是一种消息通知机制。在我看来,阻塞和非阻塞是 同步/异步技术理念的具体实现方式。同步是指调用方法在没得到返回结果之前,会在原地一直等待(等待的方式有两种:一是放入线程/进程等待队列中,二是while循环忙等待)。实现异步的函数有:aio_read, aio_write

异步 I/O 好比,你让饭堂阿姨将菜做好并把菜打到饭盒里后,把饭盒送到你面前,整个过程你都不需要任何等待。

  • Reactor:

    • Reactor是网络编程中的一种非阻塞、同步事件处理模式。其主要的特点是将监听客户端连接和处理事件进行分离,更具体的讲,是使用Reactor负责监听的和分发事件,在处理资源池(线程池)中进行事件的处理。
    • Reactor的模式是灵活多变的:
    • 单Reactor + 单进程/线程(redis使用该模式)
    • 单Reactor + 多进程/线程(本项目使用的模式)
    • 多Reactor + 多进程/线程(Netty、Memcache、Ngnix)

在单Reactor + 多线程的模式中,引入了一个线程池的概念:

  • 所谓线程池,是在内核中开辟一块内存,在客户端连接到来之前提前创建好。每建立一个客户端连接,便从线程池中分配一个线程给该客户端,客户端连接结束后,将该线程还给线程池。

    • 线程池的好处是可以避免频繁的创建和销毁线程。

各种类型的Reactor的优缺点:

  • 单Reactor + 单线程 : 优点是简单,上手快,没有多线程之间的资源竞争问题。但是缺点是无法充分利用多核CPU的性能。(不过在redis上性能瓶颈不是CPU的性能)

  • 单Reactor + 多线程: 效率高,能够充分利用多核CPU的性能优势。缺点是:使用多线程开发的话需要在各自线程上加锁保护临界区数据,比较复杂

  • 多Reactor + 多线程:效率高,相较于【单Reactor + 多线程】能够处理更高的并发情况,此外子线程在业务处理完成后,无需将数据返还到主线程中进行发送,可以直接在子线程中发送给客户端。

  • Proactor

    • Proactor模式是一种基于异步I/O的事件处理模式。(异步I/O就没有阻塞和非阻塞的区别了)。
    • 异步I/O的调试比较复杂。

  • 可惜的是,在 Linux 下的异步 I/O 是不完善的,aio 系列函数是由 POSIX 定义的异步操作接口,不是真正的操作系统级别支持的,而是在用户空间模拟出来的异步,并且仅仅支持基于本地文件的 aio 异步操作,网络编程中的 socket 是不支持的,这也使得基于 Linux 的高性能网络程序都是使用 Reactor 方案。
  • 而 Windows 里实现了一套完整的支持 socket 的异步编程接口,这套接口就是 IOCP,是由操作系统级别实现的异步 I/O,真正意义上异步 I/O,因此在 Windows 里实现高性能网络程序可以使用效率更高的 Proactor 方案。

【牛客网C++服务器项目学习】Day12-网络编程的两种事件处理模式相关推荐

  1. 【牛客网C++服务器项目学习】-Day09-网络模型个人总结

    项目学习地址:[牛客网C++服务器项目学习] day09 项目学习进入了第四章--网络编程.这一章的学习,前半段是对计算机网络体系进行一个大致的讲解.我自己在今年4月份系统性的看了<计算机网络自 ...

  2. 【牛客网C++服务器项目学习】Day6-有名管道、内存映射、信号机制

    项目学习地址:[牛客网C++服务器项目学习] 有名管道: 有名管道特点: 有名管道是FIFO文件,存在于文件系统中,可以通过文件路径名来指出. 管道文件仅仅是文件系统中的标示,并不在磁盘上占据空间.在 ...

  3. 【牛客网C++服务器项目学习】Day8-线程相关、线程锁、条件变量、信号量

    项目学习地址:[牛客网C++服务器项目学习] day08 函数:void pthread_exit(void *retval); 功能:终止调用这个函数的线程.如果是一个进程的最后一个线程调用该函数, ...

  4. 从零开始—仿牛客网讨论社区项目(一)

    主要技术架构: SpringBoot Spring SpringMVC MyBatis Redis Kakfa Elasticsearch Spring Security Spring Actator ...

  5. 从零开始—仿牛客网讨论社区项目(六)

    主要技术架构: SpringBoot Spring SpringMVC MyBatis Redis Kakfa Elasticsearch Spring Security Spring Actator ...

  6. 仿牛客网讨论社区项目—优化网站性能

    性能优化: 1.考虑加入缓存优化 优化热门帖子列表 GitHub中搜索caffeine 在Maven Repository搜索caffeine配置文件,在resources文件包内的pom.xml文件 ...

  7. 牛客网 vivo2020届春季校园招聘在线编程考试 第3题

    牛客网 vivo2020届春季校园招聘在线编程考试 第3题 1.问题分析 2.问题解决 3.总结 1.问题分析   主要就是两个数学公式.代码我已经进行了详细的注释,理解应该没有问题,读者可以作为参考 ...

  8. 牛客网vivo2020届春季校园招聘在线编程考试

    来源:牛客网vivo2020届春季校园招聘在线编程考试 https://www.nowcoder.com/question/next?pid=22390442&qid=925105&t ...

  9. 牛客网 vivo2020届春季校园招聘在线编程考试 第2题

    牛客网 vivo2020届春季校园招聘在线编程考试 第2题 1.问题分析 2.问题解决 3.总结 1.问题分析 基本思路是: 1.如果有因子大于等于 10 ,说明不存在 m,使得 m 的各位(个位.十 ...

  10. 【c++】牛客网 vivo2020届春季校园招聘在线编程考试题 手机锁屏的有效模式

    题目参考: 牛客网 vivo2020届春季校园招聘在线编程考试题 一根烟,一壶酒,一道算法编一宿... 这是个明显的图结构,九个结点,任意两个节点间相连,我们可以求出图的所有所有满足如下要求的有序路径 ...

最新文章

  1. node平台截取图片模块——jimp
  2. 第一周(1.8-1.14)
  3. python编写代码购买飞机票_女朋友是机票贩子?用Python写个刷飞机票的脚本!生活费多了两百...
  4. 单体 soa 微服务 区别_漫谈何时从单体架构迁移到微服务?
  5. php cdi_使用Fabric8在CDI管理的bean中注入Kubernetes Services
  6. testNG入门详解
  7. Spring简化Java开发_第1章—Spring之旅—简化Spring的java开发
  8. python数据库实现注册函数_10.注册和登录功能实现(3)—— 注册数据写入数据库...
  9. SQL Server2005的XML数据类型之基础篇 (4)
  10. Win10系统升级,1804->21H2
  11. gg修改器偏移量修改_GG修改器正版
  12. sap代加工流程图_委外加工_SAP的两种典型委外处理方法
  13. python能做什么软件?Python到底能干嘛,一文看懂
  14. 知识付费系统源码(开源知识付费系统平台下载)
  15. tableau public使用形状文件进行数据可视化
  16. 埃隆·马斯克(Elon Musk)
  17. 【数学建模】数学建模学习5---图与网络(例题+matlab代码实现)
  18. 滴滴二面:Kafka是如何读写副本消息的?
  19. python做人脸识别速度_Python人脸识别速度慢
  20. Hbase Schema设计与数据模型操作

热门文章

  1. struct termios结构体详解
  2. labview 写入mysql_LabVIEW 连接MySQL数据库
  3. 删除下拉框只找23火星软件_下拉怎么做首选23火星软件
  4. 北京计算机应用中级,计算机应用教程(中级)
  5. 从Android运行时出发,打造我们的脱壳神器
  6. imageai--自动机器学习初体验
  7. 硬盘“AHCI”模式和“IDE”模式的区别
  8. Java实现多张图片转pdf
  9. 计算机多媒体技术所处理的六个,多媒体技术
  10. 学生评语管理系统软件测试,学校教师老师综合评价评分系统软件