6

我正在使用带有 Node.js 的 AWS Lambda 开发一个项目。我们使用 Docker 容器作为我们的开发环境。

我们当前的设置在端口:3000 上启动了本地 AWS SAM。它运行 start-api 并将函数安装在我的 template.yml 文件中。我使用邮递员测试这些函数以将 JSON 发送到已安装的 API 端点,如下所示:http: //127.0.0.1 :3000/foo

Docker 设置还在 :4000 上启动了一个单独的 Node.js 实例。

如上所述,我能够在本地测试 Lambda 的东西。但是,我想激活调试,以便我可以单步执行函数并检查变量,而不是使用console.log(). 我不知道如何编辑 Dockerfile / docker-compose.yml 来实现这一点。

这是我的 docker-compose 文件:

version: '3'
services:
  web:
    build: ./web
    container_name: someapp
    command: npm run dev
    volumes:
      - ./web:/usr/app/
      - /usr/app/node_modules
    ports:
      - "4000:4000"
    environment:
      DATABASE_URL: mongo://someapp:someapp@10.10.62.205:37017,10.10.62.205:37018,10.10.62.205:37019/somedb
  sam:
    build: serverless/.
    container_name: samlocal
    command: sam local start-api --host 0.0.0.0
    environment:
      COMPOSE_CONVERT_WINDOWS_PATHS: 1
      SAM_DOCKER_VOLUME_BASEDIR: ${CURRENT_DIRECTORY}/serverless
      DATABASE_URL: mongo://someapp:someapp@10.10.62.205:37017,10.10.62.205:37018,10.10.62.205:37019/somedb
    volumes:
      - /var/run/docker.sock:/var/run/docker.sock
      - ./serverless:/var/opt
    ports:
      - "3000:3000"

这是 SAM 的 Dockerfile,它位于一个名为“serverless”的目录中:

FROM alpine:3.6

ENV VERSION=0.2.2

RUN apk add --no-cache curl && \
    curl -sSLO https://github.com/awslabs/aws-sam-local/releases/download/v${VERSION}/sam_${VERSION}_linux_386.tar.gz && \
    tar -C /usr/local/bin -zxvf /sam_${VERSION}_linux_386.tar.gz && \
    apk del curl && \
    rm -f /sam_${VERSION}_linux_386.tar.gz

# awscli for "sam package" and "sam deploy"
RUN apk add --no-cache py-pip && pip install awscli

WORKDIR /var/opt

EXPOSE 3000

我已经尝试了在 docker-compose.yml 的 RUN 指令中将 --d 标志添加到“sam”服务的各种排列。例如:sam local start-api --host 0.0.0.0 --d 8080。然后我尝试更改端口映射以公开它。但是,我不知道如何让端口映射工作。一旦我到达端点,我就会收到端口错误。

当谈到 Lambda 的东西时,我仍然在 docker / docker-compose 和一个完整的 nube 上加快速度,如果这个问题很愚蠢,很抱歉。

蒂亚!

4

2 回答 2

4

我已经确定我最初的方法是不正确的。

使 SAM Local 成为我的 docker-compose 设置的一部分——或者我认为——的好处是我为我的队友省去了在他们的机器上本地安装它的麻烦。并以这种方式启动它:

sam local start-api --host 0.0.0.0

似乎赋予了“自动”安装所有 API 端点的额外便利。

但是,这并不能为用户提供打开和关闭调试的灵活性。它也不允许用户在使用 Postman POST 输入或从文件加载输入数据之间切换。

所以这是我现在的做法:

$ npm install aws-sam-local --g
$ cd path/to/my/template.yml

要使用邮递员:

$ sam local start-api

或邮递员加调试器:

$sam local start-api -d 5858

绕过 Postman 并简单地从文件中读取输入:

$ sam local invoke "NameOfResource" -e ./path/to/file.json

或者用调试器做同样的事情:

$ sam local invoke "NameOfResource" -e ./path/to/file.json -d 5858

注意:在上面的例子中,"NameOfResource"必须是一个字符串,并且它必须与 template.yml 中列出的资源名称匹配(以防它与源代码中的实际函数名称不同)。

这样做我可以在 WebStorm 中连接远程 Node.js 调试器并设置断点。我还可以连接 Visual Studio Code 调试器。但是,Visual Studio Code 似乎忽略了我的断点,迫使我使用debugger;语句。这很不幸,因为我的队友都使用 Visual Studio Code,而 WebStorm 不是免费的。如果有人知道如何解决 Visual Studio 问题,请大喊!

于 2017-11-27T22:21:34.787 回答
0

这是一篇文章,解释了 PyDev 远程调试器的操作,用于通过 Eclipse IDE 单步执行在 Docker 容器中运行的 Lambda 代码。

https://medium.com/debugging-aws-lambda-functions-from-eclipse-with/debugging-aws-lambda-python-function-with-eclipse-using-pydev-1e0fa4b2deff

它是 Python 而不是 Node,但它可能有助于大致了解在 Docker 容器中运行的调试脚本。

于 2019-07-17T00:32:47.553 回答