docker - 创建从 docker 容器上的进程到同一容器上的另一个进程的连接时,连接被拒绝

标签 docker localstack

我正在使用 localstack 框架并在 docker 容器上运行它 我能够从主机连接到容器上运行的 dynamo 服务(端口 4569)。 当尝试从在此容器上运行的 lambda 连接到 dynamo(在同一容器上运行)时,连接被拒绝。我使用的IP是容器的名称。 (例如,telnet localstack 4569 将因从 lambda 运行而失败)

Docker ps 返回:

13:06:33  CONTAINER ID        IMAGE                          COMMAND                  CREATED             STATUS              PORTS                                                                                    NAMES
13:06:33  b909ac695561        localstack/localstack:0.11.4   "docker-entrypoint.sh"   2 minutes ago       Up 2 minutes        4566-4568/tcp, 4593-4597/tcp, 0.0.0.0:4569-4592->4569-4592/tcp, 0.0.0.0:8055->8080/tcp   localstack

docker 网络检查 localstack-network 返回:

13:06:33  [
13:06:33      {
13:06:33          "Name": "localstack-network",
13:06:33          "Id": "09994610b0d71dfc4fe0147bbc884a749362c3fb42397366591c73e3c10702eb",
13:06:33          "Created": "2020-10-04T10:03:52.586816186Z",
13:06:33          "Scope": "local",
13:06:33          "Driver": "bridge",
13:06:33          "EnableIPv6": false,
13:06:33          "IPAM": {
13:06:33              "Driver": "default",
13:06:33              "Options": null,
13:06:33              "Config": [
13:06:33                  {
13:06:33                      "Subnet": "100.66.0.0/16",
13:06:33                      "Gateway": "100.66.0.1"
13:06:33                  }
13:06:33              ]
13:06:33          },
13:06:33          "Internal": false,
13:06:33          "Attachable": true,
13:06:33          "Ingress": false,
13:06:33          "ConfigFrom": {
13:06:33              "Network": ""
13:06:33          },
13:06:33          "ConfigOnly": false,
13:06:33          "Containers": {
13:06:33              "b909ac695561200c1ab43c70c9f25cd537622593b7eade03d16af89b70c97d76": {
13:06:33                  "Name": "localstack",
13:06:33                  "EndpointID": "783e7aefbef801d7707d46f664b6adf329dceeee6108d23a36c63d5cb3a3fdae",
13:06:33                  "MacAddress": "02:42:64:42:00:02",
13:06:33                  "IPv4Address": "100.66.0.2/16",
13:06:33                  "IPv6Address": ""
13:06:33              }
13:06:33          },
13:06:33          "Options": {},
13:06:33          "Labels": {
13:06:33              "com.docker.compose.network": "localstack-network",
13:06:33              "com.docker.compose.project": "infra",
13:06:33              "com.docker.compose.version": "1.24.1"
13:06:33          }
13:06:33      }
13:06:33  ]

docker-compose.yaml:

  services:
  localstack:
    image: localstack/localstack:0.11.4
    container_name: localstack
    networks:
      - localstack-network
    ports:
      - "4566-4597:4566-4597"
      - '8080:8080'
    environment:
      - SERVICES=lambda,stepfunctions,dynamodb,s3,sns
      - DEBUG=1
      - DATA_DIR=/tmp/localstack/data
      - PORT_WEB_UI=${PORT_WEB_UI- }
      - LAMBDA_EXECUTOR=docker #${LAMBDA_EXECUTOR- docker-reuse}
      - DOCKER_HOST=unix:///var/run/docker.sock
      - LAMBDA_REMOTE_DOCKER=true
      - LAMBDA_REMOVE_CONTAINERS=true
    volumes:
      - "/tmp${TMPDIR:-/tmp/localstack}:/tmp/localstack"
      - "/var/run/docker.sock:/var/run/docker.sock"

最佳答案

在 localstack 中运行的 Lambda 实际上是在容器中执行的,因此您有一个容器 (Lambda) 在另一个容器 (localstack) 中运行,因此 Lambda 如果需要与其他 localstack 服务(如 DynamoDB)通信,则需要知道 localstack 地址.

在您的 Lambda 函数内,获取本地堆栈地址并在用于创建 DynamoDB 客户端实例的配置对象中使用它 - 这是一个 C# 示例:

var serviceURL = $@"http://{Environment.GetEnvironmentVariable("LOCALSTACK_HOSTNAME")}:4569";

可能还有其他原因导致您的 Lambda 无法连接到 localstack,因此请随意使用 docker/docker-compose yaml 设置文件和函数本身来扩展您的问题,如果您仍然这样做,我也许可以为您提供进一步的帮助卡住了。

PS:您还可以将所有 localstack 服务切换到单个端口 4566,因为您使用的是最新版本。

关于docker - 创建从 docker 容器上的进程到同一容器上的另一个进程的连接时,连接被拒绝,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64193447/

相关文章:

node.js - docker :找不到命令 "/bin/sh"

php - Laravel 和 LocalStack 的最大执行时间

unit-testing - Terratest - 使用模拟 AWS 服务

java - java 套接字上的 Docker : java.net.ConnectException: Connection refused (Connection refused)

docker - 在不同的docker容器中运行Jfrog cli并在Gitlab CI/CD管道中使用该cli

docker - docker中的 "Thin Pool"是什么意思?

go - 在本地堆栈上使用 aws-sdk-go 创建的 S3 存储桶最终位置为 :/none

terraform - Localstack - AWS API Gateway 使用 Terraform 启用二进制支持

amazon-web-services - Windows 10 Home上的Localstack提供ERR_CONNECTION_REFUSED

laravel - Laradock 不支持 mysql