errdump_read.lua 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. --[[
  2. @module errdump_read
  3. @summary errdump手动读取功能模块
  4. @version 1.0
  5. @date 2025.09.05
  6. @author 孟伟
  7. @usage
  8. 本功能模块演示的内容为:
  9. 手动读取异常日志,通过消息"ERRDUMP_DATA_SEND_UART"发布出去通知串口接收进行处理,
  10. 通过消息"SEND_DATA_REQ"发布出去通知tcp接收进行处理。
  11. 如果是系统异常日志,则会在重启后手动读取上报,用户写入的调试日志则需要手动读取上报。
  12. 注意:用户写入的调试日志只能手动读取上报,不能自动上报。
  13. ]]
  14. --加载uart模块
  15. require "uart_app"
  16. --加载tcp主应用模块
  17. require "tcp_client_main"
  18. local function test_user_log()
  19. -- 下面演示手动获取异常日志信息,手动读取到异常日志可以上报到自己服务器
  20. errDump.config(true, 0) --配置为手动读取,如果配置为自动上报将无法手动读取系统异常日志
  21. local err_buff = zbuff.create(4096)
  22. local new_flag = errDump.dump(err_buff, errDump.TYPE_SYS) -- 开机手动读取一次系统异常日志
  23. if err_buff:used() > 0 then
  24. -- log.info(err_buff:toStr(0, err_buff:used())) -- 打印出异常日志
  25. -- 将数据data通过"ERRDUMP_DATA_SEND_UART"消息publish给串口发送出去
  26. sys.publish("ERRDUMP_DATA_SEND_UART", err_buff:toStr(0, err_buff:used()))
  27. -- 将读取到的系统异常日志通过"SEND_DATA_REQ"消息publish给tcp发送出去
  28. sys.publish("SEND_DATA_REQ", err_buff:toStr(0, err_buff:used()))
  29. end
  30. --手动读取的话需要手动删除日志,否则下次读取会继续读取上次的日志
  31. -- errDump.dumpf返回值:true表示本次读取前并没有写入数据,false反之,在删除日志前,最好再读一下确保没有新的数据写入了
  32. new_flag = errDump.dump(err_buff, errDump.TYPE_SYS)
  33. if not new_flag then
  34. log.info("没有新数据了,删除系统错误日志")
  35. errDump.dump(nil, errDump.TYPE_SYS, true)
  36. end
  37. -- 开机读取完系统异常日志后循环读取用户调试日志
  38. while true do
  39. local new_flag = errDump.dump(err_buff, errDump.TYPE_USR)
  40. if new_flag then
  41. log.info("errBuff", err_buff:toStr(0, err_buff:used()))
  42. -- 将数据data通过"ERRDUMP_DATA_SEND_UART"消息publish给串口发送出去
  43. sys.publish("ERRDUMP_DATA_SEND_UART", err_buff:toStr(0, err_buff:used()))
  44. -- 将读取到的用户调试日志通过"SEND_DATA_REQ"消息publish给tcp发送出去
  45. sys.publish("SEND_DATA_REQ", err_buff:toStr(0, err_buff:used()))
  46. end
  47. new_flag = errDump.dump(err_buff, errDump.TYPE_USR)
  48. if not new_flag then
  49. log.info("没有新数据了,删除用户调试日志")
  50. errDump.dump(nil, errDump.TYPE_USR, true)
  51. end
  52. sys.wait(15000)
  53. errDump.record("测试一下用户的调试日志记录功能") --写入用户的调试日志,注意最大只有4KB,超过部分新的覆盖旧的
  54. end
  55. end
  56. local function test_error_log() --故意写错用来触发系统异常日志记录
  57. sys.wait(60000)
  58. --故意写错代码死机
  59. lllllllllog.info("此处使用一个不存在的库文件,导致出现异常")
  60. end
  61. sys.taskInit(test_user_log) -- 启动errdemp测试任务
  62. sys.taskInit(test_error_log) --启动错误函数任务