websocket 粘包问题_websocket数据过大

websocket 粘包问题_websocket数据过大websocket 底层使用的tcp 协议。 当一次发送数据过长时,tcp 会把数据封成多个包发送;同样当数据过短时,会把数据合并成一个包发送,这种现象就是粘包。粘包的情况也有可能是接收端造成的。[参考]( http://m.blog.csdn.net/duotemplar/article/details/73193038).tcp协议相关的知识百度之。 粘包出现必然对应拆包处理。处理

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

 
websocket 底层使用的tcp 协议。 当一次发送数据过长时,tcp 会把数据封成多个包发送;同样当数据过短时,
会把数据合并成一个包发送,这种现象就是粘包。粘包的情况也有可能是接收端造成的。[参考] ( 
websocket 粘包问题_websocket数据过大http://m.blog.csdn.net/duotemplar/article/details/73193038 ).
tcp协议相关的知识百度之。 粘包出现必然对应拆包处理。处理方案:

eg: 现在通过websocket传输: A 数据, B数据 (只讨论粘包的情况) 


i 接收(应用层)AB数据


根据数据的帧信息,先解析A数据,然后解析B数据

ii 接收AB1、B2(B数据分成B1,B2)

解析A数据;根据B1的帧信息(包含数据是否完整、数据长度、数据类型等)可以判断不是完整数据,缓存B1数据;


继续接收数据B2,然后解析B1B2数据(不包含B1、B2的帧信息);

iii 接收A1、A2B (A数据分成A1,A2)

根据A1的帧信息可以判断不是完整数据,缓存A1数据;继续接收A2B数据,解析A1A2数据;然后解析B数据

iv 接收A1、A2B1、B2(A数据分成A1,A2 B数据分B1,B2)

缓存A1;解析A1A2;缓存B1;解析B1B2。


       
       以上只是大致的一个处理思路,实际代码中情况要复杂一些。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/169704.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月11日 上午9:16
下一篇 2022年8月11日 上午9:16


相关推荐

  • anaconda卸载方法

    anaconda卸载方法卸载anaconda

    2022年6月15日
    86
  • 备份数据库表结构_sql备份表和恢复表

    备份数据库表结构_sql备份表和恢复表##================================================================##需求场景:由于MySQL没有类似于SQLSERVER那样的系统表来存放备份记录,且大规模的MySQL服务器需要集中管理和查看。服务器出现性能问题或复制延迟时,需要先判断是否由数据备份引起。##===========================…

    2025年11月14日
    3
  • 在线navicat16 激活码 键[在线序列号]

    在线navicat16 激活码 键[在线序列号],https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月18日
    2.0K
  • SQL命令之FROM子句

    SQL命令之FROM子句nbsp nbsp nbsp nbsp nbsp nbsp nbsp FROM 子句指定 SELECT 语句查询及与查询相关的表或视图 在 FROM 子句中最多可指定 256 个表或视图 之间用逗号分隔 nbsp nbsp nbsp nbsp nbsp nbsp nbsp 在 FROM 子句同时指定多个表或视图时 如果选择列表中存在同名列 这时应使用对象名限定这些列所属的表或视图 amp

    2025年11月8日
    3
  • redis面试题目_Redis面试题

    redis面试题目_Redis面试题面试题:2018最全Redis面试题整理

    2022年4月21日
    66
  • MySQL(笔记)

    MySQL(笔记)数据库总览有时候查的数据错乱,可以重启MySQL关系型数据库(SQL)MySQL,Oracle,SQLServer,SQLite,DB2,…关系型数据库通过外键关联来建立表与表之间的关系非关系型数据库(NOSQL)notonlyRedis,MongoDB,…非关系型数据库通常指数据以对象的形式存储在数据库中,而对象之间的关系通过每个对象自身的属性来决定DBMS数据库管理系统(DataBaseManagementSystem)数

    2022年5月19日
    36

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号