首页
/ 在压力下表现卓越:@fastify/under-pressure

在压力下表现卓越:@fastify/under-pressure

2024-05-23 22:24:34作者:俞予舒Fleming
under-pressure
Measure process load with automatic handling of "Service Unavailable" plugin for Fastify.

@fastify/under-pressure 是一款专为 Fastify 设计的强大插件,用于实时监测服务器的负载并自动化处理"服务不可用"的情况。通过智能检测 maxEventLoopDelaymaxHeapUsedBytesmaxRssBytesmaxEventLoopUtilization 等关键指标,确保你的应用程序在高压环境下仍能保持稳定运行。

安装与配置

要开始使用,您只需在您的项目中安装这个插件:

npm i @fastify/under-pressure

然后,将其注册到您的 Fastify 实例中,并设置相应的阈值:

const fastify = require('fastify')()

fastify.register(require('@fastify/under-pressure'), {
  maxEventLoopDelay: 1000,
  maxHeapUsedBytes: 100000000,
  maxRssBytes: 100000000,
  maxEventLoopUtilization: 0.98
})

// ...其他代码

如需自定义错误信息或 Retry-After 头部,你可以这样操作:

fastify.register(require('@fastify/under-pressure'), {
  maxEventLoopDelay: 1000,
  message: 'Under pressure!',
  retryAfter: 50
})

默认情况下,所有阈值都设为 0,表示不进行检查。请注意,这是针对Node.js v14.0.0和v12.19.0以上版本,对于不支持 eventLoopUtilization 的旧版本,该检查将被禁用。

应用场景

利用 @fastify/under-pressure,可以轻松地监控服务器资源消耗,防止在高并发或大量内存占用时造成服务崩溃。这在诸如电商平台的大促期间,或者处理大数据流的应用程序等场景中尤为关键。

特点

  1. 自动错误处理 - 当系统压力超过设定阈值时,插件会自动返回 "Service Unavailable" 错误。
  2. 可定制健康检查 - 支持提供自定义的健康检查函数,以检测外部资源的状态,例如数据库连接是否正常。
  3. 实时监测 - 采用非阻塞的 setTimeout 方法持续监测系统状态,避免加重服务器负担。
  4. 内存使用情况 - 提供 memoryUsage 函数,可获取当前的堆内存、常驻集大小、事件循环延迟等信息。
  5. 压力处理器 - 可自定义处理压力异常的策略,允许你根据具体情况优雅地处理请求。
  6. 状态路由 - 能够暴露一个 /status 路由,方便集成到如 AWS ELB 等监控系统中。

通过这些特性,@fastify/under-pressure 成为了确保服务器在面临高负荷时依然能够正常运行的可靠工具。

感谢 LetzDoIt 对该项目的支持。了解更多关于许可证的信息,请查看 LICENSE 文件。

立即尝试 @fastify/under-pressure,让您的服务在压力面前也能游刃有余!

under-pressure
Measure process load with automatic handling of "Service Unavailable" plugin for Fastify.
热门项目推荐
相关项目推荐

项目优选

收起
CangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
672
0
openHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
12
8
advanced-java
Advanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。
JavaScript
75.83 K
19.04 K
redis-sdk
仓颉语言实现的Redis客户端SDK。已适配仓颉0.53.4 Beta版本。接口设计兼容jedis接口语义,支持RESP2和RESP3协议,支持发布订阅模式,支持哨兵模式和集群模式。
Cangjie
323
26
RuoYi-Vue
🎉 基于SpringBoot,Spring Security,JWT,Vue & Element 的前后端分离权限管理系统,同时提供了 Vue3 的版本
Java
136
18
Yi-Coder
Yi Coder 编程模型,小而强大的编程助手
HTML
30
5
easy-es
Elasticsearch 国内Top1 elasticsearch搜索引擎框架es ORM框架,索引全自动智能托管,如丝般顺滑,与Mybatis-plus一致的API,屏蔽语言差异,开发者只需要会MySQL语法即可完成对Es的相关操作,零额外学习成本.底层采用RestHighLevelClient,兼具低码,易用,易拓展等特性,支持es独有的高亮,权重,分词,Geo,嵌套,父子类型等功能...
Java
1.42 K
231
xzs
在线考试系统、考试系统、在线教育考试系统、在线教育、跨平台考试、考试、智能考试、试题、错误试题、考试题目、试题组卷等
HTML
3
1
langgpt
Ai 结构化提示词,人人都能写出高质量提示词,GitHub 开源社区全球趋势热榜前十项目,已被百度、智谱、字节、华为等国内主流大模型智能体平台使用,内容来自国内最具影响力的高质量提示词工程师学习交流社群——LangGPT。开源知识库:https://langgptai.feishu.cn/wiki/RXdbwRyASiShtDky381ciwFEnpe
Jupyter Notebook
16
2