python - AWS - Lambda 无法通过 Python SDK 调用另一个 lambda

标签 python amazon-web-services aws-lambda aws-sdk aws-api-gateway

我正在尝试使用 python SDK 从另一个 lambda 调用 lambda 函数。两个 lambda 函数都属于同一个 VPC。触发器 lambda 仅包含调用第二个 lambda (loader_development) 的 python 脚本。 loader_development lambda 的 APIGateway 是私有(private)的,并且配置了一个资源策略,该策略拒绝访问不属于该特定 VPC 的所有 IP 地址。

触发器 lambda 中我的 Python 脚本是:

from __future__ import print_function

import json
import logging
import os
from urllib2 import urlopen,Request,HTTPError
import boto3

logger = logging.getLogger()
logger.setLevel(logging.INFO)
region = os.environ['AWS_REGION']

def lambda_handler(event, context):
    invokeLambda = boto3.client('lambda', region_name = 'us-east-1')  
    request = {'resource':'/bucketstatus/latest','path':'/bucketstatus/latest','httpMethod':'GET'}
    invoke_response = invokeLambda.invoke(FunctionName='loader_development',
                                           InvocationType='RequestResponse',
                                           Payload=json.dumps(request))
    print(invoke_response['Payload'].read())

logger.info('Process Complete')

因此,/bucketstatus/latest 是一个 GET 请求,此端点驻留在 loader_development lambda 的 APIGateway(这是私有(private)的)中。 loader_development lambda 是一个 spring boot 应用程序,而触发器 lambda 是一个独立的 lambda,只有一个 python 脚本来调用 loader_development lambda 的端点来获取响应。

测试此脚本时,它给出状态 500 和内部服务器错误。 错误:

2019-10-09 10:09:09.279 ERROR 1 --- [ main] c.a.s.proxy.AwsProxyExceptionHandler : Called exception handler for:
com.amazonaws.serverless.exceptions.InvalidRequestEventException: The incoming event is not a valid request from Amazon API Gateway or an Application Load Balancer
10:09:09 at com.amazonaws.serverless.proxy.internal.servlet.AwsProxyHttpServletRequestReader.readRequest(AwsProxyHttpServletRequestReader.java:41)
10:09:09 at com.amazonaws.serverless.proxy.internal.servlet.AwsProxyHttpServletRequestReader.readRequest(AwsProxyHttpServletRequestReader.java:28)
10:09:09 at com.amazonaws.serverless.proxy.internal.LambdaContainerHandler.proxy(LambdaContainerHandler.java:174)
10:09:09 at com.amazonaws.serverless.proxy.internal.LambdaContainerHandler.proxyStream(LambdaContainerHandler.java:209)
10:09:09 at com.trimble.roadrunner.StreamLambdaHandler.handleRequest(StreamLambdaHandler.java:49)
10:09:09 at lambdainternal.EventHandlerLoader$2.call(EventHandlerLoader.java:888)
10:09:09 at lambdainternal.AWSLambda.startRuntime(AWSLambda.java:293)
10:09:09 at lambdainternal.AWSLambda.<clinit>(AWSLambda.java:64)
10:09:09 at java.lang.Class.forName0(Native Method)
10:09:09 at java.lang.Class.forName(Class.java:348)
10:09:09 at lambdainternal.LambdaRTEntry.main(LambdaRTEntry.java:114)

奇怪的是,当我尝试调用其他 lambda(微服务)时,请求得到处理,并且状态为 200。示例 lambda 也在 VPC 内部,并且具有私有(private) APIGateway。

我真的不确定我错过了什么。任何帮助将不胜感激!

最佳答案

W.R.T。 GitHub 解决方案,我收到此异常,因为我没有在请求对象上包含 requestContext 属性。所以我将请求对象修改为:

request = {'resource': '/bucketstatus/latest', 'path': '/bucketstatus/latest', 'httpMethod': 'GET',
               'requestContext':{'accountId':'821665253511',
                                 'resourceId': '',
                                  'stage': 'development',
                                  'requestId': context.aws_request_id,
                                  'identity': {
                                     'cognitoIdentityPoolId': None,
                                     'accountId': None,
                                     'cognitoIdentityId': None,
                                     'caller': None,
                                     'apiKey': None,
                                     'sourceIp': '',
                                     'cognitoAuthenticationType': None,
                                     'cognitoAuthenticationProvider': None,
                                     "userArn":context.invoked_function_arn
                                  }
                                },
                "apiId": "No need"
               }

在此更改后,我能够获得状态代码为 200 的正确响应。

关于python - AWS - Lambda 无法通过 Python SDK 调用另一个 lambda,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58306012/

相关文章:

javascript - API Gateway Javascript SDK - Node Js 示例?

python - 使用 IAM 角色凭证通过 Python 卸载到 S3

node.js - 我应该使用扫描还是查询?

node.js - 如何在 Alexa Skill 中运行特定 intent 后运行 YesIntent

python - 元素的列表比较

python - 如何使用图像每个像素的值绘制 3d 图形?

python - 从另一个多索引 pandas 数据帧在多索引 pandas 数据帧中添加额外条目

amazon-web-services - 随机主机端口注册ELB到ECS服务

.net - 为什么我的 AWS Lambda 在 ARM64 架构中运行时崩溃?

python - 关于正则表达式