专栏首页极客猴一道关于 TCP 连接的题目

一道关于 TCP 连接的题目

题图:by _seo_hanbit from Instagram

某天傍晚,小陈和他的组长在食堂吃完晚饭后,他们俩慢悠悠地走回公司。

在路上,组长蓦然对小陈问道:你对 TCP 协议熟悉吗?

小陈点了点头表示很熟悉,然后一口气将 TCP 连接中三次握手和四次分手详细地说了一遍。心想暗笑,这问题难不倒我的,哈哈。

但组长只是微微一笑,继续问到:你知道在建立 Socket 连接的最开始1 秒,客户端发送了多大的数据吗

小陈听后,瞬间一脸懵逼, 久久说不出话来。

组长看到小陈这样子,只是会心一笑。拍拍他的肩膀跟他说,有空去读读《TCP/IP详解卷1:协议》,对你深入理解 TCP 协议有多帮助。

小陈是个不服输的人。回到公司后,他一个人静静坐在电脑前思考。面向 Socket 编程,是对 TCP/IP 协议的封装和应用。建立 TCP 连接是三次握手, 那么整个 TCP 连接建立过程,客户端只两次向服务器发送的数据包。这两个数据包的总大小应该是大小了。

怎么才能获取这两个数据库的大小呢? 突然他想到用抓包的方式。

他用启动 Wireshark 来抓包,以下是他捕获一个完整 TCP 连接的图。

1) 第一次发送是第一次握手,客户端发送 SYN 到服务器,并进入 SYN_SENT 状态。第一次握手详细信息图如下:

从图中可知第一次是发送的数据包是 32 字节

2)第二次发送数据是第三次握手,客户端收到 SYN+ACK 包,向服务器发送确认 ACK包,客户端进入 ESTABLISHED 状态,服务器收到请求后也进入 ESTABLISHED 状态,完成三次握手,此时 TCP 连接成功,客户端与服务器开始传送数据。第三次握手详细信息图如下:

因此,第三次是发送的数据包大小是 20 字节

综上所述:在建立 Socket 连接的最开始1 秒,客户端一共发送了 32 + 20 = 52字节

于是,小陈跑到组长的卡座上,跟他说下......

以上故事纯属虚构,但是内容是真实的。是自己研究 TCP 协议中,在阅读《TCP/IP详解卷1:协议》的过程中,还是云里雾里的。所以通过抓包的方式来加深理解。如果说错的地方,请帮忙指出,另外轻喷。

写在最后,我新建一个 Python Web 学习交流 QQ 群,群号:701534112。或者长按以下二维码加群。欢迎大家加群,一起交流学习,一起进步。

本文分享自微信公众号 - 极客猴(Geek_monkey)

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2018-03-08

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 用PhantomJS来给AJAX站点做SEO优化

    众所周知,大部分的搜索引擎爬虫都不会执行JS,也就是说,如果页面内容由Ajax返回的话,搜索引擎是爬取不到部分内容的,也就无从做SEO了。

    libo1106
  • OS X 开发:打开文件面板NSOpenPanel应用

          在Mac桌面软件开发中,如果涉及到对文件的操作,无论是新建文件还是选择或读取文件,都离不开文件路径的定位,NSOpenPanel类提供了简洁的文件选...

    珲少
  • 一周播报| 易燃易爆炸,最让程序员掉发的3个需求!

    说起产品,很多技术人都爱恨交织。明明是相依为命的关系,却总是因为“需求”而忍不住mmp。

    养码场
  • 前后端分离Nuxt.js解决SEO问题

    背景:由于后端程序猿通常对CSS 、JS掌握不是特别好,通常的开发模式,UI把静态html做好交给程序猿,程序猿开发,把静态html变成动态的时候经常会有各种样...

    小尘哥
  • 互联网思维的18条法则

    成功的互联网产品多抓住了“屌丝群体”、“草根一族”的需求。这是一个人人自称“屌丝”而骨子里认为自己是“高富帅”和“白富美”的时代。当你的产品不能让用户成为产品的...

    华章科技
  • 构建用于生产的React静态化单页面服务 原

    React 作为一项热门的前端开发技术,现在使用它的团队越来越多。之前也介绍了react 的所有的特性,但是仅仅了解怎么开发 react 只走了万里长征的第一步...

    随风溜达的向日葵
  • 汇桔宝时代:重新定义互联网营销与流量格局!

    在这个流量为王的时代,酒香也怕巷子深!时代在变,那个靠口口相传来获客盈利的年代已经一去不复返。如今,不会运营推广几乎意味着死路一条。

    汇桔宝官方账号
  • nodejs作为前后端分离中间件的跨域解决方案

    前后端分离时候SEO问题很头疼,上次提供了nuxt+axios解决服务端渲染问题的解决方案,其实nodejs一样可以做服务端渲染,这时候会产生ajax跨域问题,...

    小尘哥
  • Yoast SEO和Crayon Syntax Highlighter冲突

    libo1106
  • React前后端同构防止重复渲染 原

    为了解决某些问题(比如SEO、提升渲染速度等)react 提供了2个方法在服务端生成一个HTML文本格式的字符串。在得到了这个HTML格式的字符串之后,通常会将...

    随风溜达的向日葵

扫码关注云+社区

领取腾讯云代金券