0

我正在使用 CodeDeploy 将 Node.js 应用程序部署到 EC2。我将凭证存储在 AWS Systems Manager 和 Parameter Store 中,但是找不到将这些凭证公开给我的应用程序的方法。

我正在使用 PM2 进行流程管理。我可以成功地从目标机器上的 Parameter Store 中检索参数,所以没有权限问题。例如:

aws ssm get-parameters --region us-east-1 --names LOCAL_CACHE_PATH --with-decryption --query Parameters[0].Value`

...成功返回正确的字符串。我尝试在我的applicationStart.shCodeDeploy 文件中使用它并启动应用程序:

#!/bin/bash
export LOCAL_CACHE_PATH=$(aws ssm get-parameters --region us-east-1 --names LOCAL_CACHE_PATH --with-decryption --query Parameters[0].Value)

pm2 start ecosystem.config.js --env production

LOCAL_CACHE_PATHundefined访问时在我的应用程序中返回process.env.LOCAL_CACHE_PATH

因此,环境变量在脚本中可用applicationStart.sh,但在应用程序从该脚本启动时未定义。

我正在寻找一种推荐的方法来将 Parameter Store 中的环境变量与 CodeDeploy 一起使用。

我已经阅读了几十篇关于类似主题的帖子,但无法解决。非常感谢任何指导。

4

1 回答 1

1

我正在使用的解决方案是将环境变量写入 .env 文件并在我的应用程序中使用它:

afterInstall.sh

echo LOCAL_CACHE_PATH=$(aws ssm get-parameters --output text --region us-east-1 --names LOCAL_CACHE_PATH --with-decryption --query Parameters[0].Value) >> /home/ubuntu/foo/.env
于 2020-06-05T04:32:12.507 回答