轻松搭建基于 Serverless 的 Go 应用(Gin、Beego 举例)

本文涉及的产品
函数计算FC,每月15万CU 3个月
Serverless 应用引擎免费试用套餐包,4320000 CU,有效期3个月
简介: 函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传。本文将为大家介绍如何快速搭建基于 Serverless 的 Go 应用。

74.jpg
镜像下载、域名解析、时间同步请点击 阿里巴巴开源镜像站

函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传。函数计算准备计算资源,并以弹性伸缩的方式运行用户代码,而用户只需根据实际代码运行所消耗的资源进行付费。
Fun 是一个用于支持 Serverless 应用部署的工具,能帮助您便捷地管理函数计算、API 网关、日志服务等资源。它通过一个资源配置文件(template.yml),协助您进行开发、构建、部署操作。

说明: 本文介绍的技巧需要 Fun 版本大于等于 3.6.4。

一、效果预览

本文涉及到的两个应用示例部署后的链接,点击预览效果:

  1. Gin 简单示例:http://gentest.functioncompute.com/ping
  2. Beego 简单示例:http://beegotest.functioncompute.com
  3. Gin 博客网站示例:http://mdblog.functioncompute.com

二、环境准备

首先按照 Fun 的安装文档里介绍的方法将 Fun 安装到本机。
PS: 本文介绍的方法,不需要安装 Docker,仅仅安装 Fun 即可,最简单的方式就是直接下载可执行的二进制文件。
安装完成后,可以执行 fun --version 检查 Fun 是否安装成功。

示例一:迁移 gin 示例到函数计算

首先我们按照官方示例的步骤,安装 gin(需要 golang 版本在 1.11+ 以上):

go get -u github.com/gin-gonic/gin

创建一个 example.go,内容填写如下:

package main
import "github.com/gin-gonic/gin"
func main() {
    r := gin.Default()
    r.GET("/ping", func(c *gin.Context) {
        c.JSON(200, gin.H{
            "message": "pong",
        })
    })
  r.Run() // listen and serve on 0.0.0.0:8080 (for windows "localhost:8080")
}

使用下面的命令启动应用:

go run example.go

然后访问 localhost:8080/ping,可以看到返回结果如下:
3.png
最后直接使用 fun deploy 即可部署。

fun deploy

我们这里详细介绍下第一次部署流程:
1、Fun 首先检测到这不是一个 Fun 项目,会提示是否自动创建(按下回车或者输入 y 即可)
2、然后 Fun 又会尝试去检测应用的启动端口(函数计算要求必须启动在 0.0.0.0:9000),如果不匹配,则会协助修改:
4.png
3、按下回车,Fun 会自动检测构建生成的可执行程序,如果检测不到,则提示用户使用指定命令进行编译
5.png
4、按下回车后,就会自动进行编译了,编译完成后,会自动生成 Fun 所需要的 bootstrap 文件以及 template.yml 文件,然后会进行自动部署操作,在部署前,会首先列出本次部署带来的变更:
6.png
5、如果确认上面的变更没有问题,再按下回车即可开始资源的部署流程。
7.png
部署完成后,可以看到会自动生成一个可以测试访问的临时域名 14118335-1911504709953557.test.functioncompute.com,通过这个临时域名,可以用于开发、测试时预览应用。
使用该临时域名,访问应用的 API 接口 14118335-1911504709953557.test.functioncompute.com/ping 测试,效果如下:
8.png
备注:临时域名仅仅用作演示以及开发,是有时效的,如果用作生产,请绑定已经备案的域名。

示例二:迁移 beego 示例到函数计算

首先我们按照官方示例的步骤,搭建 beego 应用:

go get github.com/astaxie/beego

创建一个 hello.go,内容填写如下:

package main
import "github.com/astaxie/beego"
func main(){
    beego.Run()
}

使用下面的命令启动应用:

go run hello.go

然后访问 localhost:8080,可以看到返回结果。
最后部署,直接使用 fun deploy 经历类似示例一的流程后,就可以通过 Fun 返回的临时域名预览应用了。

示例三:迁移 gin 搭建的博客应用到函数计算

示例三我们选择一个稍微复杂一些的应用,我们按照官方帮助文档的步骤,搭建一个基于 gin 的 blog 应用:
1、克隆项目到本地(直接下载 zip 包也可以):

git clone https://github.com/tanhe123/mdblog.git

2、修改配置文件
config 目录下,有一个配置文件 config.example.toml,将其复制一份,并修改名称为 config.toml,然后修改里面的几个配置:

  • 将 port = 8091 修改为 port = 9000,表示应用启动时,启动在 9000 端口。
  • 将 debug = true 修改为 debug = false,表示使用生产版本
  • 将 dir = "logs" 修改为 dir = "/tmp",表示日志写到 /tmp 目录(不挂载 NAS 的情况下,函数计算只有该目录是可以写的)

3、编译并运行应用

go build # 会生成一个 mdblog 的二进制可执行程序
./mdblog # 直接运行该可执行程序

如果遇到网络问题,可以使用 https://goproxy.cn/ 加速。
访问 http://localhost:9000 预览效果
4、部署
最后,本地测试没问题后,我们需要发布到函数计算上,虽然这个示例比起上面两个代码层面要复杂很多,但部署流程是一样的,直接执行 fun deploy 然后一路回车即可。
本示例生成的临时域名为:https://14118335-1911504709953557.test.functioncompute.com
打开可以看到如下效果:
9.png
打开具体的一篇博客,效果如下:
10.png

三、总结

我们通过三个示例介绍了如何部署一个 go 应用到函数计算上,从这三个例子我们可以发现,迁移一个 go 应用到函数计算是非常容易的,主要精力还是放在了如何在本地配置并启动应用,然后部署只需要简单的通过 fun deploy 命令即可。部署完成后,即可享受到函数计算带来的弹性伸缩、按量付费、免运维等特性。

阿里巴巴开源镜像站 提供全面,高效和稳定的镜像下载服务。钉钉搜索 ' 21746399 ‘ 加入镜像站官方用户交流群。”

相关实践学习
【文生图】一键部署Stable Diffusion基于函数计算
本实验教你如何在函数计算FC上从零开始部署Stable Diffusion来进行AI绘画创作,开启AIGC盲盒。函数计算提供一定的免费额度供用户使用。本实验答疑钉钉群:29290019867
建立 Serverless 思维
本课程包括: Serverless 应用引擎的概念, 为开发者带来的实际价值, 以及让您了解常见的 Serverless 架构模式
相关文章
|
9天前
|
存储 监控 算法
员工上网行为监控中的Go语言算法:布隆过滤器的应用
在信息化高速发展的时代,企业上网行为监管至关重要。布隆过滤器作为一种高效、节省空间的概率性数据结构,适用于大规模URL查询与匹配,是实现精准上网行为管理的理想选择。本文探讨了布隆过滤器的原理及其优缺点,并展示了如何使用Go语言实现该算法,以提升企业网络管理效率和安全性。尽管存在误报等局限性,但合理配置下,布隆过滤器为企业提供了经济有效的解决方案。
45 8
员工上网行为监控中的Go语言算法:布隆过滤器的应用
|
13天前
|
人工智能 Serverless API
尽享红利,Serverless构建企业AI应用方案与实践
本次课程由阿里云云原生架构师计缘分享,主题为“尽享红利,Serverless构建企业AI应用方案与实践”。课程分为四个部分:1) Serverless技术价值,介绍其发展趋势及优势;2) Serverless函数计算与AI的结合,探讨两者融合的应用场景;3) Serverless函数计算AIGC应用方案,展示具体的技术实现和客户案例;4) 业务初期如何降低使用门槛,提供新用户权益和免费资源。通过这些内容,帮助企业和开发者快速构建高效、低成本的AI应用。
58 12
|
2月前
|
缓存 监控 前端开发
在 Go 语言中实现 WebSocket 实时通信的应用,包括 WebSocket 的简介、Go 语言的优势、基本实现步骤、应用案例、注意事项及性能优化策略,旨在帮助开发者构建高效稳定的实时通信系统
本文深入探讨了在 Go 语言中实现 WebSocket 实时通信的应用,包括 WebSocket 的简介、Go 语言的优势、基本实现步骤、应用案例、注意事项及性能优化策略,旨在帮助开发者构建高效稳定的实时通信系统。
115 1
|
2月前
|
中间件 Go API
Go语言中几种流行的Web框架,如Beego、Gin和Echo,分析了它们的特点、性能及适用场景,并讨论了如何根据项目需求、性能要求、团队经验和社区支持等因素选择最合适的框架
本文概述了Go语言中几种流行的Web框架,如Beego、Gin和Echo,分析了它们的特点、性能及适用场景,并讨论了如何根据项目需求、性能要求、团队经验和社区支持等因素选择最合适的框架。
117 1
|
2月前
|
监控 Go API
Go语言在微服务架构中的应用实践
在微服务架构的浪潮中,Go语言以其简洁、高效和并发处理能力脱颖而出,成为构建微服务的理想选择。本文将探讨Go语言在微服务架构中的应用实践,包括Go语言的特性如何适应微服务架构的需求,以及在实际开发中如何利用Go语言的特性来提高服务的性能和可维护性。我们将通过一个具体的案例分析,展示Go语言在微服务开发中的优势,并讨论在实际应用中可能遇到的挑战和解决方案。
|
2月前
|
Go 数据处理 API
Go语言在微服务架构中的应用与优势
本文摘要采用问答形式,以期提供更直接的信息获取方式。 Q1: 为什么选择Go语言进行微服务开发? A1: Go语言的并发模型、简洁的语法和高效的编译速度使其成为微服务架构的理想选择。 Q2: Go语言在微服务架构中有哪些优势? A2: 主要优势包括高性能、高并发处理能力、简洁的代码和强大的标准库。 Q3: 文章将如何展示Go语言在微服务中的应用? A3: 通过对比其他语言和展示Go语言在实际项目中的应用案例,来说明其在微服务架构中的优势。
|
3月前
|
存储 消息中间件 人工智能
ApsaraMQ Serverless 能力再升级,事件驱动架构赋能 AI 应用
本文整理自2024年云栖大会阿里云智能集团高级技术专家金吉祥的演讲《ApsaraMQ Serverless 能力再升级,事件驱动架构赋能 AI 应用》。
163 12
|
2月前
|
运维 Serverless 数据处理
Serverless架构通过提供更快的研发交付速度、降低成本、简化运维、优化资源利用、提供自动扩展能力、支持实时数据处理和快速原型开发等优势,为图像处理等计算密集型应用提供了一个高效、灵活且成本效益高的解决方案。
Serverless架构通过提供更快的研发交付速度、降低成本、简化运维、优化资源利用、提供自动扩展能力、支持实时数据处理和快速原型开发等优势,为图像处理等计算密集型应用提供了一个高效、灵活且成本效益高的解决方案。
101 1
|
2月前
|
运维 监控 Serverless
Serverless架构在图像处理等计算密集型应用中展现了显著的优势
Serverless架构在图像处理等计算密集型应用中展现了显著的优势
40 1
|
3月前
|
Cloud Native Go API
Go语言在微服务架构中的创新应用与实践
本文深入探讨了Go语言在构建高效、可扩展的微服务架构中的应用。Go语言以其轻量级协程(goroutine)和强大的并发处理能力,成为微服务开发的首选语言之一。通过实际案例分析,本文展示了如何利用Go语言的特性优化微服务的设计与实现,提高系统的响应速度和稳定性。文章还讨论了Go语言在微服务生态中的角色,以及面临的挑战和未来发展趋势。

相关产品

  • 函数计算