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

标签 postgresql amazon-web-services docker devops

如果我通过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/

相关文章:

sql - 选择数据到 Postgres 数组中

mysql - 重复的 Inter_Columns

java - 为 Hibernate @ColumnTransformer 打开 JPA 等价物

mysql - RDS 实例上的慢 Mysql 存储过程

ruby - Docker中的Ruby Thin应用

node.js - Docker-compose 失败并出现错误 "No command specified"

ruby - 续集尝试使用 postgresql 而不是 postgres 作为适配器

amazon-web-services - AWS 云形成 : unable to create ElasticCache

amazon-web-services - AWS::EC2::SubnetRouteTableAssociation 未与路由表一起显示

docker - Gitlab CI - docker : command not found