debian

如何通过日志监控Debian JS运行状态

小樊
32
2025-05-13 19:36:51
栏目: 编程语言

要通过日志监控 Debian 上的 JavaScript (JS) 运行状态,你可以使用以下方法:

  1. 使用 console.log() 或其他日志库(如 winstonmorgan 等)在 JavaScript 代码中添加日志记录。这将在控制台或指定的日志文件中生成日志。

  2. 使用 systemd 管理你的 JavaScript 应用程序。创建一个 systemd 服务单元文件,例如 /etc/systemd/system/my-js-app.service,并确保它包含以下内容:

[Unit]
Description=My JavaScript Application

[Service]
ExecStart=/usr/bin/node /path/to/your/app.js
Restart=always
User=myuser
Environment=NODE_ENV=production
StandardOutput=syslog
StandardError=syslog
SyslogIdentifier=my-js-app

[Install]
WantedBy=multi-user.target

这将确保你的应用程序在后台运行,并在出现问题时自动重启。同时,它还会将标准输出和错误重定向到 syslog。

  1. 重新加载 systemd 配置并启动你的服务:
sudo systemctl daemon-reload
sudo systemctl start my-js-app
  1. 使用 journalctl 查看日志:
sudo journalctl -u my-js-app -f

这将显示你的 JavaScript 应用程序的实时日志。你可以使用 -n 选项来限制显示的日志条数,例如 sudo journalctl -u my-js-app -f -n 100

  1. 若要设置日志级别,请在你的 JavaScript 代码中使用相应的日志库设置。例如,对于 winston,你可以这样做:
const winston = require('winston');

const logger = winston.createLogger({
  level: 'info', // 设置日志级别为 'info'
  format: winston.format.json(),
  transports: [
    new winston.transports.File({ filename: 'error.log', level: 'error' }),
    new winston.transports.File({ filename: 'combined.log' }),
  ],
});

这将确保只有 info 级别及以上的日志被记录。

通过这些方法,你可以监控 Debian 上的 JavaScript 运行状态并确保应用程序正常运行。

0
看了该问题的人还看了