Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
webnet
webnet使用浏览器刷新异常问题
发布于 2019-10-14 16:44:47 浏览:2279
订阅该版
项目背景:STM32F103RE 64K Ram. 512k ROM。 现在计划在产品中加入网页功能,使用USB虚拟网卡,rndis。使用ROMFS做文件系统。LWIP做网络协议栈。因为资源紧张,所以对原有的配置做了适当的裁剪。 目前网页功能可以正常使用,可以访问页面及cgi请求。 版本信息: ``` - RT - Thread Operating System / | \ 4.0.2 build Oct 14 2019 RT-Thread webnet package (V2.0.0) initialize success. ``` 异常情况:调试初期发现用浏览器刷新页面,经常打不开,偶尔成功几次,而且等待时间很长。 后面测试发现,用postman工具多次请求正常。用浏览器请求,几次后失败,然后等待一段时间之后又正常。 LWIP配置: ```c #define RT_MEMP_NUM_NETCONN 8 #define RT_LWIP_PBUF_NUM 8 #define RT_LWIP_RAW_PCB_NUM 4 #define RT_LWIP_UDP_PCB_NUM 4 #define RT_LWIP_TCP_PCB_NUM 4 #define RT_LWIP_TCP_SEG_NUM 10 #define RT_LWIP_TCP_SND_BUF 1024 #define RT_LWIP_TCP_WND 1024 #define RT_LWIP_TCPTHREAD_PRIORITY 10 #define RT_LWIP_TCPTHREAD_MBOX_SIZE 8 #define RT_LWIP_TCPTHREAD_STACKSIZE 2048 #define RT_LWIP_ETHTHREAD_PRIORITY 12 #define RT_LWIP_ETHTHREAD_STACKSIZE 1024 #define RT_LWIP_ETHTHREAD_MBOX_SIZE 8 #define LWIP_NETIF_STATUS_CALLBACK 1 ``` webnet配置: ```c #define PKG_USING_WEBNET #define WEBNET_PORT 80 #define WEBNET_CONN_MAX 1 #define WEBNET_ROOT "/webnet" #define WEBNET_USING_LOG #define WEBNET_USING_AUTH #define WEBNET_USING_CGI #define WEBNET_USING_ASP #define WEBNET_USING_SSI #define WEBNET_USING_INDEX #define WEBNET_USING_ALIAS #define WEBNET_USING_UPLOAD #define WEBNET_CACHE_LEVEL 2 #define WEBNET_CACHE_MAX_AGE 1800 #define WEBNET_USING_SAMPLES #define PKG_USING_WEBNET_V201 ``` buffer:1K 堆栈:2K 后使用memtrace工具,发现,用浏览器请求过程中,webnet会分配多个对话,并且没有释放。 ``` [0x2000e720 - 1K] webn [0x2000eb60 - 32] webn [0x2000eb90 - 256] webn [0x2000eca0 - 36] webn [0x2000ecd4 - 20] [0x2000ecf8 - 20] webn [0x2000ed1c - 48] [0x2000ed5c - 96] webn [0x2000edcc - 356] [0x2000ef40 - 32] webn [0x2000ef70 - 32] webn [0x2000efa0 - 100] [0x2000f014 - 32] webn [0x2000f044 - 32] webn [0x2000f074 - 32] webn [0x2000f0a4 - 48] [0x2000f0e4 - 32] webn [0x2000f114 - 32] webn [0x2000f144 - 32] webn [0x2000f174 - 40] webn [0x2000f1ac - 32] webn [0x2000f1dc - 40] webn [0x2000f214 - 32] webn [0x2000f244 - 32] webn [0x2000f274 - 32] webn [0x2000f2a4 - 136] [0x2000f33c - 32] webn [0x2000f36c - 1K] webn [0x2000f7ac - 380] [0x2000f938 - 32] webn [0x2000f968 - 1K] webn [0x2000fda8 - 568] msh />list_webnet #0 client 192.168.10.2:56862 #1 client 192.168.10.2:56861 #2 client 192.168.10.2:56856 path: /webnet/demo.html ``` 从日志现象来看,应该是web服务器一直在被访问某个接口,并且一直没有被释放掉,导致多次请求之后,内存空间不够, 请求失败(配置中设置最多只有一个链接,但是还是会有多个请求)。 后来观测发现,经过比较长的时间之后,约几分钟,原先一直在连接又被释放掉,回复正常。 具体回话没有断开的 问题还未找到。 使用过程中还有以下的未知异常请求: 第一次插入USB线时,会多次请求(浏览器未打开): ``` [D/wn.log] new client: 192.168.10.2:61817 [D/wn.log] method: GET [D/wn.log] request: / [D/wn.log] physical url: /webnet/index.html [D/wn.log] mime type: text/html ``` 第一次请求IP地址时(访问源码自带的例子): ``` [D/wn.log] new client: 192.168.10.2:62085 [D/wn.log] method: GET [D/wn.log] request: /favicon.ico [D/wn.log] physical url: /webnet/favicon.ico [D/wn.log] mime type: application/binary ``` 有做过的大神可以指点一下下。
查看更多
3
个回答
默认排序
按发布时间排序
WKJay
认证专家
2019-10-14
wkjay.com
内存不够很容易出现楼主的问题,具体可参照下帖 [https://www.rt-thread.org/qa/thread-10723-1-1.html](WebNet是否不适合比较复杂的网页开发)
aozima
2019-10-14
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
浏览器按F12,切到网络这一列,可以看到哪些链接断了。 TCP这边的数据可能开大些,webnet里面的同时连接数要小些。不然就会有死链。
huo
2019-10-14
这家伙很懒,什么也没写!
>浏览器按F12,切到网络这一列,可以看到哪些链接断了。 > >TCP这边的数据可能开大些,webnet里面的同时连接数 ... --- WEBNET_CONN_MAX配置中这个宏设置同时最大的连接数,我看着工程中只有一个地方用到了, ```c if (listen(listenfd, WEBNET_CONN_MAX) == -1) { LOG_E("Socket listen(%d) failed.", WEBNET_CONN_MAX); goto __exit; } ``` 就是代码中只限定同时连接的socket。但是session并没有做限定。 假如特殊情况socket断开,session并没有释放,这个时候新的连接进来,就会创建新的session,资源就越来越少了,这应该算个bug。
撰写答案
登录
注册新账号
关注者
0
被浏览
2.3k
关于作者
huo
这家伙很懒,什么也没写!
提问
2
回答
4
被采纳
0
关注TA
发私信
相关问题
1
webnet heap最大使用量。
2
webnet 是否可以做全动态网页,使用内存池来加快速度
3
webnet导致的页面被挂起的根本原因探讨
4
软件包WebNet示例说明配图不对
5
webnet如何接收客户端post的大量数据
6
webserver的html跳转问题
7
WebDAV上传.shtml文件和.asp文件时出错
8
rt-thread 3.0 lts如何使用webnet
9
MCU探索版+RT_Thread+Webnet的疑问
10
STM32F407+Webnet+TCPServer的问题
推荐文章
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
【NXP-MCXA153】 定时器驱动移植
2
GD32F450 看门狗驱动适配
3
【NXP-MCXA153】看门狗驱动移植
4
RT-Thread Studio V2.2.9 Release Note
5
CherryUSB的bootuf2配置
热门标签
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
UART
WIZnet_W5500
ota在线升级
PWM
freemodbus
flash
cubemx
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
编译报错
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
踩姑娘的小蘑菇
7
个答案
2
次被采纳
a1012112796
15
个答案
1
次被采纳
Ryan_CW
5
个答案
1
次被采纳
红枫
4
个答案
1
次被采纳
张世争
4
个答案
1
次被采纳
本月文章贡献
YZRD
3
篇文章
6
次点赞
catcatbing
3
篇文章
6
次点赞
lizimu
2
篇文章
8
次点赞
qq1078249029
2
篇文章
2
次点赞
xnosky
2
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部