加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

UNIX网络编程卷1:应用进程写数据到一个TCP套接字中发生的事情

发布时间:2020-12-15 16:46:26 所属栏目:安全 来源:网络整理
导读:1.每一个TCP套接字都有一个发送缓冲区,可以使用 SO_SNDBUF 套接字选项来 更改该缓冲区,当使用netstat查看时可以看到 Send-Q即是一个tcp套接字的发送缓冲区,采取队列结构 2.当某个应用进程调用write,内核从该进程的缓冲区复制所有数据到所写套接字的发送

1.每一个TCP套接字都有一个发送缓冲区,可以使用SO_SNDBUF套接字选项来更改该缓冲区,当使用netstat查看时可以看到


Send-Q即是一个tcp套接字的发送缓冲区,采取队列结构


2.当某个应用进程调用write,内核从该进程的缓冲区复制所有数据到所写套接字的发送缓冲区。

  • 此时从用户态(用户进程调用write)切换到内核态(write执行过程,数据在缓冲区之间的复制)
  • 若套接字的发送缓冲区容不下该应用进程的所有数据,在套接字具有阻塞属性(默认设置)的情况下,应用进程投入睡眠
  • 直到应用进程缓冲区所有数据都复制到套接字缓冲区,write系统调用才返回。
  • write调用成功返回并不能说明对端tcp或应用进程已经接收到数据。只能说明我们把数据成功复制到套接字的发送缓冲区,应用进程的缓冲区可以重新使用了

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读