回声嘹亮 之 Go 的 Echo 框架 —— 上手初体验

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: Echo 是众多 Go Web 框架的一个,根据官网介绍,它有着高性能、可扩展性、极简的特点。

Echo 介绍

Echo 是众多 Go Web 框架的一个,根据官网介绍,它有着高性能、可扩展性、极简的特点。


image.png


Echo 的特点概述:


  • 优化的 HTTP 路由,可智能地优先路由
  • 方便构建强大且可扩展的 RESTful API
  • API 组
  • 可扩展的中间件框架,在多个级别定义中间件(root, group, route)
  • 为 JSON ,  XML 进行表单数据负载绑定
  • 发送各种 HTTP 响应的便捷功能
  • 集中式 HTTP 错误处理
  • 使用任何模板引擎进行模板渲染
  • 定义日志的格式
  • 高度个性化、可定制
  • 通过 Let’s Encrypt 实现自动 TLS
  • HTTP/2 支持

Echo 上手

从 4.0.0 版本开始,Echo 可作为 Go 模块使用。因此,需要一个能够理解 /vN 后缀导入的 Go 版本:


  • 1.9.7+
  • 1.10.3+
  • 1.14+


这些 Go 版本中的任何一个都允许您将 Echo 导入为 github.com/labstack/echo/v4,这是今后使用 Echo 的推荐方式。

Echo 安装

这里以 Linux 为例,我们先看一下自己本地的 Go 版本:

$ go version     
go version go1.16.2 linux/amd64


本文使用的是 Go 1.16 版本,所以可以直接上手使用。


  1. 新建一个项目文件夹 HeadFirstEcho,然后进入该文件目录下:
$ mkdir HeadFirstEcho && cd HeadFirstEcho


  1. 然后利用 go mod 初始化该项目:
$ go mod init HeadFirstEcho               
go: creating new go.mod: module HeadFirstEcho


  1. 下载 Echo,命令:
// go get github.com/labstack/echo/{version}
go get github.com/labstack/echo/v4


本次下载成功如下:


image.png


下载成功后,我们来看一下如果利用 Echo 来写一个 HelloWorld 项目。

Hello World

在 Hello World 程序中,我们只需要让用户通过访问服务器地址,得到一个 Hello World 的文本就算成功,所以只需要编写一个服务器。创建一个 helloServer.go 文件:

package main
import (
  "net/http"
  "github.com/labstack/echo/v4"
)
func main() {
  e := echo.New()  // 得到一个 echo.Echo 的实例
        // 注册路由
  e.GET("/", func(c echo.Context) error {
    return c.String(http.StatusOK, "Hello, World!")
  })
        // 开启 HTTP Server
  e.Logger.Fatal(e.Start(":2022"))
}


启动我们的服务器: $ go run helloServer.go , 接着我们能看到如下的界面,说明 helloServer 服务器启动成功!


image.png


然后我们打开浏览器,访问:http://localhost:2022/,就能成功的看到我们的 Hello,World! 输出到屏幕上。


image.png


对比,之前用 Go 系统自带的 http 库实现的 HelloWorld 应用还是有异曲同工之妙的。

带日志功能的 HelloWorld 程序

Echo 还带有非常丰富的日志中间件:日志会记录每个有关 HTTP 请求的信息,只需要使用 e.Use(middleware.Logger()) 方法就能调用日志记录器,非常方便。当然日志也支持自定义,具体之后的文章再进行研究。


恢复中间件从链中任何地方的 panic 报错中恢复,并能够打印堆栈跟踪并将控制权处理给集中式 HTTPErrorHandler。用法也很简单:e.Use(middleware.Recover())


来看如下的例子:

package main
import (
  "net/http"
  "github.com/labstack/echo/v4"
  "github.com/labstack/echo/v4/middleware"
)
// Handler
func hello(c echo.Context) error {
  return c.String(http.StatusOK, "你好,世界!")
}
func main() {
  // Echo instance
  e := echo.New()
  // Middleware
  e.Use(middleware.Logger())
  e.Use(middleware.Recover())
  // Routes
  e.GET("/", hello)
  // Start server
  e.Logger.Fatal(e.Start(":1323"))
}


除了能在前端显示出:“你好,世界!” 的界面,还能在后台看到日志打印在控制台上:

$ go run hello.go                              
   ____    __
  / __/___/ /  ___
 / _// __/ _ \/ _ \
/___/\__/_//_/\___/ v4.6.3
High performance, minimalist Go web framework
https://echo.labstack.com
____________________________________O/_______
                                    O\
⇨ http server started on [::]:1323
{"time":"2022-02-25T15:08:10.481569868+08:00","id":"","remote_ip":"127.0.0.1","host":"localhost:1323","method":"GET","uri":"/","user_agent":"Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:97.0) Gecko/20100101 Firefox/97.0","status":200,"error":"","latency":9308,"latency_human":"9.308µs","bytes_in":0,"bytes_out":16}


能看到的日志信息有:


  • time :时间,2022-02-25T15:08:10.481569868+08:00
  • id:此处为空
  • remote_ip:127.0.0.1
  • host:localhost:1323
  • method:GET 方法
  • uri:/ 根目录
  • user_agent 用户头:此处为火狐 Ubuntu 版,Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:97.0) Gecko/20100101 Firefox/97.0
  • status:状态码,200
  • error:空
  • latency: 9308
  • latency_human: 9.308µs
  • bytes_in: 0
  • bytes_out: 16

其他中间件

从上面两个中间件我们可以看出,Echo 的确不愧为官网自称的极简 Web 框架,所有的函数调用都非常简单,而且支持可定制化。


在官方文档中,我们能看到所有的基本 Web 组件都已经帮我们实现好,比如:


  • Binding:绑定请求数据
  • Context:上下文,表示当前 HTTP 请求的上下文。
  • Cookies
  • Error Handling:错误处理
  • Request:请求
  • Response:响应
  • Static Files:静态文件
  • Templates:模板
  • Testing:测试


还有更多的中间件,包括 认证、CORS、CSRF、JWT、Logger、Secure、Session 等等,感兴趣的朋友赶紧上手试一试吧。

丰富而简单的案例

如果有一点 Web 开发的知识,对上述内容一定不陌生。


除了针对每一个组件的介绍,官方文档也提供了很多案例来帮助我们更好的学习和上手 Echo 这个框架,比如文件下载上传、还有一个 WebSocket 的案例实现服务器和客户端的聊天。


跟着文档学习的过程你中,发现每个程序案例都很简单,几乎都是在本地运行代码,就能看到同样的效果,对新人真的很友好!


如果大家感兴趣的话,就自己去探索吧,刚好笔者也想做一个简单的 Web 项目,刚好可以利用上 Echo ,一边开发一边学习。

总结

Go 语言的 Web 开发框架其实也有很多:GinBeegoRevel


Echo 作为其中的一款。截止到 2022 年,目前已经在 Github 上收获了 21.7k 的 Star 和 1.9k 的 Fork,可以说是经得起时间检验,得到了大家的认可,正可谓对应上标题中的回声嘹亮


在著名的 Go 开发者成长路线图 中也推荐了 Go 语言开发者应该要学习 Echo 框架。


image.png


最后,希望更多人能够和我一样加入对这个框架的学习。之后的文章中,会介绍 Echo 的其他组件在 Web 开发中的运用,下一篇 Echo 文章见!

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
1月前
|
开发框架 Go 计算机视觉
纯Go语言开发人脸检测、瞳孔/眼睛定位与面部特征检测插件-助力GoFly快速开发框架
开发纯go插件的原因是因为目前 Go 生态系统中几乎所有现有的人脸检测解决方案都是纯粹绑定到一些 C/C++ 库,如 OpenCV 或 dlib,但通过 cgo 调用 C 程序会引入巨大的延迟,并在性能方面产生显著的权衡。此外,在许多情况下,在各种平台上安装 OpenCV 是很麻烦的。使用纯Go开发的插件不仅在开发时方便,在项目部署和项目维护也能省很多时间精力。
|
2月前
|
Go API 数据库
Go 语言中常用的 ORM 框架,如 GORM、XORM 和 BeeORM,分析了它们的特点、优势及不足,并从功能特性、性能表现、易用性和社区活跃度等方面进行了比较,旨在帮助开发者根据项目需求选择合适的 ORM 框架。
本文介绍了 Go 语言中常用的 ORM 框架,如 GORM、XORM 和 BeeORM,分析了它们的特点、优势及不足,并从功能特性、性能表现、易用性和社区活跃度等方面进行了比较,旨在帮助开发者根据项目需求选择合适的 ORM 框架。
139 4
|
2月前
|
中间件 Go API
Go语言中几种流行的Web框架,如Beego、Gin和Echo,分析了它们的特点、性能及适用场景,并讨论了如何根据项目需求、性能要求、团队经验和社区支持等因素选择最合适的框架
本文概述了Go语言中几种流行的Web框架,如Beego、Gin和Echo,分析了它们的特点、性能及适用场景,并讨论了如何根据项目需求、性能要求、团队经验和社区支持等因素选择最合适的框架。
138 1
|
4月前
|
JSON Go API
使用Go语言和Gin框架构建RESTful API:GET与POST请求示例
使用Go语言和Gin框架构建RESTful API:GET与POST请求示例
|
5月前
|
Cloud Native JavaScript API
一文读懂云原生 go-zero 微服务框架
一文读懂云原生 go-zero 微服务框架
|
4月前
|
消息中间件 NoSQL Go
PHP转Go系列 | ThinkPHP与Gin框架之Redis延时消息队列技术实践
【9月更文挑战第7天】在从 PHP 的 ThinkPHP 框架迁移到 Go 的 Gin 框架时,涉及 Redis 延时消息队列的技术实践主要包括:理解延时消息队列概念,其能在特定时间处理消息,适用于定时任务等场景;在 ThinkPHP 中使用 Redis 实现延时队列;在 Gin 中结合 Go 的 Redis 客户端库实现类似功能;Go 具有更高性能和简洁性,适合处理大量消息。迁移过程中需考虑业务需求及系统稳定性。
|
5月前
|
SQL JavaScript Go
Go Web 服务框架实现详解
Go Web 服务框架实现详解
|
13天前
|
存储 监控 算法
员工上网行为监控中的Go语言算法:布隆过滤器的应用
在信息化高速发展的时代,企业上网行为监管至关重要。布隆过滤器作为一种高效、节省空间的概率性数据结构,适用于大规模URL查询与匹配,是实现精准上网行为管理的理想选择。本文探讨了布隆过滤器的原理及其优缺点,并展示了如何使用Go语言实现该算法,以提升企业网络管理效率和安全性。尽管存在误报等局限性,但合理配置下,布隆过滤器为企业提供了经济有效的解决方案。
54 8
员工上网行为监控中的Go语言算法:布隆过滤器的应用
|
1月前
|
存储 Go 索引
go语言中数组和切片
go语言中数组和切片
41 7
|
1月前
|
Go 开发工具
百炼-千问模型通过openai接口构建assistant 等 go语言
由于阿里百炼平台通义千问大模型没有完善的go语言兼容openapi示例,并且官方答复assistant是不兼容openapi sdk的。 实际使用中发现是能够支持的,所以自己写了一个demo test示例,给大家做一个参考。