Node.js日志切割实现方法
在实际项目开发中,日志文件若不及时切割,很快就会变得异常庞大,既占用磁盘空间,又增加排查问题的难度。那么,在 Node.js 环境中如何实现日志的自动按天切分呢?使用 winston 搭配其扩展库 winston-daily-rotate-file 就是一种非常成熟的方案。下面直接提供完整代码实现,每一步都清晰易懂。

第一步:安装依赖
npm install winston winston-daily-rotate-file
第二步:编写日志配置模块
新建一个 logger.js 文件,核心配置如下 —— 自定义日志格式、按日期自动切分、自动压缩归档,一次配置即可完成全部需求。
const winston = require('winston');
const { format } = winston;
const { combine, timestamp, printf } = format;
const DailyRotateFile = require('winston-daily-rotate-file');
// 自定义日志格式:时间 + 级别 + 消息
const myFormat = printf(({ timestamp, level, message }) => {
return `${timestamp} ${level}: ${message}`;
});
const logger = winston.createLogger({
level: 'info',
format: combine(
timestamp(),
myFormat
),
transports: [
new DailyRotateFile({
filename: 'logs/application-%DATE%.log',
datePattern: 'YYYY-MM-DD',
zippedArchive: true, // 归档压缩,节省空间
maxSize: '20m', // 单个文件最大 20MB
maxFiles: '14d' // 保留最近 14 天的日志
})
]
});
module.exports = logger;
第三步:在应用中引入并使用
在需要记录日志的位置,只需引入这个 logger 模块即可正常使用,其接口与标准 winston logger 完全一致。
const logger = require('./logger');
logger.info('Hello, world!');
logger.error('An error occurred');
配置完成后,系统每天会自动生成一个形如 application-2026-06-26.log 的新日志文件,并按设定规则对旧文件进行压缩归档和清理。这样一来,日志管理变得井井有条,再也不用担心磁盘空间被日志文件撑爆。
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
详解如何使用Apache服务器进行防盗链配置步骤
Apache使用mod_rewrite模块实现图片防盗链,通过 htaccess文件配置Rewrite规则,检查HTTP_REFERER来源,若非本站域名且来源不为空,则对jpg等常见图片格式返回403禁止访问。此方法能有效阻止大多数盗链行为。
Filebeat日志转发实现步骤详解
Filebeat通过配置输入源读取日志,输出目标转发至Elasticsearch或Logstash。安装后编辑filebeat yml文件,指定日志路径和输出地址。支持直接转发或经Logstash处理。通过systemctl启动并验证数据到达,可选SSL加密和多行日志合并配置。
手把手教你如何在CentOS上使用PhpStorm构建项目的详细步骤
在CentOS上使用PHPStorm构建项目需先准备环境:安装Java、PHP及扩展、Nginx、MariaDB并开放端口。然后安装配置PHPStorm,设置SSH解释器与Web服务器映射。导入或创建项目后安装Composer依赖,调整php ini。配置SFTP部署并同步文件,最后设置Xdebug进行调试运行。
CentOS下GitLab集成其他工具的详细配置方法与完整指南
在CentOS平台中,GitLab通过Webhooks、API与CI CD配置,深度集成Jenkins、SonarQube、Docker及Slack,构建代码托管、自动构建、质量检查与协作通知的自动化链路,覆盖开发、测试、部署全流程,实现从提交到上线的自动化,大幅提升团队效率与交付质量,推动开发运维一体化。
CentOS设置Node.js定时任务的方法
在CentOS上为Node js应用设置定时任务常用两种方案:systemd适合长期运行服务,需创建服务文件并配置开机自启;cron更灵活,适合定期唤醒任务,通过编辑crontab添加时间计划和执行命令。两种方法均需指定Node js路径和应用入口。
- 日榜
- 周榜
- 月榜
相关攻略
2026-06-30 06:46
2026-06-30 06:46
2026-06-30 06:46
2026-06-30 06:46
2026-06-30 06:45
2026-06-30 06:45
2026-06-30 06:45
2026-06-30 06:45
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

