AI 考拉技术分享-Nodejs 基础架构专题(二)

发布于 1周前 作者 ionicwang 来自 nodejs/Nestjs

AI 考拉技术分享-Nodejs 基础架构专题(二)

klg-logger

前言

今天给大家介绍 logger 日志工具的使用,用 dev 的小哥哥的话说:log 工具,基于 tracer,简单,可以显示 log 的位置。
详情请看以下配置方法,有问题欢迎在评论区提出!

配置

3.0 版本开始,将不对 tracer 做任何封装,直接使用 Tracer

详细用法见 tracer 文档https://www.npmjs.com/package/tracer

基本用法

简单版本

默认版本是把 log 输出到 console

js
import { Logger } from 'klg-logger'

const logger = Logger({ level: config.get(‘log.level’), dateformat: ‘yyyy-mm-dd HH:MM:ss.L’, inspectOpt: { showHidden: false, // if true then the object’s non-enumerable properties will be shown too. Defaults to false depth: 5 // tells inspect how many times to recurse while formatting the object. This is useful for inspecting large complicated objects. Defaults to 2. To make it recurse indefinitely pass null. } })

logger.info(‘hello world’) logger.debug(‘hello %s’, ‘world’) logger.error(‘hello %s’, ‘error’)

export {logger}

配置项的详细解释:

interface LoggerConfig {
    /**
     * Output format (Using `tinytim` templating)
     *
     * Defaults to: `"{{timestamp}} <{{title}}> {{file}}:{{line}} ({{method}}) {{message}}"`
     *
     * Possible values:
     * - timestamp: current time
     * - title: method name, default is 'log', 'trace', 'debug', 'info', 'warn', 'error','fatal'
     * - level: method level, default is 'log':0, 'trace':1, 'debug':2, 'info':3, 'warn':4, 'error':5, 'fatal':6
     * - message: printf message, support %s string, %d number, %j JSON and auto inspect
     * - file: file name
     * - line: line number
     * - pos: position
     * - path: file's path
     * - method: method name of caller
     * - stack: call stack message
     */
    format?: string | [string, LevelOption<string>];
    /**
     * Datetime format (Using `Date Format`)
     */
    dateformat?: string;
    filters?: FilterFunction[] | LevelOption<FilterFunction> | Array<FilterFunction | LevelOption<FilterFunction | FilterFunction[]>>;
    /**
     * Output the log, if level of log larger than or equal to `level`.
     */
    level?: string | number;
    methods?: string[];
    /**
     * Get the specified index of stack as file information. It is useful for development package.
     */
    stackIndex?: number;
    inspectOpt?: {
        /**
         * If true then the object's non-enumerable properties will be shown too. Defaults to false.
         */
        showHidden: boolean,
        /**
         * Tells inspect how many times to recurse while formatting the object.
         * This is useful for inspecting large complicated objects.
         * Defaults to 2. To make it recurse indefinitely pass null.
         */
        depth: number
    };
/**
 * Pre-process the log object.
 */
preprocess?(data: LogOutput): void;
/**
 * Transport function (e.g. console.log)
 */
transport?: TransportFunction | TransportFunction[];

}

自定义 transport

如果你需要把 log 输出到文件或者发送其他地方,可以自定义 transport function

import { Logger } from 'klg-logger'
const logger = new Logger({
  level: 'log',
  transport: function (data: Tracer.LogOutput) {
    // 写文件
    fs.write(data)
    // 发送其他地址
    tcp.send(data)
assert(data)
assert(data.level === 0)

} }) logger.log(‘hello world’)

每日分割日志

如果你需要把 log 输出到文件或者发送其他地方,可以自定义 transport function

import { LoggerDaily } from 'klg-logger'
const logger = LoggerDaily({
  root: '/data/app/log',
  maxLogFiles: 10,
  allLogsFileName : true,
  level: 'log'
})
logger.log('hello world')
logger.err = logger.error
logger.err('hello world')

配置字段:

interface DailyFileConfig {
    /**
     * All daily log file's dir, default to: `'.'`.
     */
    root?: string;
    /**
     * Log file path format.
     *
     * Default to: `'{{root}}/{{prefix}}.{{date}}.log'`
     *
     * Possible values:
     * - `root`: all daily log file's dir, default to: `'.'`.
     * - `prefix`: it equal to `allLogsFileName`, if `allLogsFileName` is provided; else it will be the method name.
     * - `date`: today's date.
     */
    logPathFormat?: string;
    /**
     * Datetime format (Using `Date Format`)
     */
    splitFormat?: string;
    /**
     * If `allLogsFileName` is provided then all level logs will be move to one daily log file.
     */
    allLogsFileName?: boolean;
    maxLogFiles?: number;
}

著作权归本文作者所有,未经授权,请勿转载,谢谢。


1 回复

以下是对“AI考拉技术分享-Node.js基础架构专题(二)”的回帖,供您参考:


感谢AI考拉的技术分享,对于Node.js的基础架构,我也有一些心得和代码示例,愿意与大家分享。

Node.js是一个将多种技术组合起来的平台,它使用JavaScript调用系统接口,实现了高效的服务器端开发。Node.js的架构可以分为三个主要部分:标准库、中间层和底层库。

  1. 标准库:提供了开发人员能够直接调用的API,如http模块、stream模块、fs文件系统模块等。

  2. 中间层:即Node bindings,它封装了底层库中的实现细节,并向标准库提供基础API服务。这一层使得JavaScript代码能够与C/C++代码进行通信。

  3. 底层库:是Node.js运行的关键,包括V8引擎、libuv等。V8引擎将JavaScript编译为原生机器码,提高了执行效率。libuv是一个跨平台的异步I/O库,提供了非阻塞的文件系统、DNS、网络等机制。

以下是一个简单的Node.js代码示例,展示了如何使用http模块创建一个服务器:

const http = require('http');

const hostname = '127.0.0.1';
const port = 3000;

const server = http.createServer((req, res) => {
  res.statusCode = 200;
  res.setHeader('Content-Type', 'text/plain');
  res.end('Hello World\n');
});

server.listen(port, hostname, () => {
  console.log(`Server running at http://${hostname}:${port}/`);
});

这个示例展示了Node.js的事件驱动架构和异步I/O处理能力。当服务器接收到请求时,它会触发一个事件,Node.js会处理这个事件并返回响应。

再次感谢AI考拉的技术分享,希望这次回帖能对大家有所帮助。


希望以上回帖能够符合您的要求。

回到顶部