继上一篇socket层的介绍,接着说说linux的socket层的知识点,我们知道,在linux系统上,一切皆文件,之所以这么说,是因为linux系统的抽象层的设计是非常到位的,对于操作系统上的很多子系统也是基于文件IO的方式进行工作的,linux系统之所以有这样的特性,要感恩于VFS的设计,正是有了VFS,才有了后面的网络系统,文件系统等,言归正传,socket层也可以通过文件IO的方式进行工作,因为linux内核支持了一种套接口文件类型的系统,它的数据结构如下所示:
这个数据结构就是套接口文件类型的表示,可以看到,里面包含了两个比较重要的函数指针,一个是超级块的分配函数sockfs_get_sb,另一个是超级块的释放函数kill_anon_super,大家可能对超级块的概念不熟,简单来说,超级块就是管理文件系统的结构,里面存放了文件系统的很多详细信息,比如,节点的释放和分配,文件系统使用了哪些节点等等,对于超级块的概念,还是专门留一篇文章介绍吧。
每个文件系统的超级块都有自己的操作接口,这也是抽象层设计的惯用方法,那么socket文件超级块的操作接口如下所示:
sockfs_ops这个结构定义了套接口层超级块的操作函数的集合:
Sock_alloc_inode:申请inode节点的函数
Sock_destroy_inode:释放inode节点的函数
Simple_statfs: 统计文件系统的函数
说到这里,大家可能对inode节点不太了解,简单的说,就是linux系统上你创建一个文件,就会生成一个inode节点,也就是你在linux系统上看的文件,在内核都会有一个inode节点与之对应。
我们知道文件系统中的文件与inode是一一对应的,那么,socket层为了能让自己能像文件IO一样被操作,所以socket和inode节点必须建立起关联性才能达到效果,这个关联性在内核有一个结构体来表示这样的关系,如下所示:
可见这个结构体由socket和inode构成,这样既可以通过inode找到socket,也可以通过socket找到inode。
下面是inode节点的分配函数,如下:
从 sock_inode_cacheip 缓存中申请socekt_alloc大小的内存空间出来,主要用来存放socket和inode,然后是初始化等待队列,等待队列是和进程的调度有关,后续会讲到,大家可以看到,套接口的初始化的状态是SS_UNCONNECTED。
今天就说到这里吧,谢谢,最后给大家展示一下网络的分层模型,我们现在讲的是传输层中的socket层。