Node.js:开发和生产之间的区别

Node.js 中的开发和生产没有区别,即,你无需应用任何特定设置即可使 Node.js 在生产配置中工作。但是,npm 注册表中的一些库会识别使用 NODE_ENV 变量并将其默认为 development 设置。始终在设置了 NODE_ENV=production 的情况下运行 Node.js。

一、Express 中的 NODE_ENV

在广受欢迎的 express 框架中,将 NODE_ENV 设置为 production 通常可确保:

  • 日志记录保持在最低限度,基本级别
  • 更多缓存级别用于优化性能
    这通常是通过执行命令来完成的
复制代码
export NODE_ENV=production

在 shell 中,但最好将其放在 shell 配置文件中(例如,带有 Bash shell 的 .bash_profile),否则在系统重启的情况下设置不会保留。
你也可以通过将其添加到应用初始化命令的前面来应用环境变量:

复制代码
NODE_ENV=production node app.js

例如,在 Express 应用中,你可以使用它为每个环境设置不同的错误处理程序:

复制代码
if (process.env.NODE_ENV === 'development') {
  app.use(express.errorHandler({ dumpExceptions: true, showStack: true }));
}

if (process.env.NODE_ENV === 'production') {
  app.use(express.errorHandler());
}

例如,如果 NODE_ENV 未设置为 production,则 Express 使用的模板库 Pug 会在调试模式下编译。在开发模式下,Express 视图在每个请求中都会进行编译,而在生产中,它们会被缓存。还有更多示例。

此环境变量是外部库中广泛使用的约定,但不在 Node.js 本身内使用。

二、为什么 NODE_ENV 被视为反模式?

环境是一个数字平台或系统,工程师可以在其中构建、测试、部署和管理软件产品。通常,我们的应用运行的环境有四个阶段或类型:

  • 开发
  • 测试
  • 准备
  • 生产
    NODE_ENV 的根本问题源于开发者将优化和软件行为与其软件运行的环境相结合。结果是如下代码:
复制代码
if (process.env.NODE_ENV === 'development') {
  // ...
}

if (process.env.NODE_ENV === 'production') {
  // ...
}

if (['production', 'staging'].includes(process.env.NODE_ENV)) {
  // ...
}


虽然这看起来无害,但它使生产和登台环境不同,从而使可靠的测试变得不可能。例如,当 NODE_ENV 设置为 development 时,测试以及产品的功能可能会通过,但当将 NODE_ENV 设置为 production 时会失败。因此,将 NODE_ENV 设置为 production 以外的任何值都被视为反模式。

相关推荐
超哥--18 小时前
B站视频内容智能分析系统(九):React 前端与管理面板
前端·react.js·前端框架
Cutecat_21 小时前
视频字幕处理工具横向:提取模式 vs 编辑模式,该如何选择
android·前端·ios·语音识别
qq_4221525721 小时前
PDF 加水印工具怎么选?2026 年文档版权保护方案对比
前端·pdf·github
kyriewen21 小时前
手写 Promise.all、race、any:不到 30 行代码,解决并发异步的所有姿势
前端·javascript·面试
brucelee1861 天前
OpenClaw 浏览器控制(Chrome MCP)完整教程
前端·chrome
ct9781 天前
React 状态管理方案深度对比
开发语言·前端·react
胡志辉的博客1 天前
深入浅出理解浏览器事件循环:从一道输出题讲到 Chrome 源码
前端·javascript·chrome·chromium·event loop
代码不加糖1 天前
js中不会冒泡的事件有哪些?
前端·javascript·vue.js
懂懂tty1 天前
Vue2与Vue3之间API差异
前端·javascript·vue.js
AI焦点1 天前
跨越协议鸿沟:Tool Use状态机从Anthropic到OpenAI兼容体系的适配要点
前端·人工智能