返回顶部
首页 > 资讯 > 精选 >小程序中的Log日志系统该如何搭建和使用
  • 346
分享到

小程序中的Log日志系统该如何搭建和使用

2023-06-28 17:06:41 346人浏览 薄情痞子
摘要

这篇文章主要为大家分析了小程序中的Log日志系统该如何搭建和使用的相关知识点,内容详细易懂,操作细节合理,具有一定参考价值。如果感兴趣的话,不妨跟着跟随小编一起来看看,下面跟着小编一起深入学习“小程序中的Log日志系统该如何搭建和使用”的知

这篇文章主要为大家分析了小程序中的Log日志系统该如何搭建和使用的相关知识点,内容详细易懂,操作细节合理,具有一定参考价值。如果感兴趣的话,不妨跟着跟随小编一起来看看,下面跟着小编一起深入学习“小程序中的Log日志系统该如何搭建和使用”的知识吧。

通常情况下,日志系统是开发中重要的一环。

但出于种种原因,在前端开发中做日志打印和上报系统却不常见。
但有些特定情况下,日志系统往往有奇效。

比如一个聊天系统中遇到了以下问题:

  • 语音通话中,用户听不到声音

  • 即时通讯中,部分场景用户反馈,消息发送不出去

  • 即时通讯中, A 回复 B 消息时,偶尔对话框不显示

  • 即时通讯中, A 给 B 连续发送两条消息后, B 接收不到第二条的提示

  • 即时通讯中,发送语音消息发送时,用户以为语音已经发送,但实际上录音还在继续。这时用户以为是网络卡了,最后发现自己和其他人说话的声音被录制进去

但是以上几种错误,在后台接口中并没有体现。再加上部分用户手机型号的问题,导致问题很难被定位。
如果我们这里有 log ,我们就能很快定位到出问题的代码。
如果不是代码问题,也更有底气回复用户不是我们系统的问题。

如何使用小程序 Log 日志系统

小程序侧提供了两种小程序 Log 日志接口:

  • LogManager ( 普通日志 )

  • RealtimeLogManager ( 实时日志 )

官方并没有介绍两者的具体区别,只是强调了 Realtime 的实时性质。

在我看来他们的最大区别就是:

  • LogManager 可以让用户有种心安的感觉,因为 LogManager 是用户手动反馈的问题。

  • RealtimeLogManager 则对开发者更友好,可以在用户不知情的情况下收集到问题信息,并在用户无感的情况下对问题进行修复。

LogManager

小程序提供的 Log 日志接口,通过 wx.getLogManager() 获取实例。
注意:

  • 最多保存5M的日志内容,超过5M后,旧的日志内容会被删除。

  • 对于 小程序 ,用户可以通过使用 button 组件的 open-type="feedback" 来上传打印的日志。

  • 对于 小游戏 ,用户可以通过使用 wx.createFeedbackButton 来创建上传打印的日志的按钮。

  • 开发者可以通过小程序管理后台左侧菜单 反馈管理 页面查看相关打印日志。

创建 LogManager 实例

你可以通过 wx.getLogManager() 获取日志实例。
括号中可以传参 { level: 0 | 1 } 来决定是否写入 Page 的生命周期函数, wx 命名空间下的函数日志。

  • 0: 写入

  • 不写入

 https://GitHub.com/Kujiale-Mobile/Painter

使用 LogManager 实例

const logger = wx.getLogManager({ level: 0 })logger.log({str: 'hello world'}, 'basic log', 100, [1, 2, 3])logger.info({str: 'hello world'}, 'info log', 100, [1, 2, 3])logger.debug({str: 'hello world'}, 'debug log', 100, [1, 2, 3])logger.warn({str: 'hello world'}, 'warn log', 100, [1, 2, 3])

用户反馈上传 LogManager 记录的日志

当日志记录后, 用户可以在小程序的 profile 页面,单击 反馈与投诉 ,在点击 功能异常 进行日志上传。

开发者处理用户反馈及和用户沟通

开发者可以在小程序后台 管理 -> 用户反馈 -> 功能异常 查看用户反馈的信息。
开发者可以在 功能 -> 客服 下绑定客服微信,绑定后可以在 48小时 内通过微信和反馈用户沟通。

注:沟通需要用户反馈时勾选:允许开发者在 48 小时内通过客服消息联系我。

RealtimeLogManager

小程序提供的 实时Log 日志接口,通过 wx.getRealtimeLogManager() 获取实例。
注意:

  • wx.getRealtimeLogManager() 基础库 2.7.1 开始支持

  • 官方给出实时日志每条的容量上限是 5kb

  • 官方对每条日志的定义:在一个页面 onShow -> onHide 之间,会聚合成一条日志上报

  • 开发者可从小程序管理后台: 开发 -> 运维中心 -> 实时日志 进入小程序端日志查询页面

为了定位问题方便,日志是按页面划分的,某一个页面,在onShow到onHide(切换到其它页面、右上角圆点退到后台)之间打的日志,会聚合成一条日志上报,并且在小程序管理后台上可以根据页面路径搜索出该条日志

创建 RealtimeLogManager 实例

你可以通过 wx.getRealtimeLogManager() 获取实时日志实例。

const logger = wx.getRealtimeLogManager()

使用 RealtimeLogManager 实例

const logger = wx.getRealtimeLogManager()logger.debug({str: 'hello world'}, 'debug log', 100, [1, 2, 3])logger.info({str: 'hello world'}, 'info log', 100, [1, 2, 3])logger.error({str: 'hello world'}, 'error log', 100, [1, 2, 3])logger.warn({str: 'hello world'}, 'warn log', 100, [1, 2, 3])

查看实时日志

与普通日志不同的是,实时日志不再需要用户反馈,可以直接通过以下方式查看实例。

  • 登录小程序后台

  • 通过路径 开发 -> 开发管理 -> 运维中心 -> 实时日志 查看实时日志

如何搭建小程序 Log 日志系统

上面我们知道了小程序的 Log 日志怎么使用,我们当然可以不进行封装直接使用。
但是我们直接使用起来会感觉到十分的别扭,因为这不符合我们程序员单点调用的习惯。

那么接下来让我们对这套 Log 系统进行初步的封装以及全局的方法的日志注入。

后续我会在 github 开放源码,并打包至 npm ,需要的开发者可自行 install 调用。

封装小程序 Log 方法

封装 Log 方法前,我们需要整理该方法需要考虑什么内容:

  • 打印格式:统一打印格式有助于我们更快的定位问题

  • 版本号:方便我们清晰的知道当前用户使用的小程序版本,避免出现旧版本问题在新代码中找不到问题

  • 兼容性:我们需要考虑用户小程序版本不足以支持 getLogManagergetRealtimeLogManager 的情况

  • 类型:我们需要兼容 debuglogerror 类型的 log日志

版本问题

我们需要一个常量用以定义版本号,以便于我们定位出问题的代码版本。
如果遇到版本问题,我们可以更好的引导用户

const VERSioN = "1.0.0"const logger = wx.getLogManager({ level: 0 })logger.log(VERSION, info)

打印格式

我们可以通过 [version] file | content 的统一格式来更快的定位内容。

const VERSION = "1.0.0"const logger = wx.getLogManager({ level: 0 })logger.log(`[${VERSION}] ${file} | `, ...args)

兼容性

我们需要考虑用户小程序版本不足以支持 getLogManagergetRealtimeLogManager 的情况

const VERSION = "0.0.18";const canIUseLogManage = wx.canIUse("getLogManager");const logger = canIUseLogManage ? wx.getLogManager({ level: 0 }) : null;const realtimeLogger = wx.getRealtimeLogManager ? wx.getRealtimeLogManager() : null;export function RUN(file, ...args) {  console.log(`[${VERSION}]`, file, " | ", ...args);  if (canIUseLogManage) {    logger.log(`[${VERSION}]`, file, " | ", ...args);  }  realtimeLogger && realtimeLogger.info(`[${VERSION}]`, file, " | ", ...args);}

类型

我们需要兼容 debuglogerror 类型的 log日志

export function RUN(file, ...args) {    ...}export function DEBUG(file, ...args) {    ...}export function ERROR(file, ...args) {    ...}export function getLogger(fileName) {  return {    DEBUG: function (...args) {      DEBUG(fileName, ...args)    },    RUN: function (...args) {      RUN(fileName, ...args)    },    ERROR: function (...args) {      ERROR(fileName, ...args)    }  }}

完整代码

以上都做到了,就完成了一套 Log 系统的基本封装。

const VERSION = "0.0.18";const canIUseLogManage = wx.canIUse("getLogManager");const logger = canIUseLogManage ? wx.getLogManager({ level: 0 }) : null;const realtimeLogger = wx.getRealtimeLogManager ? wx.getRealtimeLogManager() : null;export function DEBUG(file, ...args) {  console.debug(`[${VERSION}] ${file}  | `, ...args);  if (canIUseLogManage) {    logger.debug(`[${VERSION}]`, file, " | ", ...args);  }  realtimeLogger && realtimeLogger.info(`[${VERSION}]`, file, " | ", ...args);}export function RUN(file, ...args) {  console.log(`[${VERSION}]`, file, " | ", ...args);  if (canIUseLogManage) {    logger.log(`[${VERSION}]`, file, " | ", ...args);  }  realtimeLogger && realtimeLogger.info(`[${VERSION}]`, file, " | ", ...args);}export function ERROR(file, ...args) {  console.error(`[${VERSION}]`, file, " | ", ...args);  if (canIUseLogManage) {    logger.error(`[${VERSION}]`, file, " | ", ...args);  }  realtimeLogger && realtimeLogger.error(`[${VERSION}]`, file, " | ", ...args);}export function getLogger(fileName) {  return {    DEBUG: function (...args) {      DEBUG(fileName, ...args)    },    RUN: function (...args) {      RUN(fileName, ...args)    },    ERROR: function (...args) {      ERROR(fileName, ...args)    }  }}

全局注入 Log

通过该章节的名称,我们就可以知道全局注入。
全局注入的意思就是,不通过手动调用的形式,在方法写完后自动注入 log ,你只需要在更细节的地方考虑打印 log 即可。

为什么要全局注入

虽然我们实现了全局 log 的封装,但是很多情况下,一些新同学没有好的打 log 的习惯,尤其是前端同学(我也一样)。
所以我们需要做一个全局注入,以方便我们的代码书写,也避免掉手动打 log 会出现遗漏的问题。

如何进行全局注入

小程序提供了 behaviors 参数,用以让多个页面拥有相同的数据字段和方法。

需要注意的是, page 级别的 behaviors 在 2.9.2 之后开始支持

我们可以通过封装一个通用的 behaviors ,然后在需要 log 的页面进行引入即可。

import * as Log from "./log-test";export default Behavior({  definitionFilter(defFields) {    console.log(defFields);    Object.keys(defFields.methods || {}).forEach(methodName => {      const originMethod = defFields.methods[methodName];      defFields.methods[methodName] = function (ev, ...args) {        if (ev && ev.target && ev.currentTarget && ev.currentTarget.dataset) {          Log.RUN(defFields.data.PAGE_NAME, `${methodName} invoke, event dataset = `, ev.currentTarget.dataset, "params = ", ...args);        } else {          Log.RUN(defFields.data.PAGE_NAME, `${methodName} invoke, params = `, ev, ...args);        }        originMethod.call(this, ev, ...args)      }    })  }})

关于“小程序中的Log日志系统该如何搭建和使用”就介绍到这了,更多相关内容可以搜索编程网以前的文章,希望能够帮助大家答疑解惑,请多多支持编程网网站!

--结束END--

本文标题: 小程序中的Log日志系统该如何搭建和使用

本文链接: https://lsjlt.com/news/321001.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 小程序中的Log日志系统该如何搭建和使用
    这篇文章主要为大家分析了小程序中的Log日志系统该如何搭建和使用的相关知识点,内容详细易懂,操作细节合理,具有一定参考价值。如果感兴趣的话,不妨跟着跟随小编一起来看看,下面跟着小编一起深入学习“小程序中的Log日志系统该如何搭建和使用”的知...
    99+
    2023-06-28
  • 如何使用Docker搭建ELK日志系统
    本篇内容主要讲解“如何使用Docker搭建ELK日志系统”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用Docker搭建ELK日志系统”吧!以下安装都是以...
    99+
    2024-04-02
  • Python 中的日志系统:如何记录和管理应用程序的运行日志?
    在开发应用程序时,我们经常需要记录应用程序的运行状态和错误信息,以便于日后排查问题。在 Python 中,可以使用标准库中的 logging 模块来实现日志记录和管理。 本文将介绍 Python 中的日志系统,包括如何创建和配置日志记录器...
    99+
    2023-10-08
    接口 path 日志
  • ELK日志系统中如何进行通用应用程序日志接入
    这篇文章给大家介绍ELK日志系统中如何进行通用应用程序日志接入,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。日志规范规范的日志存放路径和输出格式将为我们后续的收集和分析带来极大的方便,无需考虑各种不同路径、格式的兼容问...
    99+
    2023-06-19
  • 如何使用Java和Apache创建实时日志系统?
    随着企业和组织的规模逐渐扩大,日志管理变得越来越重要。实时日志系统可以帮助开发人员、系统管理员和安全专家监控应用程序和系统的运行状态,以及识别潜在的问题和安全漏洞。在本文中,我们将介绍如何使用Java和Apache创建实时日志系统。 第一步...
    99+
    2023-07-26
    apache 日志 实时
  • PHP 中如何使用 Unix 系统的日志 API?
    在 Unix 系统中,日志是一个非常重要的组成部分,可以帮助我们记录系统运行状态、错误信息等重要信息。PHP 中也提供了许多函数和 API 来帮助我们在 Unix 系统中使用日志。 在本文中,我们将介绍如何在 PHP 中使用 Unix 系...
    99+
    2023-08-06
    日志 api unix
  • 如何使用ASP和Laravel构建实时日志记录系统?
    日志记录是每个应用程序都必须处理的事情。它可以帮助开发人员在应用程序中发现问题、调试代码和监控性能。在本文中,我们将介绍如何使用ASP和Laravel构建实时日志记录系统。 ASP是一种跨平台的Web应用程序框架,它可以用于构建高性能的We...
    99+
    2023-10-07
    laravel 日志 实时
  • 如何在Linux系统中使用Java编写高效的日志记录程序?
    在Linux系统中,Java是一种常用的编程语言,可以用来编写各种应用程序,包括日志记录程序。日志记录是软件开发过程中不可或缺的一部分,可以帮助我们了解软件的运行情况,定位问题等。在本文中,我们将介绍如何使用Java编写高效的日志记录程序。...
    99+
    2023-08-11
    日志 linux 关键字
  • python中普通程序员如何了解日志系统
    这篇文章给大家分享的是有关python中普通程序员如何了解日志系统的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。当我们在做系统开发时,日志系统是绕不开的话题。作为日志系统的最终使用者,我们会接触不同的日志系统,比...
    99+
    2023-06-17
  • 如何在Windows操作系统中使用Java编写文件日志程序?
    在Windows操作系统中,Java是一种非常流行的编程语言,它不仅可以用于开发各种类型的应用程序,还可以用于编写文件日志程序。在本文中,我们将介绍如何在Windows操作系统中使用Java编写文件日志程序。 一、什么是文件日志程序 文件日...
    99+
    2023-09-24
    windows 文件 日志
  • 如何简单高效的搭建Linux系统日志服务器
    本篇文章给大家分享的是有关如何简单高效的搭建Linux系统日志服务器,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。日志服务器就是把若干台服务器的日志信息 统一写入到某一台里面,...
    99+
    2023-06-28
  • Linux系统中,如何使用Python来优化缓存和日志?
    在Linux系统中,Python是一种非常流行的编程语言,它可以帮助我们优化缓存和日志。在本文中,我们将会介绍一些使用Python来优化缓存和日志的技巧,并提供一些示例代码。 一、缓存优化 缓存是一种常用的技术,它可以帮助我们提高应用程序的...
    99+
    2023-10-10
    linux 缓存 日志
  • Java 应用程序如何在 Linux 系统上记录日志?
    在 Linux 系统上运行 Java 应用程序时,对于问题排查和性能优化而言,日志记录是至关重要的。本文将介绍如何在 Linux 系统上记录 Java 应用程序的日志,并提供演示代码以帮助您更好地理解。 一、Java 日志框架 Java 日...
    99+
    2023-08-17
    linux 日志 git
  • 如何在Python中使用numpy和Linux日志来优化程序?
    Python是一种非常强大的编程语言,由于其易于学习和使用,以及其强大的库和框架支持,越来越多的开发人员选择Python作为他们的首选编程语言。然而,Python在处理大量数据时可能会变得非常缓慢。在这种情况下,我们需要使用一些工具来优化...
    99+
    2023-08-10
    numpy 日志 linux
  • Linux系统中如何使用logwatch监控日志文件
    这篇文章主要介绍Linux系统中如何使用logwatch监控日志文件,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Linux 操作系统和许多应用程序会创建特殊的文件来记录它们的运行事件,这些文件通常被称作“日志”。当...
    99+
    2023-06-16
  • 如何在 Unix 系统下使用 PHP 的日志 API?
    在 Unix 系统下使用 PHP 的日志 API 是非常重要的一项技能。PHP 的日志 API 可以帮助开发人员记录和跟踪应用程序中的错误和事件。在本文中,我们将介绍如何使用 PHP 的日志 API 在 Unix 系统下进行日志记录。 一、...
    99+
    2023-08-06
    日志 api unix
  • 如何在Unix系统中使用Go语言和Numpy来分析日志?
    Unix 系统是一种常用的操作系统,而 Go 语言和 Numpy 是两个强大的工具,它们可以帮助我们分析日志。在本文中,我们将探讨如何在 Unix 系统中使用 Go 语言和 Numpy 来分析日志。 一、Go 语言 Go 语言是一种开源的编...
    99+
    2023-06-02
    日志 numpy unix
  • 如何进行微信小程序点餐系统功能模板搭建
    这期内容当中小编将会给大家带来有关如何进行微信小程序点餐系统功能模板搭建,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。点餐小程序对于餐饮行业来说非常有实用性,顾客到店无需排队就可以进行扫码点餐,节约顾客排...
    99+
    2023-06-26
  • 如何使用NumPy和Go语言处理Linux系统上的日志?
    在Linux系统中,日志文件是非常重要的一部分。它们记录了系统中发生的各种事件,包括错误、警告和其他信息。为了管理和分析这些日志,我们需要一种有效的方法。NumPy和Go语言提供了一些强大的工具,可以帮助我们处理和分析日志数据。在本文中,我...
    99+
    2023-07-06
    linux numy 日志
  • Nodejs中的模块系统该如何使用
    本篇文章给大家分享的是有关Nodejs中的模块系统该如何使用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。模块化的背景早期 JavaScrip...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作