java 超时等待函数,外部呼叫上的Lambda函数超时

博客作者遇到AWS Lambda函数在VPC内无法进行外部API调用的问题。他们已经设置了NAT网关,调整了安全组和网络ACL,但仍然收到'ETIMEDOUT'错误。问题可能在于AWS配置的某些细节,如路由表或NAT网关的配置不正确。作者在本地环境和Postman中能成功执行相同的请求,暗示问题确实出在AWS的配置上。
摘要由CSDN通过智能技术生成

我有一个Lambda函数,我需要从中进行外部API调用 . 我已将Lambda函数添加到安全组,VPC和2个子网,它为我提供了以下文本:

启用VPC后,您的Lambda函数将失去默认的Internet访问权限 . 如果您的功能需要外部Internet访问,请确保您的安全组允许出站连接,并确保您的VPC具有NAT网关 .

我进入VPC,创建一个NAT网关(我让AWS创建一个EIP),将它附加到我的lambda函数的一个子网上 .

出于调试目的,我的安全组出站功能设置为所有流量/所有目的地( 0.0.0.0/0 ) . 此VPC的网络ACL也设置为此(具有5个子网,包括具有NAT网关的子网):

100 | ALL Traffic | ALL | ALL | 0.0.0.0/0 | ALLOW

具有相同2个子网的路由表位于VPC上, 0.0.0.0/0 路由设置为以NAT网关为目标 .

VPC上还有一个带有3个其他子网的不同路由表,其中 0.0.0.0/0 路由设置为目标Internet网关 .

两个路由表都具有相同的 local 目标IP(VPC的IP) .

我得到的错误是:

{ Error: connect ETIMEDOUT x.x.x.x:443

at Object.exports._errnoException (util.js:1018:11)

at exports._exceptionWithHostPort (util.js:1041:20)

at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1090:14)

code: 'ETIMEDOUT',

errno: 'ETIMEDOUT',

syscall: 'connect',

address: 'x.x.x.x',

port: 443 }

我正在运行的节点代码在我的桌面节点环境中工作,POST调用在postman中工作,所以我很确定这是我的AWS配置的问题 .

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值