最近在看网络编程模型,虽然Golang天然高并发的原因很大一部分是因为协程
和channel
,但是这个里面还是离不开底层的网络编程模型的选用 — epoll
。在学习这部分的时候对IO多路复用
做了一些了解。
一些概念
内核空间和用户空间
现在操作系统都是采用虚拟存储器,那么对32位操作系统而言,它的寻址空间(虚拟存储空间)为4G(2的32次方)。操作系统的核心是内核,独立于普通的应用程序,可以访问受保护的内存空间,也有访问底层硬件设备的所有权限。
为了保证用户进程不能直接操作内核,保证内核的安全,操心系统将虚拟空间划分为两部分,一部分为内核空间
,一部分为用户空间
。我们可以简单理解为,一张纸,四分之一给一个叫内核的人用,四分之三给一个叫用户的人用。
fd 文件操作描述符
文件描述符
在形式上是一个非负整数,它是一个索引值,指向内核为每一个进程所维护的该进程打开文件的记录表。当程序打开一个现有文件或者创建一个新文件时,内核向进程返回一个文件描述符。文件描述符这一概念往往只适用于Unix和Linux这样的操作系统。
缓存IO
缓存 I/O 又被称作标准 I/O
,大多数文件系统的默认 I/O 操作都是缓存 I/O。在 Linux 的缓存 I/O 机制中,操作系统会将 I/O 的数据缓存在文件系统的页缓存( page cache )中,也就是说,数据会先被拷贝到操作系统内核的缓冲区中
,然后才会从操作系统内核的缓冲区拷贝到应用程序的地址空间。就是从内核空间
到用户空间
需要经过两次复制操作。这些数据拷贝操作所带来的 CPU 以及内存开销是非常大的。