文件描述符与socket连接

每个进程开启一个soeket连接,都会占用一个文件描述符。

1. 概述

在Linux系统中一切皆可以看成是文件,文件又可分为:普通文件、目录文件、链接文件和设备文件。

文件描述符(file descriptor)是内核为了高效管理已被打开的文件所创建的索引,其是一个非负整数(通常是小整数),用于指代被打开的文件,所有执行I/O操作(包括网络socket操作)的系统调用都通过文件描述符。

程序刚刚启动的时候,0是标准输入,1是标准输出,2是标准错误。如果此时去打开一个新的文件,它的文件描述符会是3。POSIX标准要求每次打开文件时(含socket)必须使用当前进程中最小可用的文件描述符号码,因此,在网络通信过程中稍不注意就有可能造成串话。标准文件描述符图如下:

文件描述与打开的文件对应模型如下图:

2. 文件描述限制

在编写文件操作的或者网络通信的软件时,初学者一般可能会遇到“Too many open files”的问题。这主要是因为文件描述符是系统的一个重要资源,虽然说系统内存有多少就可以打开多少的文件描述符,但是在实际实现过程中内核是会做相应的处理的,一般最大打开文件数会是系统内存的10%(以KB来计算)(称之为系统级限制),查看系统级别的最大打开文件数可以使用sysctl -a | grep fs.file-max命令查看。与此同时,内核为了不让某一个进程消耗掉所有的文件资源,其也会对单个进程最大打开文件数做默认值处理(称之为用户级限制),默认值一般是1024,使用ulimit -n命令可以查看用户级文件描述符。在Web服务器中,通过更改系统默认值文件描述符的最大值来优化服务器是最常见的方式之一,具体优化方式请查看http://blog.csdn.net/kumu_linux/article/details/7877770。

3. 文件描述符和打开文件之间的关系

    每个进程都拥有自己的文件描述符。  文件描述符的唯一性是进程+文件描述符ID确定的。

4. 内核维护的3个数据结构

1. 进程级的文件描述符表

2. 系统级的打开文件描述符表

3. 文件系统的i-node表

进程级的描述符表的每一条目记录了单个文件描述符的相关信息。

1. 控制文件描述符操作的一组标志。(目前,此类标志仅定义了一个,即close-on-exec标志)

2. 对打开文件句柄的引用

内核对所有打开的文件的文件维护有一个系统级的描述符表格(open file description table)。有时,也称之为打开文件表(open file table),并将表格中各条目称为打开文件句柄(open file handle)。一个打开文件句柄存储了与一个打开文件相关的全部信息,如下所示:

1. 当前文件偏移量(调用read()和write()时更新,或使用lseek()直接修改)

2. 打开文件时所使用的状态标识(即,open()的flags参数)

3. 文件访问模式(如调用open()时所设置的只读模式、只写模式或读写模式)

4. 与信号驱动相关的设置

5. 对该文件i-node对象的引用

6. 文件类型(例如:常规文件、套接字或FIFO)和访问权限

7. 一个指针,指向该文件所持有的锁列表

8. 文件的各种属性,包括文件大小以及与不同类型操作相关的时间戳

下图展示了文件描述符、打开的文件句柄以及i-node之间的关系,图中,两个进程拥有诸多打开的文件描述符。

在进程A中,文件描述符1和30都指向了同一个打开的文件句柄(标号23)。这可能是通过调用dup()、dup2()、fcntl()或者对同一个文件多次调用了open()函数而形成的。

进程A的文件描述符2和进程B的文件描述符2都指向了同一个打开的文件句柄(标号73)。这种情形可能是在调用fork()后出现的(即,进程A、B是父子进程关系),或者当某进程通过UNIX域套接字将一个打开的文件描述符传递给另一个进程时,也会发生。再者是不同的进程独自去调用open函数打开了同一个文件,此时进程内部的描述符正好分配到与其他进程打开该文件的描述符一样。

此外,进程A的描述符0和进程B的描述符3分别指向不同的打开文件句柄,但这些句柄均指向i-node表的相同条目(1976),换言之,指向同一个文件。发生这种情况是因为每个进程各自对同一个文件发起了open()调用。同一个进程两次打开同一个文件,也会发生类似情况。

5. 总结

1. 由于进程级文件描述符表的存在,不同的进程中会出现相同的文件描述符,它们可能指向同一个文件,也可能指向不同的文件

2. 两个不同的文件描述符,若指向同一个打开文件句柄,将共享同一文件偏移量。因此,如果通过其中一个文件描述符来修改文件偏移量(由调用read()、write()或lseek()所致),那么从另一个描述符中也会观察到变化,无论这两个文件描述符是否属于不同进程,还是同一个进程,情况都是如此。

3. 要获取和修改打开的文件标志(例如:O_APPEND、O_NONBLOCK和O_ASYNC),可执行fcntl()的F_GETFL和F_SETFL操作,其对作用域的约束与上一条颇为类似。

4. 文件描述符标志(即,close-on-exec)为进程和文件描述符所私有。对这一标志的修改将不会影响同一进程或不同进程中的其他文件描述符

转载出处

https://www.cnblogs.com/DengGao/p/file_symbol.html

文件描述符与socket连接相关推荐

  1. linux unix域socket_从文件描述符到Socket

    回顾 在上一篇[谈谈我对学习Netty的看法]大致描述了学习netty整个知识的储备,今天就从最基础的文件描述符开始. 文件描述符 我们知道在linux系统中一切皆文件,而文件又可分为:普通文件.目录 ...

  2. linux文件描述符、软硬连接、输入输出重定向

    引用链接:https://blog.csdn.net/qq769651718/article/details/79459346 文件描述符的作用: 文件描述符是linux操作系统中特有的概念.其相当于 ...

  3. 一文帮你搞懂 Android 文件描述符

    介绍文件描述符的概念以及工作原理,并通过源码了解 Android 中常见的 FD 泄漏. 一.什么是文件描述符? 文件描述符是在 Linux 文件系统的被使用,由于Android基 于Linux 系统 ...

  4. C语言socket accept()函数(提取出所监听套接字的等待连接队列中第一个连接请求,创建一个新的套接字,并返回指向该套接字的文件描述符)

    文章目录 名称 使用格式 功能参数描述 参数 sockfd addr addrlen 返回值 示例 man 2 文档中的accept解释 错误处理 名称 accept() 接收一个套接字中已建立的连接 ...

  5. Linux中通过Socket文件描述符寻找连接状态介绍

    针对下文的总结:socket是一种文件描述符 进程的打开文件描述符表 Linux的三个系统调用:open,socket,pipe 返回的都是一个描述符.不同的进程中,他们返回的描述符可以相同.那么,在 ...

  6. TCP/UDP网络编程入门教程之二:TCP Server端——socket与文件描述符

    UNIX中的一切事物都是文件(everything in Unix is a file!) 当我在这篇教程中提到UNIX的时候,其意思专指符合UNIX标准的所谓"正统"UNIX的衍 ...

  7. socket 编程入门教程(一)TCP server 端:2、socket与文件描述符

    UNIX中的一切事物都是文件( everything in Unix is a file!) 当我在这篇教程中提到UNIX的时候,其意思专指符合UNIX标准的所谓"正统"UNIX的 ...

  8. socket 文件描述符

    Linux中,socket 也是被认为是文件的一种 window中,需要区分socket和文件 文件描述符:window中叫文件句柄:可以理解成分配的ID socket经过创建的过程中才会被分配文件描 ...

  9. socket与文件描述符

    在Linux编程时,无论是在操作文件还是网络操作时都能够通过文件描述符来read或者write.之前在没有接触C++的时候,不懂面向对象的那套东西.自从学习了C++以及面向对象的一些知识以后突然对Li ...

最新文章

  1. Android 弱引用 (WeakReference)的使用
  2. 点滴印象中的周其凤校长
  3. Linux CPU信息
  4. Config Sharepoint 2013 Workflow PowerShell Cmdlet
  5. JSTL标签显示动态控件
  6. 连接MongoDB 3.x 报 Authorization failed 解决办法(创建账号的部分亲测)
  7. crtmpserver 配置说明_crtmpserver流媒体服务器的介绍与搭建
  8. spark BlockManager如何实现shuffle
  9. springcloud工作笔记101---强大的代码自动提示工具_aiXcoder智能编程_以及开源java工具大全_提升开发效率
  10. [草稿]尝试从 same.com 的视角观察简书的用户社交网络
  11. Java 并发编程实战 -- 常见概念
  12. 小米2s自带rec刷root_关于vivo手机的root
  13. Chapter 1 贝叶斯推断的思想
  14. 恶意代码分析实战_实验练习
  15. 【3D建模制作技巧分享】用3dsmax制作炫酷的机器人模型
  16. 国际学术论文写作与发表 期末考试
  17. 4、隐私计算--可信计算
  18. oracle避免回表,请教大家: 经常在sql调优过程中提到避免“回表”,具体是指什么意思???3Q...
  19. inet_aton、inet_addr、inet_ntoa、inet_pton、inet_ntop
  20. IMX6开发板支持Android|Linux + Qt|Ubuntu|Debian|Youcto系统

热门文章

  1. 从实际蹲坑中涨姿势之——彻底搞懂Mysql事务隔离级别
  2. Java实现数组反转翻转的方法
  3. 定速巡航指示灯一直闪_定速巡航关不了怎么办 这些应急操作要学会
  4. 仿糯米弹框效果demo
  5. ASP.netCore 笔记整理(自用)
  6. 用js方法实现随机颜色tag标签
  7. 用java实现字符串的部分应用
  8. 尽管存在 DDoS 攻击,但不要放弃 Dyn 或 DNS 服务提供商
  9. GSM模块信号强度CSQ与RSSI的对应关系,新增android的ASU值
  10. 密码学:密码算法分析(对称密码学)