【剖析 | SOFARPC 框架】之SOFARPC 线程模型剖析

  1. 云栖社区>
  2. 博客>
  3. 正文

【剖析 | SOFARPC 框架】之SOFARPC 线程模型剖析

花肉酱 2018-11-01 15:10:12 浏览910
展开阅读全文

前言

上一篇,我们介绍了 SOFARPC 同步异步的实现,本文我们将会介绍 SOFARPC 中的线程模型。

本文会从同步异步,阻塞非阻塞开始讲起,进而探讨常见的线程模型设计,之后,我们会介绍下 SOFABolt 中对 Netty 的模型使用,最后 SOFARPC 在一次调用过程中各个步骤执行的线程。

几种常见的 IO 模型

首先介绍一下 Linux 的几种 IO 模型,以进程从 Socket 中读取数据为例。实际上,进程最终是通过 recvfrom 系统调用来读取数据。这个时候,系统内核在收到之后,根据 IO 模型的不同,处理是不同的。

注意,图下的红色部分表示阻塞时间。

阻塞 I/O

阻塞 IO.png | center | 747x326

阻塞 I/O(blocking I/O) 模型是最流行,最简单易用的 I/O 模型,默认情况下,所有套接字和文件描述符就是阻塞的。阻塞 I/O 将使请求进程阻塞

网友评论

登录后评论
0/500
评论
花肉酱
+ 关注