burrow

burrow

基于AWS Lambda的全球分布式Go语言HTTP代理

Burrow是基于AWS Lambda构建的全球分布式HTTP代理,专为Go语言设计。该项目兼容标准Go http.Client,易于集成现有应用。Burrow实现了http.RoundTripper接口,支持通过多个AWS Lambda函数代理请求,并提供轮询传输功能在不同区域的函数间自动切换。这一设计为开发者提供了分布于多个区域的IP网络,适用于开发测试、负载模拟、匿名访问和绕过地理限制等多种应用场景。

BurrowHTTP代理AWS LambdaIP轮换多区域部署Github开源项目

Burrow

Burrow 是一个基于 AWS Lambda 构建的无服务器、全球分布式 HTTP 代理,专为 Go 语言设计。

它旨在与标准 Go *http.Client 完全兼容,这意味着它可以无缝地添加到许多现有应用程序中。Burrow 提供了 http.RoundTripper 接口的实现,通过一个或多个使用 Function URLs 暴露的 AWS Lambda 函数代理请求。

此外,还提供了一个轮询传输,可以轻松地在不同区域的多个 Lambda 函数之间自动轮换。

设计理念

Burrow 为您提供了一个在不同区域旋转 IP 的网络,这在多种情况下都很有用,包括:

  • 开发:测试您的应用程序在不同区域访问时的行为。
  • 负载测试:模拟服务的全球分布式流量。
  • 隐私:进行网络请求时使用匿名 IP 地址。
  • 绕过地理限制:访问区域限制的内容或服务。
  • API 速率限制:在调用 API 时减少 IP 地址使用配额的影响。
  • 网络爬虫:以分布式方式高效收集数据。
  • 多区域测试:验证应用程序在不同全球区域的行为。

通过 Burrow 的单个请求性能可能较慢,特别是在路由到远距离区域时。然而,Burrow 专为 Go 中的高并发使用而设计,其中整体吞吐量比单个请求延迟更重要。

特性

  • 通过 http.RoundTripper 实现的易用代理
  • 可选的轮询传输,用于在多个 lambda 代理之间轮换
  • 使用 Terraform 一键部署到 17 个 AWS 区域

使用方法

将 burrow 包添加到您的 Go 项目中:

go get github.com/myzie/burrow

http.Client 上启用:

proxy := "https://randomprefix.lambda-url.eu-west-2.on.aws/" client := &http.Client{Transport: burrow.NewTransport(proxy, "POST")} // 现在像平常一样使用 *http.Client

创建轮询传输:

proxies := []string{ "https://randomprefix1.lambda-url.us-east-1.on.aws/", "https://randomprefix2.lambda-url.us-east-2.on.aws/", "https://randomprefix3.lambda-url.us-west-1.on.aws/", } var transports []http.RoundTripper for _, u := range proxies { transports = append(transports, burrow.NewTransport(u, "POST")) } client := &http.Client{ Transport: burrow.NewRoundRobinTransport(transports), } // 客户端现在将为每个请求轮换使用提供的代理

或使用 burrow.NewRoundRobinClient 辅助函数:

client := burrow.NewRoundRobinClient([]string{ "https://randomprefix1.lambda-url.us-east-1.on.aws/", "https://randomprefix2.lambda-url.us-east-2.on.aws/", "https://randomprefix3.lambda-url.us-west-1.on.aws/", })

AWS 多区域部署

Burrow 包含 Terraform 配置,可以通过一个命令在您账户的 17 个默认启用的 AWS 区域中部署 Burrow:

make deploy BUCKET_NAME=my-terraform-state-bucket

命令完成后,将生成一个 function_urls.json 文件,其中包含每个区域中每个 Lambda 函数的 URL。然后,您可以在 Go 程序中读取此文件,并将这些值传递给 burrow.NewRoundRobinClient

有关更多信息,请参阅 Makefile。您需要安装以下工具:

  • terraform
  • make
  • go
  • jq
  • aws cli

默认启用的 AWS 区域:

ap-northeast-1 - 东京
ap-northeast-2 - 首尔
ap-northeast-3 - 大阪
ap-south-1 - 孟买
ap-southeast-1 - 新加坡
ap-southeast-2 - 悉尼
ca-central-1 - 加拿大中部
eu-central-1 - 法兰克福
eu-north-1 - 斯德哥尔摩
eu-west-1 - 爱尔兰
eu-west-2 - 伦敦
eu-west-3 - 巴黎
sa-east-1 - 圣保罗
us-east-1 - 弗吉尼亚北部
us-east-2 - 俄亥俄州
us-west-1 - 加利福尼亚北部
us-west-2 - 俄勒冈州

未来改进

  • Lambda 代理中的可选 API 密钥认证
  • 测试
  • 其他建议?

示例

多区域示例向 https://api.ipify.org?format=json 发送请求,以演示代理 IP 地址如何在不同区域之间变化。

$ go run ./cmd/example_multi_region {"ip":"13.36.171.187"} {"ip":"13.208.187.84"} {"ip":"18.142.184.58"} {"ip":"3.106.212.219"} {"ip":"13.60.11.169"} {"ip":"43.200.183.53"} {"ip":"3.127.170.76"} {"ip":"3.238.225.252"} {"ip":"54.185.130.119"} {"ip":"54.168.55.243"} {"ip":"13.201.18.225"} {"ip":"15.222.11.134"} {"ip":"54.247.221.168"} {"ip":"13.40.174.185"} {"ip":"15.228.175.92"} {"ip":"3.137.163.176"} {"ip":"54.177.165.5"} {"ip":"13.36.171.187"} # 回到第一个区域

定制开发和咨询

Burrow 的作者 @myzie 可以提供合同工作和咨询服务。如果您需要有关 Go、AWS、Terraform、云安全或 SaaS 开发的帮助,欢迎通过 Github 或 LinkedIn 联系。请查看我的 个人资料 以获取我的 LinkedIn 信息。

贡献

欢迎贡献!请随时提交拉取请求。

许可证

Apache 许可证 2.0

编辑推荐精选

Keevx

Keevx

AI数字人视频创作平台

Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。

即梦AI

即梦AI

一站式AI创作平台

提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作

扣子-AI办公

扣子-AI办公

AI办公助手,复杂任务高效处理

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
蛙蛙写作

蛙蛙写作

AI小说写作助手,一站式润色、改写、扩写

蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。

AI辅助写作AI工具蛙蛙写作AI写作工具学术助手办公助手营销助手AI助手
问小白

问小白

全能AI智能助手,随时解答生活与工作的多样问题

问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。

热门AI助手AI对话AI工具聊天机器人
Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

下拉加载更多