首页
/ Forever 项目技术文档

Forever 项目技术文档

2024-12-15 16:30:35作者:廉皓灿Ida

1. 安装指南

安装 Forever

Forever 是一个简单的 CLI 工具,用于确保给定的脚本持续运行(即“永远”运行)。你可以通过 npm 全局安装 Forever。

$ [sudo] npm install forever -g

注意: 如果你计划在代码中以编程方式使用 Forever,你应该安装 forever-monitor

$ cd /path/to/your/project
$ [sudo] npm install forever-monitor

2. 项目的使用说明

命令行使用

你可以使用 Forever 来持续运行脚本(无论是用 Node.js 编写的还是其他语言编写的)。

示例:

$ forever start app.js

选项

你可以通过 forever --help 查看所有可用选项。以下是一些常用选项:

  • start: 启动脚本作为守护进程。
  • stop: 停止指定的守护进程。
  • stopall: 停止所有运行的 Forever 脚本。
  • restart: 重启指定的守护进程。
  • restartall: 重启所有运行的 Forever 脚本。
  • list: 列出所有运行的 Forever 脚本。
  • logs: 列出所有 Forever 进程的日志文件。

JSON 配置文件

除了通过命令行传递脚本路径和选项外,你还可以传递 Forever 一个 JSON 文件,其中包含这些选项。例如:

{
    "uid": "app",
    "append": true,
    "watch": true,
    "script": "index.js",
    "sourceDir": "/home/myuser/app",
    "logFile": "/home/myuser/logs/forever.log",
    "outFile": "/home/myuser/logs/out.log",
    "errFile": "/home/myuser/logs/error.log"
}

你可以通过以下命令启动应用:

$ forever start ./forever/development.json

在代码中使用

Forever 模块提供了一些有用的方法,可以在你的代码中使用。每个方法返回一个 EventEmitter 实例,当操作完成时会触发相应的事件。

示例:

const forever = require('forever');

forever.startDaemon('app.js', {
    'uid': 'app',
    'logFile': 'forever.log',
    'outFile': 'out.log',
    'errFile': 'error.log'
});

3. 项目 API 使用文档

forever.load(config)

同步设置 Forever 模块的配置。配置选项包括:

  • root: 存放所有默认 Forever 日志文件的目录。
  • pidPath: 存放所有 Forever *.pid 文件的目录。
  • sockPath: 用于 IPC 的套接字目录。
  • loglength: forever tail 返回的日志数量。
  • columns: 当 format 为 true 时显示的列。
  • debug: 是否以调试模式运行。
  • stream: 日志是否会被流式传输。

forever.start(file, options)

启动一个脚本并使用 Forever 管理。options 对象是 forever-monitor 期望的选项。

forever.startDaemon(file, options)

以守护进程方式启动一个脚本。options 对象是 forever-monitor 期望的选项。

forever.stop(index)

停止指定索引的 Forever 守护进程脚本。索引与 forever.list() 返回的索引相同。

forever.stopAll(format)

停止所有当前运行的 Forever 脚本。format 参数是一个布尔值,指示返回的值是否应根据配置的列进行格式化。

4. 项目安装方式

全局安装

$ [sudo] npm install forever -g

项目内安装

$ cd /path/to/your/project
$ [sudo] npm install forever-monitor

通过以上步骤,你可以轻松安装并使用 Forever 来管理你的脚本,确保它们持续运行。

热门项目推荐
相关项目推荐

项目优选

收起
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
49
38
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
250
63
mybatis-plusmybatis-plus
mybatis 增强工具包,简化 CRUD 操作。 文档 http://baomidou.com 低代码组件库 http://aizuda.com
Java
14
0
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
173
41
open-eBackupopen-eBackup
open-eBackup是一款开源备份软件,采用集群高扩展架构,通过应用备份通用框架、并行备份等技术,为主流数据库、虚拟化、文件系统、大数据等应用提供E2E的数据备份、恢复等能力,帮助用户实现关键数据高效保护。
HTML
69
52
advanced-javaadvanced-java
Advanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。
JavaScript
395
102
HarmonyOS-Cangjie-CasesHarmonyOS-Cangjie-Cases
参考 HarmonyOS-Cases/Cases,提供仓颉开发鸿蒙 NEXT 应用的案例集
Cangjie
54
2
PDFMathTranslatePDFMathTranslate
PDF scientific paper translation with preserved formats - 基于 AI 完整保留排版的 PDF 文档全文双语翻译,支持 Google/DeepL/Ollama/OpenAI 等服务,提供 CLI/GUI/Docker
Python
31
3
RuoYi-Cloud-Vue3RuoYi-Cloud-Vue3
🎉 基于Spring Boot、Spring Cloud & Alibaba、Vue3 & Vite、Element Plus的分布式前后端分离微服务架构权限管理系统
Vue
25
17
topiam-eiamtopiam-eiam
开源IDaas/IAM平台,用于管理企业内员工账号、权限、身份认证、应用访问,帮助整合部署在本地或云端的内部办公系统、业务系统及三方 SaaS 系统的所有身份,实现一个账号打通所有应用的服务。
Java
19
0