Javascript提高:Node.js readline 模块 完整使用教程

Node.js readline 模块 完整使用教程

readlineNode.js 内置核心模块 ,无需安装,直接 require 即可使用,核心作用:逐行读取流数据(日志文件、命令行输入、大文件读取必备),完美解决大文件一次性加载内存溢出问题。

下面给你最常用、最实用的用法,直接复制就能跑。


一、最核心:逐行读取日志文件(高频用法)

处理日志文件 90% 场景都用这个

javascript 复制代码
const fs = require('fs');
const readline = require('readline');

// 1. 创建 readline 实例
const rl = readline.createInterface({
  input: fs.createReadStream('app.log'), // 读取文件流
  crlfDelay: Infinity // 兼容 Windows/Linux 所有换行符(必加)
});

// 2. 监听每一行数据
rl.on('line', (lineStr) => {
  // lineStr 就是日志的每一行,在这里做解析/过滤/处理
  console.log('读取到一行:', lineStr);
});

// 3. 文件读取完毕
rl.on('close', () => {
  console.log('文件读取完成!');
});

关键事件说明

事件名 作用
line 每次读取到一行时触发
close 读取完毕/停止时触发
error 发生错误时触发

二、进阶用法:命令行交互(输入输出)

readline 也可以做控制台问答工具,比如让用户输入内容:

javascript 复制代码
const readline = require('readline');

const rl = readline.createInterface({
  input: process.stdin,   // 控制台输入
  output: process.stdout  // 控制台输出
});

// 提问
rl.question('请输入日志文件名:', (answer) => {
  console.log('你输入的是:', answer);
  
  // 用完必须关闭
  rl.close();
});

三、处理大日志文件(防止内存爆炸)

大文件(1GB以上日志)绝对不能用 readFile ,必须用 readline 流式读取:

javascript 复制代码
const fs = require('fs');
const readline = require('readline');

let lineCount = 0;

const rl = readline.createInterface({
  input: fs.createReadStream('big.log'),
  crlfDelay: Infinity
});

rl.on('line', (line) => {
  lineCount++;
  // 逐行解析日志,比如只看错误日志
  if (line.includes('ERROR')) {
    console.log('错误日志:', line);
  }
});

rl.on('close', () => {
  console.log(`总行数:${lineCount}`);
});

四、常用 API 速查(背会这几个就够)

1. 创建实例

javascript 复制代码
const rl = readline.createInterface(options)

2. 监听行

javascript 复制代码
rl.on('line', (line) => {})

3. 关闭实例

javascript 复制代码
rl.close()

4. 暂停/恢复读取

javascript 复制代码
rl.pause()  // 暂停
rl.resume() // 恢复

五、完整实战:解析 Nginx/应用日志

javascript 复制代码
const fs = require('fs');
const readline = require('readline');

const rl = readline.createInterface({
  input: fs.createReadStream('app.log'),
  crlfDelay: Infinity
});

// 正则解析日志(示例)
const logReg = /(\d{4}-\d{2}-\d{2}) \[(\w+)\] (.*)/;

rl.on('line', (line) => {
  const res = line.match(logReg);
  if (res) {
    const [, time, level, msg] = res;
    console.log({ time, level, msg });
  }
});

rl.on('close', () => {
  console.log('解析完成');
});

六、重要注意事项(避坑)

  1. 必须处理 close:读取完成后释放资源
  2. 大文件必须用流fs.createReadStream + readline 是标准方案
  3. crlfDelay: Infinity :兼容所有系统换行符,一定要加
  4. 不要在 line 事件里写同步阻塞代码:会拖慢读取速度
  5. 错误处理 :生产环境建议加 error 事件监听

总结

require('readline') 就记住 3 个核心点

  1. 逐行读取on('line') 是灵魂
  2. 搭配文件流fs.createReadStream 处理大文件
  3. 日志解析神器:Node.js 处理日志文件的标准方案

需要我给你写一个可直接用于生产环境的日志解析工具类吗?

相关推荐
晓说前端7 小时前
第一篇:为什么学TypeScript?—— 优势、场景与环境搭建
javascript·ubuntu·typescript
ZC跨境爬虫8 小时前
模块化烹饪小程序开发日记 Day7:(菜谱详情接口开发与JSON数据读取全流程)
前端·javascript·css·ui·微信小程序·json
এ慕ོ冬℘゜8 小时前
JS 前端基础面试题
开发语言·前端·javascript
张元清11 小时前
驯服 React 里的 DOM 事件:useEventListener、useEventEmitter、useKeyModifier、useTextSelect
前端·javascript·面试
古韵11 小时前
�������� JavaScript �հ�����ԭ����ʵս
javascript
代码熊崽的编程森林12 小时前
vue + onlyoffice 自定义插件的实现(OnlyOffice 插件:AI 智能编辑)。
前端·javascript·vue.js
Lucky_Turtle12 小时前
【Vue】element plus Slider小数组件设置顺滑程度
前端·javascript·vue.js
Dxy123931021612 小时前
js中Math.min.apply()详解
开发语言·javascript
砍材农夫13 小时前
物联网 基于netty控制报文结构(发布与接收)
java·开发语言·前端·javascript·物联网
上单带刀不带妹13 小时前
Vue3 中 getCurrentInstance() 与 proxy 详解
前端·javascript·vue.js