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

 更新时间:2021年10月18日 15:59:27   投稿:hqx  
这篇文章主要介绍Golang标准库和外部库的性能比较,下面文章讲围绕这两点展开内容,感兴趣的小伙伴可以参考一下

前言:

我已经在生产中使用 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

1、路由

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

/students/:studentID/grades/:gradeID


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

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

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

2、JSON 序列化和反序列化

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

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

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

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

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

3、是否使用ORM框架

大多数流行的语言都依赖于框架来构建与数据库交互的微服务。在 Java 世界中,HibernateActive 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 调用的每个步骤中,都有更好的框架或外部库,它们将使您的响应更快并提供一定的灵活性。

4、总结

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

到此这篇关于Golang标准库和外部库的性能比较的文章就介绍到这了,更多相关Golang标准库和外部库的性能内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Go语言学习网络编程与Http教程示例

    Go语言学习网络编程与Http教程示例

    这篇文章主要为大家介绍了Go语言学习网络编程与Http教程示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • Golang中struct{}和struct{}{}的区别解析

    Golang中struct{}和struct{}{}的区别解析

    这篇文章主要介绍了Golang中struct{}和struct{}{}的区别,通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-03-03
  • go module构建项目的实现

    go module构建项目的实现

    本文主要介绍了go module构建项目的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • golang去除多余的空格与换行符示例代码

    golang去除多余的空格与换行符示例代码

    Golang是一种强大的编程语言,提供了丰富的字符串处理功能,这篇文章主要给大家介绍了关于golang去除多余的空格与换行符的相关资料,需要的朋友可以参考下
    2023-10-10
  • go 分布式锁简单实现实例详解

    go 分布式锁简单实现实例详解

    这篇文章主要为大家介绍了go 分布式锁简单实现实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • go mayfly开源项目代码结构设计

    go mayfly开源项目代码结构设计

    这篇文章主要为大家介绍了go mayfly开源项目代码结构设计详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • Go泛型应用工厂方法及泛型使用

    Go泛型应用工厂方法及泛型使用

    这篇文章主要介绍了Go泛型应用工厂方法及泛型使用,结合工厂方法+泛型方法来看一下泛型到底是如何在业务场景中使用的,需要的小伙伴可以参考一下
    2022-07-07
  • golang类型转换组件Cast的使用详解

    golang类型转换组件Cast的使用详解

    这篇文章主要介绍了golang类型转换组件Cast的使用详解,帮助大家更好的理解和学习使用golang,感兴趣的朋友可以了解下
    2021-02-02
  • golang实现大文件上传功能全过程

    golang实现大文件上传功能全过程

    Go语言可以用来实现大文件传输,下面这篇文章主要给大家介绍了关于golang实现大文件上传功能的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-07-07
  • Go web入门Go pongo2模板引擎

    Go web入门Go pongo2模板引擎

    这篇文章主要为大家介绍了Go web编程入门Go pongo2模板引擎使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05

最新评论