内核的keepalive:检查是否有连接,检查当次的连接的健康。
程序的keepalive:检查应用空间角色的健康。
内核在IO中:既管内存的分配,又管磁盘IO。
内核中有VFS的虚拟文件系统,VFS一个目录树,映射到不同的物理位置,每个物理位置可以是不同的具体的文件系统。
VFS树:给用户程序暴露的统一接口,她下面挂载的一些设备驱动可以不一样。
inode id:每个文件的id,是唯一的。
程序想读数据:1.先访问内核,说明想读哪个文件。inode号被加载,源数据被加载。
2.接着文件被读入到内存中,pagecache被加载。
如果两个程序想要访问同一个文件,并不会直接去读取文件,先访问的是虚拟文件系统。先去看pagecache,这个pagecache是共享的,如果pagecache里有文件读入的话直接在这里访问。pagecache是在内存中对数据的一个缓存。如果对其进行修改,会修改为dirty脏,会有flush书写到磁盘中进去。这个时候,什么时候书写的书写的形式就决定了IO模型。比如达到某个阈值才书写到磁盘中去。
怎么找到pagecache,每个程序都有其独立的指针,seek。seek会有其偏移量来指向程序所对应的pagecache。