我正在使用 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.sh
CodeDeploy 文件中使用它并启动应用程序:
#!/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_PATH
undefined
访问时在我的应用程序中返回process.env.LOCAL_CACHE_PATH
。
因此,环境变量在脚本中可用applicationStart.sh
,但在应用程序从该脚本启动时未定义。
我正在寻找一种推荐的方法来将 Parameter Store 中的环境变量与 CodeDeploy 一起使用。
我已经阅读了几十篇关于类似主题的帖子,但无法解决。非常感谢任何指导。