centos下如何配置js日志
在CentOS系统下配置Ja vaScript日志
为Ja vaScript应用配置一个清晰、可靠的日志系统,是保障服务可观测性的关键一步。在CentOS环境下,这项工作通常需要从两个层面入手:一是应用程序自身的日志记录,二是Node.js运行环境的日志管理。下面,我们就来详细拆解一下具体的配置步骤。
免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

1. 应用程序日志配置
对于主流的Web应用框架,比如Express或Koa,配置日志最便捷的方式莫过于使用成熟的中间件。它们能帮你自动捕获HTTP请求的来龙去脉。
Express示例:
const express = require('express');
const morgan = require('morgan');
const app = express();
// 使用morgan中间件记录日志
app.use(morgan('combined'));
app.get('/', (req, res) => {
res.send('Hello World!');
});
app.listen(3000, () => {
console.log('Server is running on port 3000');
});
看,就像上面这样,引入morgan中间件并调用app.use方法,日志功能就集成好了。morgan提供了多种预定义的日志格式,比如combined(Apache标准组合格式)、common、dev等,你可以根据实际需求灵活选择。
2. Node.js环境日志配置
Node.js本身并没有内置功能强大的日志模块,但这恰恰给了我们选择的自由。社区里广受好评的winston和pino等库,可以轻松构建起一套健壮的日志系统。
Winston示例:
首先,通过npm安装winston:
npm install winston
接下来,在应用中进行配置。一个典型的winston配置示例如下:
const winston = require('winston');
// 创建一个logger实例
const logger = winston.createLogger({
level: 'info',
format: winston.format.json(),
transports: [
new winston.transports.File({ filename: 'error.log', level: 'error' }),
new winston.transports.File({ filename: 'combined.log' })
]
});
// 如果不在生产环境中,将日志输出到控制台
if (process.env.NODE_ENV !== 'production') {
logger.add(new winston.transports.Console({
format: winston.format.simple()
}));
}
// 示例日志记录
logger.info('Hello, world!');
logger.error('Something went wrong!');
这段配置实现了什么?它创建了一个日志记录器(logger),会将错误级别(error)及以上的日志单独写入error.log文件,同时将所有级别的日志都写入combined.log。这里有个很实用的技巧:通过判断NODE_ENV环境变量,让在非生产环境(如开发、测试)下的日志同时输出到控制台,方便调试;而在生产环境则静默地只记录到文件,避免不必要的控制台输出。
3. 配置日志轮转
日志文件如果放任不管,很容易膨胀到几个G,不仅占用磁盘空间,查看起来也极其不便。因此,配置日志轮转(Log Rotation)是生产环境必不可少的一环。在CentOS上,logrotate工具是完成这项任务的标准选择。
首先,确保系统已安装logrotate:
sudo yum install logrotate
然后,为你的应用创建一个专属的配置文件,例如放在/etc/logrotate.d/myapp:
/path/to/your/logs/*.log {
daily
missingok
rotate 7
compress
notifempty
create 0640 root root
}
这个配置文件的每一行指令都有其明确作用:
daily:设定轮转周期为每天一次。missingok:即使日志文件暂时不存在,也不报错。rotate 7:保留最近7天的日志文件,更早的则自动删除。compress:启用压缩,将旧的日志文件打包成.gz格式,节省空间。notifempty:如果日志文件是空的,就跳过本次轮转。create 0640 root root:轮转后创建新的空日志文件,并设置其权限为0640,所有者为root用户和root组。
配置完成后,基本就大功告成了。logrotate通常作为系统每日定时任务(cron job)自动运行,它会主动检查并处理符合规则的日志文件。
遵循以上步骤,你就能在CentOS系统上,为你的Ja vaScript应用程序搭建起一套从记录、分级到自动维护的完整日志管理体系。
相关攻略
Crontab 任务为何没有按预期执行? 相信不少运维工程师或开发者都遇到过这个头疼的问题:明明设置好的 Crontab 定时任务,到了点却“静悄悄”,完全没有执行。这背后的原因其实挺多,但别担心,排查起来有章可循。下面这几个方向,是经验中最常见的问题点,按顺序检查一遍,多半能定位到症结。 1 确
CentOS 上 LibreOffice 与其他软件冲突的定位与解决 在 CentOS 环境下部署 LibreOffice,有时会遇到一些令人头疼的兼容性问题。别担心,这些问题大多有迹可循,且能通过系统性的排查来解决。下面,我们就来梳理一下常见的冲突类型以及一套行之有效的解决方案。 一、常见冲突类型
在CentOS上进行Python测试,可以遵循以下步骤 安装Python CentOS系统通常会预装Python,不过版本可能不是最新的。要安装或更新Python,最直接的方式就是利用系统自带的包管理器,比如 yum 或 dnf。 sudo yum install python3 当然,如果项目有特
CentOS 上安装 Python 的最佳实践 在CentOS服务器上部署Python环境,选对方法能省去后续无数麻烦。今天,我们就来聊聊如何根据不同的需求,选择最合适的安装路径,并确保环境的稳定与高效。 一 版本选择与总体策略 先说几个核心判断。对于新项目,优先选择仍在积极维护的版本是明智之举。P
在CentOS上安装Python:常见问题与解决之道 在CentOS系统上手动安装Python,尤其是从源码编译时,确实可能遇到一些“拦路虎”。别担心,这些问题大多有迹可循。下面就来梳理一下那些典型的安装失败原因以及对应的解决方案,帮你理清思路。 1 缺少依赖包 这恐怕是最常见的原因了。编译Pyt
热门专题
热门推荐
美的洗碗机:告别手动预洗,真能实现“脏碗直入”吗? 直接将沾满油污的碗盘放入洗碗机,您是否仍心存疑虑?这确实是许多用户的共同疑问。实际上,针对日常餐后绝大多数餐具的清洁需求,美的洗碗机已设计出一套高效的智能解决方案,让您彻底告别费力的人工冲洗。其核心在于一项智能预洗程序,它并非简单的“过一遍水”,而
虚拟键盘:用鼠标也能轻松打字的系统级方案 当物理键盘临时罢工,或者你只是想在触摸屏上点点戳戳完成输入,系统内置的虚拟键盘(或称屏幕键盘)就是那个随时待命的救星。它无需安装任何第三方软件,完全通过鼠标操作即可调用和输入,完美适配临时应急、无障碍辅助,甚至是清洁键盘时的临时替代等场景。无论是Window
油市现在最诡异的地方,账算不平 眼下油市最吊诡的一点,是账怎么也算不平:供应端被硬生生切掉了一大块,库存正以肉眼可见的速度被抽干,需求那头也在往下掉。可价格的反应,却不像一个正在被迫“清算”的市场该有的样子。摩根大通的观点一针见血——这套全球原油的供需账,肯定有哪里不对劲。 该行大宗商品策略师Nat
德业除湿机常见故障解析与模块化排查指南 说到德业除湿机的常见故障,其实主要集中在五个方面:通风系统异常、制冷循环失常、压缩机性能下降、整机噪音升高,以及水路泄漏问题。有意思的是,机器本身还挺“聪明”,配备了一套标准化的故障代码系统,能精准指向具体问题模块。比如,从E1到E9这些代码,分别对应着湿度传
iPad关机按键失效后,如何优雅地完成关机与重启? 物理按键偶尔失灵,这在电子设备中并不罕见。好在,即便iPad的关机按键完全失效,你依然有多种可靠的方式来实现正常关机与重启。这些方法并非旁门左道,而是苹果官方在系统层面预留的“后门”,从系统设置、组合按键到辅助触控,构成了完整的冗余操作链。根据ID





