gpt4 book ai didi

postgresql - AWS docker multicontainer应用程序上的哪个postgres连接字符串?

转载 作者:行者123 更新时间:2023-12-02 20:00:15 25 4
gpt4 key购买 nike

如果我通过AWS上的Dockerrun.aws.js运行docker multicontainer应用程序,应该使用哪个Postgres连接字符串?

我有一个Node.JS / Postgres / docker网络应用程序。 Postgres在自己的容器中运行,该应用程序也是如此。该应用在本地运行正常。当我通过ECR和BeanStalk将其部署到AWS时,该应用程序成功部署并运行,但该Web应用程序未连接到Postgres。

docker-compose.yaml中,连接字符串中的主机是容器的名称(在我的情况下是db)。这不适用于AWS。 localhost127.0.0.1都没有。

这是我的Dockerrun.aws.js:

{
"AWSEBDockerrunVersion": 2,
"volumes": [
{
"name": "db-data",
"host": {
"sourcePath": "/data/db"
}
}
],
"containerDefinitions": [
{
"name": "db",
"image": "db_image_name",
"essential": true,
"memory": 128,
"environment": [
{
"name": "POSTGRES_USER",
"value": "postgres"
},
{
"name": "POSTGRES_PASSWORD",
"value": "password"
},
{
"name": "PGDATA",
"value": "/data/db/pgdata"
}
],
"portMappings": [
{
"hostPort": 5432,
"containerPort": 5432
}
],
"mountPoints": [
{
"sourceVolume": "db-data",
"containerPath": "/data/db"
}
]
},
{
"name": "app",
"image": "app_image_name",
"essential": true,
"memory": 128,
"environment": [
{
"name": "NODE_ENV",
"value": "production"
},
{
"name": "DB_HOST",
"value": "db"
},
{
"name": "DB_PORT",
"value": "5432"
},
{
"name": "DB_PASSWORD",
"value": "password"
}
],
"links": [
"db"
],
"portMappings": [
{
"hostPort": 80,
"containerPort": 3000
}
]
}
]
}

我应该在环境变量 DB_HOST 中放入什么? (应用程序使用DB_HOST和DB_PORT来构造连接字符串。)非常感谢。

最佳答案

Beanstalk和Dockerrun.aws.json格式使您可以使用以下语法从同一定义文件链接容器:
"links": ["some-name"]
根据您的情况,您可以添加一个指向"db"的链接,并且postgres将在db下的应用程序容器中可用。如果您不想将postgres容器公开,甚至不需要映射容器端口。

您可以在以下文档中看到一个正在使用的示例:https://docs.aws.amazon.com/elasticbeanstalk/latest/dg/create_deploy_docker_v2config.html#create_deploy_docker_v2config_dockerrun

关于postgresql - AWS docker multicontainer应用程序上的哪个postgres连接字符串?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54309667/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com