Dotenv Webpack - 当我在运行时更改系统环境变量时,更改不会影响应用程序

Dotenv Webpack - When I change the system environment variables on runtime, the changes is not affected on the app

我使用 React、webpack、docker 和 AWS 构建了一个网络应用程序。

我创建了一个依赖于环境变量的功能。因此,如果环境变量值为 true,则该功能将显示在前端。

问题是,当我更改服务器上的环境变量时(Webpack 已经完成构建应用程序,应用程序已经部署并且 运行),我的功能没有显示。我猜是因为应用程序无法读取系统环境变量的值变化。

我怎样才能做到这一点?可以吗?

=====

我使用 dotenv webpack 来管理我的环境变量。我已经将 systemvars 设置为 true 以检测系统或 .env 文件中的所有环境变量。

=====

那么我为什么要这样做,因为我不想发出合并请求来推送环境变量的新值。我只想保留环境变量名称,如果该功能已准备好部署,则直接从服务器更改值。如果有错误,我只需要将环境变量更改为某个东西,功能就会关闭。

您根本无法更改环境变量。 Evn 变量在 compile/webpack 加载时间加载。因此,一旦应用程序启动,您就无法更改,process.env

@jonrsharpe 解释的解决方案。您需要创建某种数据库。它可以是内存或文件或数据库。你从那里读取数据。公开一个 API,以更新数据库。

快递样品:

global.enableFeature = false

app.post("/updateFeatureToggle", (req, res) => {
  const enableFeature = req.body.enableFeature

  global.enableFeature = enableFeature
  res.send({success: "OK"})
})

在另一个文件中,读取自 global.enableFeature。这是基于内存的。