Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
at_device
MQTT
MQTT + AT device 掉线无法重连(IP解析错误)
发布于 2021-04-21 19:51:09 浏览:1425
订阅该版
这个问题出现了几天了,原本以为是ESP8266的问题,后来换了SIM800c也是一样的现象。 这里给出ESP8266的log,请熟悉的大佬帮我看看是啥问题。 平台是STM32L476,LPUART1,115200, RTT 4.0.3, AT Device是latest LOG 里面第1332行开始,之后就不正常了。1332行本身也是有问题 [esp8266.log](https://oss-club.rt-thread.org/uploads/20210421/99ae2729cec31003a3d630ec1510e3bf.log) 我分析的过程如下 1332 之后的,发送close socket,超时返回 ~~~ [D/AT] sendline: 0000-0020: 41 54 2B 43 49 50 43 4C 4F 53 45 3D 30 AT+CIPCLOSE=0 [D/AT] recvline: 0000-0020: 00 30 2C 43 4C 4F 53 45 44 0D 0A .0,CLOSED.. [D/AT] recvline: 0000-0020: 0D 0A .. [614885] D/at.clnt: execute command (AT+CIPCLOSE=0) timeout (300 ticks)! ~~~ 之后mqtt应该是在新建一个socket ~~~ [D/AT] sendline: 0000-0020: 41 54 2B 43 49 50 44 4F 4D 41 49 4E 3D 22 71 62 65 32 36 62 34 36 2E 65 6E 2E 65 6D 71 78 2E 63 AT+CIPDOMAIN="qbe26b46.en.emqx.c [D/AT] sendline: 0020-0040: 6C 6F 75 64 22 loud" [619885] D/mqtt: inter mqtt_connect_callback! [D/AT] recvline: 0000-0020: 4F 4B 0D 0A OK.. [D/AT] recvline: 0000-0020: 2B 43 49 50 44 4F 4D 41 49 4E 3A 35 34 2E 31 36 36 2E 37 36 2E 31 37 38 0D 0A +CIPDOMAIN:54.166.76.178.. [D/AT] recvline: 0000-0020: 0D 0A .. [D/AT] sendline: 0000-0020: 41 54 2B 43 49 50 44 4F 4D 41 49 4E 3D 22 71 62 65 32 36 62 34 36 2E 65 6E 2E 65 6D 71 78 2E 63 AT+CIPDOMAIN="qbe26b46.en.emqx.c [D/AT] sendline: 0020-0040: 6C 6F 75 64 22 loud" [D/AT] recvline: 0000-0020: 4F 4B 0D 0A OK.. [D/AT] recvline: 0000-0020: 2B 43 49 50 44 4F 4D 41 49 4E 3A 35 34 2E 31 36 36 2E 37 36 2E 31 37 38 0D 0A +CIPDOMAIN:54.166.76.178.. [D/AT] recvline: 0000-0020: 0D 0A .. [D/AT] sendline: 0000-0020: 41 54 2B 43 49 50 44 4F 4D 41 49 4E 3D 22 71 62 65 32 36 62 34 36 2E 65 6E 2E 65 6D 71 78 2E 63 AT+CIPDOMAIN="qbe26b46.en.emqx.c [D/AT] sendline: 0020-0040: 6C 6F 75 64 22 loud" [D/AT] recvline: 0000-0020: 4F 4B 0D 0A OK.. [D/AT] recvline: 0000-0020: 2B 43 49 50 44 4F 4D 41 49 4E 3A 35 34 2E 31 36 36 2E 37 36 2E 31 37 38 0D 0A +CIPDOMAIN:54.166.76.178.. [D/AT] recvline: 0000-0020: 0D 0A .. [D/AT] sendline: 0000-0020: 41 54 2B 43 49 50 44 4F 4D 41 49 4E 3D 22 71 62 65 32 36 62 34 36 2E 65 6E 2E 65 6D 71 78 2E 63 AT+CIPDOMAIN="qbe26b46.en.emqx.c [D/AT] sendline: 0020-0040: 6C 6F 75 64 22 loud" [D/AT] recvline: 0000-0020: 4F 4B 0D 0A OK.. [D/AT] recvline: 0000-0020: 2B 43 49 50 44 4F 4D 41 49 4E 3A 35 34 2E 31 36 36 2E 37 36 2E 31 37 38 0D 0A +CIPDOMAIN:54.166.76.178.. [D/AT] recvline: 0000-0020: 0D 0A .. [D/AT] sendline: 0000-0020: 41 54 2B 43 49 50 44 4F 4D 41 49 4E 3D 22 71 62 65 32 36 62 34 36 2E 65 6E 2E 65 6D 71 78 2E 63 AT+CIPDOMAIN="qbe26b46.en.emqx.c [D/AT] sendline: 0020-0040: 6C 6F 75 64 22 loud" [D/AT] recvline: 0000-0020: 4F 4B 0D 0A OK.. [D/AT] recvline: 0000-0020: 2B 43 49 50 44 4F 4D 41 49 4E 3A 35 34 2E 31 36 36 2E 37 36 2E 31 37 38 0D 0A +CIPDOMAIN:54.166.76.178.. [D/AT] recvline: 0000-0020: 0D 0A .. ~~~ **这里IP请求了5次,全部返回了解析,但是下面没用上,解析不成功** 从这里开始IP为0. 很奇怪没有用上上面解析得到的IP地址。 ~~~ [D/AT] sendline: 0000-0020: 41 54 2B 43 49 50 53 54 41 52 54 3D 30 2C 22 54 43 50 22 2C 22 30 2E 30 2E 30 2E 30 22 2C 31 31 AT+CIPSTART=0,"TCP","0.0.0.0",11 [D/AT] sendline: 0020-0040: 35 32 33 2C 36 30 523,60 [D/AT] recvline: 0000-0020: 4F 4B 0D 0A OK.. [D/AT] recvline: 0000-0020: 0D 0A .. [D/AT] recvline: 0000-0020: 45 52 52 4F 52 0D 0A ERROR.. ~~~ 再后面就一直报错了 ~~~ [D/AT] sendline: 0000-0020: 41 54 2B 43 49 50 53 45 4E 44 3D 30 2C 36 30 AT+CIPSEND=0,60 [D/AT] recvline: 0000-0020: 30 2C 43 4C 4F 53 45 44 0D 0A 0,CLOSED.. [D/AT] recvline: 0000-0020: 6C 69 6E 6B 20 69 73 20 6E 6F 74 20 76 61 6C 69 64 0D 0A link is not valid.. [D/AT] recvline: 0000-0020: 0D 0A .. [D/AT] sendline: 0000-0020: 10 3A 00 04 4D 51 54 54 04 CE 00 1E 00 08 51 69 6E 67 37 39 31 31 00 04 74 65 73 74 00 08 47 6F .:..MQTT......Qing7911..test..Go [D/AT] sendline: 0020-0040: 6F 64 62 79 65 21 00 0B 71 69 6E 67 73 74 61 74 69 6F 6E 00 07 71 69 6E 67 31 32 33 odbye!..qingstation..qing123 [634248] E/at.skt.esp: esp0 device socket(0) wait connect result timeout. [634248] E/mqtt: MQTT connect error(-1): UNKNOWN_ERROR. [634248] D/mqtt: inter mqtt_offline_callback! [D/AT] sendline: 0000-0020: 41 54 2B 43 49 50 44 4F 4D 41 49 4E 3D 22 71 62 65 32 36 62 34 36 2E 65 6E 2E 65 6D 71 78 2E 63 AT+CIPDOMAIN="qbe26b46.en.emqx.c [D/AT] sendline: 0020-0040: 6C 6F 75 64 22 loud" [6393[D/AT] recvline: 0000-0020: 45 52 52 4F 52 0D 0A ERROR.. [D/AT] recvline: 0000-0020: 0D 0A .. ~~~ 相关代码是这: https://github.com/RT-Thread-packages/at_device/blob/2878647c0c85f376223f333a87ce05cf0c9a8c98/class/esp8266/at_socket_esp8266.c#L309 这个函数里面 ~~~ static int esp8266_domain_resolve(const char *name, char ip[16]) ~~~ 单步调试,第一次断连的时候,这个地方是可以过的,链接成功恢复。传进来的是IP 第二次断链传进来的就单纯是OK而已 ![image.png](https://oss-club.rt-thread.org/uploads/20210421/2a3684514f19009608636c41c810077a.png) 问题应该找到了,真正的IP是用URC发回来的,AT 设备已经考虑到了,但是没有实现这部分功能。不清楚其他模块是否也是这样? ~~~~ /* parse the third line of response data, get the IP address */ if (at_resp_parse_line_args_by_kw(resp, "+CIPDOMAIN:", "+CIPDOMAIN:%s", recv_ip) < 0) { rt_thread_mdelay(100); /* resolve failed, maybe receive an URC CRLF */ continue; } if (rt_strlen(recv_ip) < 8) { rt_thread_mdelay(100); /* resolve failed, maybe receive an URC CRLF */ continue; } ~~~~ 这是第一次的返回,先返回IP 再返回OK ~~~ [D/AT] sendline: 0000-0020: 41 54 2B 43 49 50 44 4F 4D 41 49 4E 3D 22 71 62 65 32 36 62 34 36 2E 65 6E 2E 65 6D 71 78 2E 63 AT+CIPDOMAIN="qbe26b46.en.emqx.c [D/AT] sendline: 0020-0040: 6C 6F 75 64 22 loud" [D/AT] recvline: 0000-0020: 2B 43 49 50 44 4F 4D 41 49 4E 3A 35 34 2E 31 36 36 2E 37 36 2E 31 37 38 0D 0A +CIPDOMAIN:54.166.76.178.. [D/AT] recvline: 0000-0020: 0D 0A .. [D/AT] recvline: 0000-0020: 4F 4B 0D 0A OK.. ~~~ 这是往后数次的IP resolve,先返回OK,再返回IP ~~~ [D/AT] sendline: 0000-0020: 41 54 2B 43 49 50 44 4F 4D 41 49 4E 3D 22 71 62 65 32 36 62 34 36 2E 65 6E 2E 65 6D 71 78 2E 63 AT+CIPDOMAIN="qbe26b46.en.emqx.c [D/AT] sendline: 0020-0040: 6C 6F 75 64 22 loud" [D/AT] recvline: 0000-0020: 4F 4B 0D 0A OK.. [D/AT] recvline: 0000-0020: 2B 43 49 50 44 4F 4D 41 49 4E 3A 35 34 2E 31 36 36 2E 37 36 2E 31 37 38 0D 0A +CIPDOMAIN:54.166.76.178.. [D/AT] recvline: 0000-0020: 0D 0A .. ~~~
查看更多
4
个回答
默认排序
按发布时间排序
mii
2021-04-22
这家伙很懒,什么也没写!
像这种情况,建议您刷一下ESP8266固件,看看有没有新版本。二是单独调试模组,确认模组会不会重现你所说的情况。
flashman2002
2021-04-22
这家伙很懒,什么也没写!
那就要针对第一次返回还是其它次返回做针对性编程了。
吴梦胜
2021-04-22
这家伙很懒,什么也没写!
我也遇到过相同的问题,是使用ping获取IP一直有问题,后来发现是IP解析上的问题,IP获取把引号也获取了导致转换IP有问题的。把他按URC那边IP解析挪过来就ok了。
majianjia
2021-05-17
这家伙很懒,什么也没写!
问题大概是因为串口接受是用了中断,然后中断速度跟不上,导致有时候多一个少一个字节
撰写答案
登录
注册新账号
关注者
0
被浏览
1.4k
关于作者
majianjia
这家伙很懒,什么也没写!
提问
5
回答
21
被采纳
2
关注TA
发私信
相关问题
1
umqtt 软件包使用后,连接上emqx服务器,过一会儿就掉线了
2
使用正点原子的 潘多拉 开发板 的例程19_iot_mqtt
3
mqtt软件包,不支持直接关闭?
4
kawaii_mqtt 申请内存崩溃
5
_signal_entry() 函数中dbg_enter在哪里定义呢?
6
start to connect mqtt server 失败
7
MQTT 在“ read 0:1, break “后断开重连
8
paho_mqtt线程相关疑问
9
RT thread studio kawaii mqtt 无法连接EMQ
10
调试bc26 ,断言错误failed at rt_thread_timeout
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
恩智浦[FRDM-MCXN947]初探 之 ADC与DAC
2
恩智浦[FRDM-MCXN947]初探 之 ADC&DAC
3
LVGL使用字库IC芯片显示中文
4
基于STM32H750和Rt-Thread的CANFD通信实现的记录(一)
5
freemodbus主机在freertos的适配,参考rtthread例程
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
WIZnet_W5500
UART
ota在线升级
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
SFUD
msh
rt_mq_消息队列_msg_queue
keil_MDK
ulog
MicroPython
C++_cpp
本月问答贡献
出出啊
1517
个答案
342
次被采纳
小小李sunny
1443
个答案
289
次被采纳
张世争
805
个答案
174
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
148
次被采纳
本月文章贡献
出出啊
1
篇文章
4
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
1
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部