1. 问题背景: tcp是以流动的方式传输数据,没有边界的一段数据。像打开自来水管一样,连成一片,没有边界。传输的最小单位为一个报 文段(segment)。tcp Header中有个Options标识位,常见的标识为mss(Maximum Segment Size)指的是:连接层每次传输的数据有个最 ...
分类:
其他好文 时间:
2020-02-14 01:11:07
阅读次数:
91
可以参考原帖:https://blog.csdn.net/u010643777/article/details/79503343 以下是问题描述,以及自己的理解,依据的链接也会提供出来: 问题描述: 有个问题,困扰我很久,在tcp传输中,应用层的数据大于MTU,则TCP需要进行分段传输,假设一段应用 ...
分类:
其他好文 时间:
2020-02-13 19:16:21
阅读次数:
79
server import jsonimport structimport socket# 接收sk = socket.socket()sk.bind(('127.0.0.1',9001))sk.listen()conn,_ =sk.accept()msg_len = conn.recv(4)dic ...
分类:
编程语言 时间:
2020-02-04 22:02:24
阅读次数:
82
# 服务端 import socketimport subprocessimport structimport json servers = socket.socket(family=socket.AF_INET, type=socket.SOCK_STREAM)servers.bind(('127 ...
分类:
其他好文 时间:
2020-02-02 21:25:03
阅读次数:
84
################## Python语法基础 ####################### Linux操作系统 操作系统,可以直接认为是linux,毕竟搞后端的多数是和linux打交道。 1. tcp/udp的区别?tcp粘包是怎么回事,如何处理?udp有粘包吗? TCP/UDP, ...
分类:
编程语言 时间:
2020-01-22 16:10:48
阅读次数:
82
1、什么是 tcp 粘包? 发送方发送的多个数据包,到接收方缓冲区首尾相连,粘成一包,被接收。 2、原因 TCP 协议默认使用 Nagle 算法可能会把多个数据包一次发送到接收方。 应用程读取缓存中的数据包的速度小于接收数据包的速度,缓存中的多个数据包会被应用程序当成一个包一次读取。 3、处理方法 ...
分类:
其他好文 时间:
2019-12-24 11:48:39
阅读次数:
70
tcp传输的数据是以流的形式传输的,因此就没有办法判断到哪里结束算是自己的一个消息,这样就会出现粘包问题,多个包粘在一起了 可以使用这样一个自定义的形式来解决,一个消息分为 head+body head包括数据的长度和数据编号 , 长度和编号都是uint32类型 也就是32位 占有4个字节 , 总共 ...
分类:
其他好文 时间:
2019-12-18 00:08:16
阅读次数:
99
C/C++ socket编程教程之九:TCP的粘包问题以及数据的无边界性 C/C++ socket编程教程之九:TCP的粘包问题以及数据的无边界性 C/C++ socket编程教程之九:TCP的粘包问题以及数据的无边界性 C/C++ socket编程教程之九:TCP的粘包问题以及数据的无边界性 上节 ...
分类:
编程语言 时间:
2019-12-16 19:39:48
阅读次数:
196
关于TCP粘包和拆包的终极解答 程序员行业有一些奇怪的错误的观点(误解),这些误解非常之流行,而且持有这些错误观点的人经常言之凿凿,打死也不相信自己有错,实在让人啼笑皆非。究其原因,还是因为这些错误观点所对应的正确观点不符合人的正常思维习惯,是扭曲人的直观感受的。 有两个错误观点非常之经典,一而再, ...
分类:
其他好文 时间:
2019-12-16 19:00:51
阅读次数:
80
抽象网络设备的原理及使用 Linux 抽象网络设备简介 和磁盘设备类似,Linux 用户想要使用网络功能,不能通过直接操作硬件完成,而需要直接或间接的操作一个 Linux 为我们抽象出来的设备,既通用的 Linux 网络设备来完成。一个常见的情况是,系统里装有一个硬件网卡,Linux 会在系统里为其 ...
分类:
系统相关 时间:
2019-12-16 13:20:10
阅读次数:
88