Miao-Yunzai/lib/tools/log.js

44 lines
1.3 KiB
JavaScript
Raw Permalink Normal View History

import fs from "node:fs"
import childProcess from "child_process"
const _path = process.cwd()
fs.readFile(`${_path}/config/pm2/pm2.json`, "utf8", (err, data) => {
if (err) {
console.error("pm2.json文件读取错误:", err)
return
}
try {
const config = JSON.parse(data)
if (config.apps && config.apps.length > 0 && config.apps[0].name) {
const appName = config.apps[0].name
runPm2Logs(appName)
} else {
console.error("读取失败无法在pm2.json中找到name数组")
}
} catch (parseError) {
console.error("读取失败json文件解析发生了错误", parseError)
}
})
function runPm2Logs(appName) {
const command = process.platform === "win32" ? "pm2.cmd" : "pm2"
const args = ["logs", "--lines", "400", appName]
2024-06-09 04:03:50 +08:00
// console.log(`Command: ${command}`)
// console.log(`Args: ${args.join(" ")}`)
const pm2LogsProcess = childProcess.spawn(command, args, { stdio: "inherit", shell: true })
pm2LogsProcess.on("error", (error) => {
console.error("Error spawning pm2 logs process:", error)
})
pm2LogsProcess.on("exit", (code) => {
if (code !== 0) {
console.error(`pm2 logs process exited with code ${code}`)
}
})
2023-10-25 03:34:37 +08:00
}