client.等待标头时超时
来源:stackoverflow
时间:2024-03-31 09:27:35 115浏览 收藏
知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个Golang开发实战,手把手教大家学习《client.等待标头时超时》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!
我有一个用 go 编写的 lambda,它与 aws 中应用程序负载均衡器后面的轻量级 http 应用程序进行通信:
package main import ( "io/ioutil" "log" "net/http" "os" "time" ) func main() { for { req, err := http.NewRequest("GET", "http://my-app-12345.us-east-1.elb.amazonaws.com:8080", nil) if err != nil { log.Fatal("Error reading request. ", err) } req.Header.Set("Load-Rate", os.Getenv("LOAD")) client := &http.Client{Timeout: time.Second * 10} resp, err := client.Do(req) if err != nil { log.Fatal("Error reading response. ", err) } if resp.StatusCode == http.StatusOK { bodyBytes, err := ioutil.ReadAll(resp.Body) if err != nil { log.Fatal(err) } bodyString := string(bodyBytes) log.Println(bodyString) } time.Sleep(time.Duration(10) * time.Millisecond) } }
我已经在 lambda 和 alb 使用的安全组中的所有端口上打开了全球访问权限,并且我可以从我的家用计算机上很好地卷曲端点。但是,当我尝试在 lambda 中运行此命令时,我在 cloudwatch 日志中收到以下内容:
2020-06-04t07:06:31.028-05:00 进程在完成之前退出 要求 2020-06-04t07:06:41.100-05:00 2020/06/04 12:06:41 错误 阅读回应。得到 http://my-app-12345.us-east-1.elb.amazonaws.com:8080: net/http:等待连接时请求被取消 (等待标头时超出了 client.timeout) 2020-06-04t07:06:41.101-05:00 2020/06/04 12:06:41 退出状态 1
我很难确定这是 go 问题还是我在 aws 中的某些配置错误。我对 go 在这里抛出的错误不太熟悉。
解决方案
自从您写了有关其安全组以来,您的 lambda 似乎位于 VPC 中。如果是这种情况,那么超时的最可能原因是VPC 中的 lambda 没有互联网访问权限,也没有公共 IP,即使它位于公共子网中。
来自docs:
将函数连接到公共子网不会为其提供 Internet 访问权限或公共 IP 地址。
由于您的 ALB 是公共的(您从家里卷曲它),您的 lambda 无法访问它,即使它们位于同一子网中也是如此。
要纠正此问题,您必须使用正确的路由设置 NAT 网关或实例,以便能够从 VPC 中的 lambda 与您的公共 ALB 进行通信,并将您的 lambda 置于私有子网中。
好了,本文到此结束,带大家了解了《client.等待标头时超时》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
139 收藏
-
204 收藏
-
325 收藏
-
477 收藏
-
486 收藏
-
439 收藏
-
357 收藏
-
352 收藏
-
101 收藏
-
440 收藏
-
212 收藏
-
143 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习