使用 AWS SAM 和 Go 构建 API
AWS SAM是通过基础设施即代码(IAC)部署Web应用程序的绝佳方式。我最近尝试在我的工作项目中使用它,却遇到了一个严峻的现实……
Go是AWS的丑小鸭 ?
AWS SAM文档中专门介绍Go的部分非常简短且含糊不清,建议大量重复我们的源代码!每个lambda函数都有一个go.mod、go.sum和实用函数?!
我写这篇文章是为了像我一样迷茫的你??。让我们一起解决这个问题!
这将是一个两部分的系列:
- 文件结构(本文)
- SAM配置
Go运行时的上下文
目前,lambda的Go运行时不受支持。这意味着AWS lambda没有特定选项来指定您的代码是用Go编写的。相反,AWS提供2个通用运行时?:
- al2(Amazon Linux 2)
- al2023(Amazon Linux 2023)
这指的是lambda将运行的操作系统。建议使用al2023,因为它更新,并且与AWS Graviton处理器兼容,后者可以以更低的价格提供更好的性能。
无论如何,这些运行时要求我们提供一个可执行文件(通常命名为bootstrap),该文件将在每个lambda函数中执行。因此,我们不是向lambda交付代码,而是交付我们之前用Go编译的可执行文件。很简单,对吧?
这也消除了像JS这样的语言需要使用lambda层的必要性,因为所有常见的依赖项都将打包在已编译的可执行文件中?。
问题
那么,我们如何构建该可执行文件呢?AWS建议我们每个lambda都应该存储在一个文件夹中,以及它的go.mod和go.sum,他们提供的模板如下所示:
<code>. ├── hello-world/ │ ├── go.mod │ ├── go.sum │ └── main.go ├── events/ │ └── ... ├── samconfig.toml └── template.yaml</code>
这是template.yaml中的函数定义
<code> HelloWorldFunction: Type: AWS::Serverless::Function Metadata: BuildMethod: go1.x Properties: CodeUri: hello-world/ Handler: bootstrap Runtime: provided.al2023 Architectures: - x86_64 Events: CatchAll: Type: Api Properties: Path: /hello Method: GET</code>
如果我们查看Lambda定义,我们会了解到:
- BuildMethod: go1.x 我们使用AWS内置的Go构建器来为我们构建可执行文件
- CodeUri: hello-world/ lambda代码将专门存储在这个目录中。
- Handler: bootstrap 可执行文件的名称将是bootstrap
- Runtime: provided.al2023 这将是运行时。
你看到问题了吗?目前我们需要第二个lambda,我们必须创建一个带有自己go.mod、go.sum和依赖项的新目录,如果我们想在两个lambda之间共享一个实用函数怎么办?太糟糕了?!你必须将相同的文件复制到新的lambda文件夹中。留下一个看起来像这样的文件结构:
<code>. ├── function1/ │ ├── go.mod │ ├── go.sum │ ├── main.go │ └── SHAREDFUNC.go ├── function2/ │ ├── go.mod │ ├── go.sum │ ├── main.go │ └── SHAREDFUNC.go ├── events/ │ └── ... ├── samconfig.toml └── template.yaml</code>
这太糟糕了?!有很多重复的代码!并且随着我们添加的lambda越多,它会变得更糟。一定有更好的方法!
解决方案
由于我想通过所有lambda共享go.mod、go.sum和实用程序代码,我想出了这个结构:
<code>. ├── hello-world/ │ ├── go.mod │ ├── go.sum │ └── main.go ├── events/ │ └── ... ├── samconfig.toml └── template.yaml</code>
- 我将所有公共代码分解到internal/文件夹中,
- 将go.mod和go.sum文件放在根目录中
- 将所有lambda入口点移动到/cmd(在Go中存在这种约定,每当项目产生多个可执行文件时,入口点都放在cmd目录中)
现在我只需要通知AWS SAM这个新的结构?!我只是通过调整CodeUri和Handler的值找到了解决方案。
秘密?
似乎如果你
- 将go.mod和go.sum移动到根文件夹
- 将CodeUri设置为函数入口点所在的任何文件夹。
SAM将自动检测它并使用根依赖项和internal/代码进行构建? ? ?
<code> HelloWorldFunction: Type: AWS::Serverless::Function Metadata: BuildMethod: go1.x Properties: CodeUri: hello-world/ Handler: bootstrap Runtime: provided.al2023 Architectures: - x86_64 Events: CatchAll: Type: Api Properties: Path: /hello Method: GET</code>
可以更好吗?
是的✨,我们将在下一篇文章中讨论更多自定义Go编译的方法!
以上是使用 AWS SAM 和 Go 构建 API的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

Golang在性能和可扩展性方面优于Python。1)Golang的编译型特性和高效并发模型使其在高并发场景下表现出色。2)Python作为解释型语言,执行速度较慢,但通过工具如Cython可优化性能。

Golang在并发性上优于C ,而C 在原始速度上优于Golang。1)Golang通过goroutine和channel实现高效并发,适合处理大量并发任务。2)C 通过编译器优化和标准库,提供接近硬件的高性能,适合需要极致优化的应用。

goisidealforbeginnersandsubableforforcloudnetworkservicesduetoitssimplicity,效率和concurrencyFeatures.1)installgromtheofficialwebsitealwebsiteandverifywith'.2)

Golang适合快速开发和并发场景,C 适用于需要极致性能和低级控制的场景。1)Golang通过垃圾回收和并发机制提升性能,适合高并发Web服务开发。2)C 通过手动内存管理和编译器优化达到极致性能,适用于嵌入式系统开发。

GoimpactsdevelopmentPositationalityThroughSpeed,效率和模拟性。1)速度:gocompilesquicklyandrunseff,ifealforlargeprojects.2)效率:效率:ITScomprehenSevestAndArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdEcceSteral Depentencies,增强开发的简单性:3)SimpleflovelmentIcties:3)简单性。

Golang和Python各有优势:Golang适合高性能和并发编程,Python适用于数据科学和Web开发。 Golang以其并发模型和高效性能着称,Python则以简洁语法和丰富库生态系统着称。

Golang和C 在性能上的差异主要体现在内存管理、编译优化和运行时效率等方面。1)Golang的垃圾回收机制方便但可能影响性能,2)C 的手动内存管理和编译器优化在递归计算中表现更为高效。

Golang和C 在性能竞赛中的表现各有优势:1)Golang适合高并发和快速开发,2)C 提供更高性能和细粒度控制。选择应基于项目需求和团队技术栈。
