OpenEdv-开源电子网

 找回密码
 立即注册

扫一扫,访问微社区

正点原子新作:阿波罗STM32F767&F429&探索者STM32F4开发板&赶快来下载资料哦。

查看: 107|回复: 5

SIM800C接收数据异常,两个数据包接收成一个

[复制链接]

  离线 

3

主题

7

帖子

0

精华

新手上路

Rank: 1

积分
29
金钱
29
注册时间
2017-7-17
在线时间
7 小时
发表于 2017-10-19 09:26:33 | 显示全部楼层 |阅读模式
15金钱
我现在用GPRS做一个网关,昨天和服务器测试的时候,发现这样一个情况:有时候服务器连续下发的两个数据包被接收成一个,我刚开始以为是我MCU串口接收的问题,但是GPRS回传的数据包长度+IPD字段确实表明是GPRS接收的问题。服务器侧把两个数据包时间间隔改成了1.5S稍微好点了,但还是会出现这种情况。不知道大家有没有遇到过这个问题啊,有没有什么解决办法呢?

回复

使用道具 举报

  离线 

8

主题

687

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1664
金钱
1664
注册时间
2011-5-23
在线时间
708 小时
发表于 2017-10-19 09:40:14 | 显示全部楼层
TCP是流式的,除了协议栈会自动拼拆,中间的路由也可能会拼拆。
所以,只能保证最终收到的数据不乱不丢,你所希望的“包”这个概念是没有的。
回复

使用道具 举报

  离线 

3

主题

7

帖子

0

精华

新手上路

Rank: 1

积分
29
金钱
29
注册时间
2017-7-17
在线时间
7 小时
 楼主| 发表于 2017-10-19 10:13:42 | 显示全部楼层
数据包应用端不是按照PACK包发送接收的么,TCP协议栈也应该一个包一个包处理啊,怎么会在中间拼接我的东西呢。有什么办法避免这个问题吗,服务器那边数据包间隔已近改到1.5S了
回复

使用道具 举报

  离线 

8

主题

687

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1664
金钱
1664
注册时间
2011-5-23
在线时间
708 小时
发表于 2017-10-19 10:24:53 | 显示全部楼层
无法避免,原始设计就是这样。
可以打开 tcp_nodelay 会好一些,实时性也上去一些,但性能下降。
但依然无法避免,应用协议上必须要支持流式解析。
在慢速网络上,肯定会有自动粘包的。
回复

使用道具 举报

  离线 

3

主题

7

帖子

0

精华

新手上路

Rank: 1

积分
29
金钱
29
注册时间
2017-7-17
在线时间
7 小时
 楼主| 发表于 2017-10-19 11:17:02 | 显示全部楼层
aozima 发表于 2017-10-19 10:24
无法避免,原始设计就是这样。
可以打开 tcp_nodelay 会好一些,实时性也上去一些,但性能下降。
但依然 ...

这么悲剧,就是说我要在MCU上面判断一个包头和包尾吗?
回复

使用道具 举报

  离线 

8

主题

687

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1664
金钱
1664
注册时间
2011-5-23
在线时间
708 小时
发表于 2017-10-19 16:53:06 | 显示全部楼层
candylife9 发表于 2017-10-19 11:17
这么悲剧,就是说我要在MCU上面判断一个包头和包尾吗?

用MQTT之类的现成协议就好了
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则




QQ|联系我们|手机版|官方淘宝店|新浪微博|微信公众平台|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2017-11-22 01:27

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表
/* */