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

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

day12

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

day x

1. 服务器编程基本框架

img

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

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

两种高效的事件处理模式

准备知识:

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

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

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

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

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

  • Reactor:

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

img

img

img

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

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

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

各种类型的Reactor的优缺点:

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

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

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

  • Proactor

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

img

      • 可惜的是,在 Linux 下的异步 I/O 是不完善的,aio 系列函数是由 POSIX 定义的异步操作接口,不是真正的操作系统级别支持的,而是在用户空间模拟出来的异步,并且仅仅支持基于本地文件的 aio 异步操作,网络编程中的 socket 是不支持的,这也使得基于 Linux 的高性能网络程序都是使用 Reactor 方案。
      • 而 Windows 里实现了一套完整的支持 socket 的异步编程接口,这套接口就是 IOCP,是由操作系统级别实现的异步 I/O,真正意义上异步 I/O,因此在 Windows 里实现高性能网络程序可以使用效率更高的 Proactor 方案。
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
牛客网的课程《Linux高并发服务器开发》中包含了项目笔记,其中涉及到了WebServer的开发。根据引用的信息,这门课程的学习进度可能由于个人原因而拖延了一段时间。在第五章的项目学习中,可能包含了关于多进程服务器开发的学习内容。不过具体的学习笔记可能还没有迁移到pad上,暂时无法获取详细的内容[2]。根据引用,在服务器开发中,使用单Reactor和多线程的方法可以提高效率,并充分利用多核CPU的性能优势。然而,使用多线程开发可能需要在各自的线程上加锁保护临界区数据,相对较为复杂。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [牛客网c++web服务器项目学习笔记-第0章 课程介绍](https://blog.csdn.net/weixin_45139984/article/details/132205586)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [【牛客网C++服务器项目学习Day12-网络编程两种事件处理模式](https://blog.csdn.net/qq_42518941/article/details/122283291)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值