在 gitlab-ci 的 localstack 中运行 lambda

问题描述

所以我在本地(在我的笔记本电脑上)运行了 localstack,并且可以将无服务器应用程序部署到它,然后调用一个 Lambda。
但是,我真的很难在 gitlab-ci 中做同样的事情。
这是 .gitlab-ci.yml 的相关部分:

integration-test:
  stage: integration-test
  image: node:14-alpine3.12
  tags:
    - docker
  services:
    - name: localstack/localstack
      alias: localstack
  variables:
    LAMBDA_EXECUTOR: docker
    HOSTNAME_EXTERNAL: localstack
    DEFAULT_REGION: eu-west-1
    USE_SSL: "false"
    DEBUG: "1"
    AWS_ACCESS_KEY_ID: test
    AWS_SECRET_ACCESS_KEY: test
    AWS_DEFAULT_REGION: eu-west-1
  script:
    - npm ci
    - npx sls deploy --stage local
    - npx jest --testMatch='**/*.integration.js'
  only:
    - merge_requests

localstack 启动,部署工作正常。但是一旦 lambda 被调用(在集成测试中),localstack 就会尝试为 lambda 创建一个容器来运行它,但它会失败并显示以下内容

Lambda process returned error status code: 1. Result: . Output:\\nCannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?\\nmust specify at least one container source (.....)

我尝试将 DOCKER_HOST 设置为 tcp://docker:2375 但它失败了:

Lambda process returned error status code: 1. Result: . Output:\\nerror during connect: Post http://docker:2375/v1.29/containers/create: dial tcp: lookup docker on 169.254.169.254:53: no such host\

DOCKER_HOST 设置为 tcp://localhost:2375 也会抱怨:

Lambda process returned error status code: 1. Result: . Output:\\nCannot connect to the Docker daemon at tcp://localhost:2375. Is the docker daemon running?\\nmust specify at least one container source

有没有人让 lambdas 在共享 gitlab runners 中的 localstack 中运行?
谢谢你的帮助:)

解决方法

在 docker 中运行 docker 通常是一个坏主意,因为它是一个很大的安全漏洞。授予对本地 docker 守护进程的访问权限等同于授予运行程序的 root 权限。

如果还想使用宿主机上安装的docker来生成容器,参考官方文档-https://docs.gitlab.com/ee/ci/docker/using_docker_build.html#use-docker-socket-binding

归结为添加

volumes = ["/var/run/docker.sock:/var/run/docker.sock","/cache"]

到运行器配置中的 [runners.docker] 部分。

问题是,你为什么需要docker?根据 https://github.com/localstack/localstack ,将 LAMBDA_EXECUTOR 设置为 local

在本地机器上的临时目录中运行 Lambda 函数

这应该是解决您的问题的最佳方法,并且不会损害您的跑步者主机的安全性。