前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Golang标准库和外部库的性能对比

Golang标准库和外部库的性能对比

作者头像
用户5166556
发布2023-03-18 14:26:25
9400
发布2023-03-18 14:26:25
举报
文章被收录于专栏:让技术和时代并行

我已经在生产中使用 Go 一段时间了,因为它的构建规模较小,并且由 goroutines 提供的并发性能以及直接在机器上运行构建的能力,所以我非常喜欢它的快速和可靠。

由于标准包的速度非常快,您可以在不使用任何第三方库或框架的情况下构建生产就绪的微服务。这并不是说 Go 中没有提供更多灵活性或速度的框架,只是它们不那么受欢迎。

官方通常告诉你坚持使用标准库。具有讽刺意味的是,golang 框架的顶级 Google 搜索结果一般都是关于为什么不应该使用标准库。

我对标准库的替代品进行了一些研究和基准测试,以了解它们的表现。我将它们分为我认为是关键的微服务组件。

所有基准测试都在下面列出的配置上运行。虽然正常的基准测试时间只有 1 秒,但我将所有测试运行了 10 秒,以确保每个测试周期都是一致的。

  • 处理器 — 2.7 GHz Intel Core i7
  • RAM — 16GB — 16 GB 2133 MHz LPDDR3
  • Bench Time 10s 而不是标准的 1s
  • go test -bench=. -benchtime=10s

路由

标准的 http Go 服务器带有一个不错的路由器,可以读取查询参数但不能读取命名参数,例如,

代码语言:javascript
复制
/students/:studentID/grades/:gradeID

任何具有上述嵌套资源的 REST 服务都必须使用外部路由库来解析它们。Gin、Echo、Beego、Gorilla Mux 和 Goji 只是其中几个知名框架(根据 Github 关注量)。

其中一些是具有路由功能的成熟中间件框架,而另一些则仅仅只是路由库。

这些库针对单个命名参数进行了测试,结果如下所示,Gin 拥有最快的路由器,Echo 排在第二位。

JSON 序列化和反序列化

一旦 API 请求通过路由器并传递到控制器或处理程序,下一步就是在返回响应时对请求 JSON 或 Encode 进行解码。

Go 有一个非常好的encoding包,它支持多种格式,比如json, XML, csv,但是快速浏览一下替代品会向你展示大量的库。我针对标准encoding/json包对 Jsoniter、EasyJson 进行了基准测试,结果如下。

下面是编码的结果,结果表明性能差异并不显着。

但是对于解码 JSON,jsoniter执行速度比标准编码包快 5 倍。

现在,如果您的请求已被解码,下一步可能是应用您的业务逻辑,并可能执行一些数据库操作。

是否使用ORM框架

大多数流行的语言都依赖于框架来构建与数据库交互的微服务。在 Java 世界中,Hibernate、Active Record for Rails 和 Django ORM 非常流行。ORM(对象关系映射器)有时有助于更好地处理事务、表之间的关系,并有助于避免为简单连接编写复杂的 SQL。

但是 Go 再次拥有一个非常好的database标准库,它使连接到关系数据库变得非常容易,而且速度也非常快。但是,一个痛点是查询。当您查询某些行时,您必须手动映射行中的每个字段,然后将它们分配给struct. 这有效,但很快就会变得混乱并让您编写大量代码。sqlx是一个库,它允许您将整行扫描到您的结构变量中。

虽然sqlx减少了为构建 CRUD 而编写的典型行数,但最终仍会多次编写重复代码。使用 ORM 可以帮助减少它并专注于您的业务逻辑。

database, database + sqlx, gorm , go-pg对查询进行了基准测试,下面是结果。令人惊讶的是,go-pgORM 的执行速度比标准包甚至sqlx还要快. GORM虽然在生态系统中非常有名,但速度相对较慢。

在 API 调用的每个步骤中,都有更好的框架或外部库,它们将使您的响应更快并提供一定的灵活性。

总结

虽然一些外部库的性能改进非常明显,但这不应该成为远离标准库的原因。诸如测试代码的难易程度、开源库的长期维护、团队的学习曲线等都应该考虑在内。尽管如此,我认为像 echo + jsoniter + go-pgGo 等标准库功能的所有令人敬畏的东西将是构建微服务并避免冗余代码的最快方法。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-10-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 云原生技术爱好者社区 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 路由
  • JSON 序列化和反序列化
  • 是否使用ORM框架
  • 总结
相关产品与服务
消息队列 TDMQ
消息队列 TDMQ (Tencent Distributed Message Queue)是腾讯基于 Apache Pulsar 自研的一个云原生消息中间件系列,其中包含兼容Pulsar、RabbitMQ、RocketMQ 等协议的消息队列子产品,得益于其底层计算与存储分离的架构,TDMQ 具备良好的弹性伸缩以及故障恢复能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档