在 AWS AppSync 上查询 GraphQL 后的 AWS Lambda 超时

chr*_*rkl 0 amazon-web-services aws-lambda graphql aws-appsync aws-amplify

我按照本教程使用 Amplify 部署了一个 AWS AppSync GraphQL 终端节点:

https://aws-amplify.github.io/docs/js/api#amplify-graphql-client

我用 Node.js 和 TypeScript 创建了一个 Lambda 函数来查询数据:

import { APIGatewayEvent, Callback, Context, Handler } from 'aws-lambda';
import Amplify, { API, graphqlOperation } from "aws-amplify";
import * as queries from './src/graphql/queries';
import * as mutations from './src/graphql/mutations';
import { CreateBlogInput } from './src/API';
import aws_config from "./src/aws-exports";

Amplify.configure(aws_config);

export const list: Handler = async (event: APIGatewayEvent, context: Context, cb: Callback) => {
  const allBlogs = await API.graphql(graphqlOperation(queries.listBlogs));

  // this seems to be working
  console.log(JSON.stringify(allBlogs));

  const response = {
    statusCode: 200,
    body: JSON.stringify(allBlogs),
  };

  cb(null, response);
}
Run Code Online (Sandbox Code Playgroud)

现在,当我通过 HTTP 调用 Lambda 函数时,它会检索数据并将其记录到控制台。但它永远不会完成请求并做出响应,它总是遇到超时,即使我将超时增加到 30 秒。运行突变和插入数据也会发生同样的情况。

任何想法可能是错误的?

tho*_*ace 5

这里的问题是你正在混合你的 lambda 签名。

要么使用async返回(或在出现错误时抛出):

export const list: Handler = async (event: APIGatewayEvent, context: Context, cb: Callback) => {
  // ... rest of function

  return response;
}
Run Code Online (Sandbox Code Playgroud)

或者你不使用async而你使用的callback功能:

export const list: Handler = (event: APIGatewayEvent, context: Context, cb: Callback) => {
  // ... rest of function

  cb(null, response);
}
Run Code Online (Sandbox Code Playgroud)