在前几篇文章中,我们先从宏观角度(TCP 概述)大致介绍了 tcp 的概念,然后从微观角度(滑动窗口、拥塞窗口等)详细说明了从 client 端和 server 端,tcp 是如何进行网络控制的。在本文中,我们将通过一个 tcp 例子,将整个过程联...
我们基本上从宏观角度描述了,应用层是如何构建通信消息、查询服务端IP地址的。今天,我们着重讲讲,在客户端准备好通信消息后,是如何委托OS的协议栈进行后续的处理。也就是,Socket如何处理从客户端拿到数据,并将其转发到协议...
FIN_WAIT_1 : FIN_WAIT_1和FIN_WAIT_2状态的真正含义都是表示等待对方的FIN报文。而这两种状态的区别是: FIN_WAIT_1状态实际上是当SOCKET在ESTABLISHED状态时,它想主动关闭连接,向对方发送了FIN报文,此时该SOCKET即进入...
之前写过几篇在线协作相关的文章,如何实现多人协作的在线文档,在线Excel存储方案,如何实现在线Excel多人协作,在线协作如何保证消息有序、不丢、不重,今天继续和大家一起探讨在线协作系统的总体架构。我们这里说的在线协...
多个用户同时操作一个Excel文件。 场景中的实体有:用户、Excel。其中用户又分为「拥有者」、「阅读者」、「协作者」拥有者:创建Excel的用户阅读者:可以查看Excel的用户协作者:可以编辑Excel内容的用户...
WebSocket是为了解决服务端和客户端双向通讯问题,提出的一种传输协议,使客户端和服务端可以互相推送、接收消息,做到真正的双工。
统计在一台前端机上高峰时间TCP连接的情况,统计命令:netstat -n | awk ‘/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}’
Kafka是一种消息队列,主要用来处理大量数据状态下的消息队列,一般用来做日志的处理。既然是消息队列,那么Kafka也就拥有消息队列的相应的特性了。...
Netstat是控制台命令,是一个监控TCP/IP网络的非常有用的工具,它可以显示路由表、实际的网络连接以及每一个网络接口设备的状态信息。Netstat用于显示与IP、TCP、UDP和ICMP协议相关的统计数据,一般用于检验本机各端口的...
当服务器close一个连接时,若client端接着发数据。根据TCP协议的规定,会收到一个RST响应,client再往这个服务器发送数据时,系统会发出一个SIGPIPE信号给进程,告诉进程这个连接已经断开了,不要再写了。...