Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
easyflash
flashDB
flashDB / Easyflash 触发GC 导致系统卡死的解决方法分享
发布于 2022-11-19 10:46:50 浏览:2007
订阅该版
[tocm] # flashDB / Easyflash 触发GC 导致系统卡死的解决方法分享 ## 使用情况 - 芯片:SMT32F429 - 操作系统:RTT 5.0.0 - 文件系统:littlefs + romfs - flashdb:kvdb + 文件模式 使用 ## 使用场景 ### 分配5个扇区情况 - 创建一个线程,1秒写入一次当前时间戳至kvdb数据库中 - 发现如果分配五个扇区,前四个扇区都可以正常读写。 - 当五个扇区都写满的时候,需要搬运数据到第0扇区去。 日志如下,没有空扇区了。 ```shell The remain empty sector is 1, GC threshold is 1. ``` - 这个日志已出现,系统就会卡死,看门狗复位 - 尝试debug调试,总是调到没有使用的函数里面,函数地址0x00000xx开头。 ### 解决方法 - 经过不断尝试,ps打印当前线程状态时,发现时间戳保存线程的最大使用率高达81%.一般来说都要控制在75%左右合适。 - 分析是不是应该堆栈不够导致系统卡死 - 将该线程从2048改为4096后,不会出现卡死问题了。线程的最大使用率变为51% ### 分析 - flshdb在扇区都满的情况下,会进行Collect操作。这个操作是在当前线程完成的,会增加占用率。 - 然而这个运行操作并不是会频繁出现的,所以很难判断到是堆栈不够导致的问题。 ### 建议 - 能否增加一个异步模式来专门执行gc与Collect操作? - 就像ulog的异步线程的方式那样。 - 写入数据库并不要求实时性,只需要确保数据的准确就好了。 - 异步方式需要一个缓冲区,缓冲区满了才能传入数据,可能导致缓冲区未满时掉电,导致数据缺失了一部分。 - 但是这个情况,可以添加一个函数,立刻刷新缓冲区。然后给用户使用。 用户自己实现掉电保存与硬件。所以可以增加一个异步线程的选项,提供用户使用。看用户是选择实时,还是效率
0
条评论
默认排序
按发布时间排序
登录
注册新账号
关于作者
用户名由3_15位
这家伙很懒,什么也没写!
文章
5
回答
232
被采纳
33
关注TA
发私信
相关文章
1
easyflash 用来存储 传感器定时采样的数据适不适合?
2
easyflash存放于fat文件系统中,但是会擦除文件系统
3
EasyFlash移植失败,硬件发生错误?
4
easyflash demo擦写完数据后再上电就挂了?
5
easyflash初始化env无法自动写入默认环境变量?
6
有在STM32L4上用easyflash的么?请教个问题
7
[已解决] easyflash 使用内部 flash 无法保存参数
8
FAL 上的FlashDB、EasyFlash、EasyLogger调试经历
9
easyflash存储问题
10
easyflash可以用来存储300个小文件且能够按照日期分类检索吗?
推荐文章
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组件
热门标签
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
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
次点赞
回到
顶部
发布
问题
投诉
建议
回到
底部