标签 MySQL 下的文章

Go 语言观察:登顶“最受期待”榜首,JetBrains 2025报告洞悉未来趋势

本文永久链接 – https://tonybai.com/2025/10/23/go-language-leads-jetbrains-trends

大家好,我是Tony Bai。

近日,软件开发工具巨头 JetBrains 发布了其年2025度《开发者生态系统现状》报告,这份基于全球数万名开发者调研的数据报告,已成为洞察技术风向的关键参考之一。在今年的报告中,Go 语言的表现尤为亮眼,它不仅在“未来潜力”和“学习意愿”等前瞻性指标上独占鳌头,其在当前主流语言版图中的位置也愈发稳固。

本文将为您全方位解读这份报告,从多个维度剖析 Go 语言的现状、潜力和生态位,洞察这些趋势对每一位 Gopher 的深远影响。

核心洞察:Go 成为开发者“最想采用的下一门语言”

报告中最激动人心的发现,莫过于在“开发者最想采用的下一门语言”这项调查中,Go 语言以 11% 的得票率高居榜首

这一数据强烈预示着 Go 语言在未来的项目选型和团队扩张中将拥有巨大的潜力。它表明 Go 简洁、高效、高并发的理念已成功捕获了大量开发者的心智。对于企业而言,这意味着 Go 的人才储备池正在快速扩大;对于开发者个人而言,掌握 Go 语言无疑是抓住了未来技术栈演进的关键脉搏。

当前使用现状:稳居主流,但非绝对主导

当然,我们也需客观看待 Go 的当前位置。在“主要编程语言”的长期使用趋势图表中,Go 的使用率稳定在 20%

这是一个非常健康且重要的数字,它意味着 Go 已经牢固地占据了主流编程语言的一席之地,与 C# (21%) 并驾齐驱,并且领先于 Kotlin (18%) 和 Rust (12%) 等现代语言。

然而,与常年盘踞榜首的 JavaScript (61%)、Python (57%) 和 Java (49%) 相比,Go 还有相当的差距。这恰恰反映了 Go 的战略定位:它并非一门试图“通吃”所有领域的语言。Python 在数据科学和 Web 后端拥有深厚根基,Java 在庞大的企业级应用中难以撼动,而 Go 则精准地聚焦于其核心优势领域——云原生、分布式系统和高性能后端服务。这种聚焦,正是其强大生命力的来源。

增长潜力:位列“承诺指数”第一梯队

JetBrains 创设的“语言承诺指数 (Language Promise Index)”综合评估了语言的增长稳定性、采用势头和用户忠诚度。在这个极具前瞻性的榜单上,Go 以 +115 的高分位列第四,与 TypeScript (+223)、Rust (+187) 和 Python (+131) 共同组成了未来增长潜力最强的“第一梯队”。

这表明,尽管 Go 的当前总使用率不如 Python 或 Java,但其增长的质量和动能却处于顶尖水平。社区活跃、用户忠诚度高、应用场景不断拓宽,这些都是 Go 未来持续攀升的坚实基础。

趋势解读:为何是 Go?技术范式演进的必然选择

报告中的另外几组数据,完美解释了 Go 语言为何能在当今的技术浪潮中乘风破浪。

完美契合“连接型”开发范式

报告指出,现代开发者的核心工作正在从构建孤立的应用,转向构建系统间的“连接性组织 (connective tissue)”。

  • 52% 的开发者工作涉及与 API 和服务集成
  • 48% 的开发者工作涉及提供 API 和服务

同时,在开发者构建的软件产品类型中,Web 服务 (29%)Cloud 服务 (19%)System software (17%) 占据了重要份额。

这些领域恰恰是 Go 语言的核心优势区。其天生为并发而设计的 Goroutine 模型、简洁高效的 net/http 标准库以及强大的 gRPC 生态,使其成为构建高性能 API、微服务、中间件和基础设施软件的理想选择。

云原生主战场的绝对优势

在应用部署平台方面,40% 的应用被部署在服务器/云端,这是仅次于浏览器的第二大平台。在云服务提供商方面,AWS (43%)、GCP (22%) 和 Azure (22%) 占据了市场主导地位。

Go 语言自诞生之初就被誉为“云原生时代的 C 语言”,其编译后体积小、资源占用低、启动速度快的特性,使其在以 Docker 和 Kubernetes 为代表的容器化环境中,以及在 Serverless 架构下降本增效的潜力巨大。可以说,Go 是为在 AWS、GCP、Azure 等云平台上运行而生的语言。

生态位观察:数据库新王登基,Gopher 需关注

报告还揭示了一个对所有后端开发者都至关重要的趋势:PostgreSQL 的使用率 (50%) 预计将历史性地超越 MySQL (49%),成为最受欢迎的关系型数据库。

这一变化对 Go 开发者同样具有指导意义。虽然 Go 的 database/sql 包提供了统一的数据库访问接口,但了解并熟练使用社群中性能最优、特性最丰富的 PostgreSQL 驱动(如 pgx)将变得愈发重要。关注主流数据库的演进,并及时更新自己的技术栈,是保持竞争力的关键。

总结与展望

JetBrains 的这份报告以翔实的数据,为我们描绘了一幅立体而清晰的 Go 语言发展图景:

  • 人气高涨:它是开发者最渴望学习和使用的新语言,拥有最强的“拉新”能力。
  • 地位稳固:已成为使用率达 20% 的主流语言,在特定领域拥有不可替代的优势。
  • 潜力巨大:其高质量的增长动能使其稳居未来潜力榜的第一梯队。
  • 定位精准:它完美契合了以 API 集成和云原生为核心的现代软件开发范式。

对于 Go 社区而言,这份报告既是肯定也是激励。它证明了 Go 的选择是正确的,其专注的领域正是软件行业发展的未来方向。对于每一位 Gopher 来说,深入理解 Go 的生态位,持续打磨在云原生和高性能后端领域的技能,无疑是投身这股浪潮、创造更大价值的最佳路径。

资料链接:https://devecosystem-2025.jetbrains.com/tools-and-trends


你的Go技能,是否也卡在了“熟练”到“精通”的瓶颈期?

  • 想写出更地道、更健壮的Go代码,却总在细节上踩坑?
  • 渴望提升软件设计能力,驾驭复杂Go项目却缺乏章法?
  • 想打造生产级的Go服务,却在工程化实践中屡屡受挫?

继《Go语言第一课》后,我的《Go语言进阶课》终于在极客时间与大家见面了!

我的全新极客时间专栏 《Tony Bai·Go语言进阶课》就是为这样的你量身打造!30+讲硬核内容,带你夯实语法认知,提升设计思维,锻造工程实践能力,更有实战项目串讲。

目标只有一个:助你完成从“Go熟练工”到“Go专家”的蜕变! 现在就加入,让你的Go技能再上一个新台阶!


想系统学习Go,构建扎实的知识体系?

我的新书《Go语言第一课》是你的首选。源自2.4万人好评的极客时间专栏,内容全面升级,同步至Go 1.24。首发期有专属五折优惠,不到40元即可入手,扫码即可拥有这本300页的Go语言入门宝典,即刻开启你的Go语言高效学习之旅!


商务合作方式:撰稿、出书、培训、在线课程、合伙创业、咨询、广告合作。如有需求,请扫描下方公众号二维码,与我私信联系。

为什么说“接口”,而非代码或硬件堆砌,决定了系统的性能上限?

本文永久链接 – https://tonybai.com/2025/09/07/the-power-of-an-interface-for-performance

我的《Go语言第一课》已上市,赠书活动正在进行中,欢迎点击此链接参与。

大家好,我是Tony Bai。

我们通常如何看待性能优化?答案往往是:更快的算法、更少的内存分配、更底层的并发原语、甚至用SIMD指令压榨CPU的每一个周期。我们痴迷于“引擎盖之下”的实现细节,坚信更好的代码和更强的硬件能带来更高的性能。

然而,TigerBeetle数据库创始人Joran Dirk Greef在Strange Loop上的一场精彩的演讲(https://www.youtube.com/watch?v=yKgfk8lTQuE),用一场耗资百万美元的数据库比赛,颠覆了这一传统认知。他通过无可辩驳的基准测试数据证明:在分布式系统中,接口(Interface)的设计,而非代码实现或硬件堆砌,才是决定性能上限的真正瓶颈。

在深入探讨之前,我们必须对本文的“接口”一词进行关键澄清。对于Go开发者而言,“接口”通常指代语言层面的interface类型,一种实现行为契约以及多态的工具。但本文中所说的“接口”,则是一个更宏观、更广义的概念,它指的是系统与系统之间、或用户与系统之间进行通信的交互模式、契约与协议。你的REST API设计、gRPC的.proto文件、微服务间的调用时序,都属于这个“广义接口”的范畴。

这场演讲虽然以数据库为载体,但其揭示的“接口即天花板”的原理,对于每一位设计和使用Go API、微服务的工程师来说,都无异于一声惊雷。它迫使我们重新审视,我们日常构建的系统,是否在设计之初,就已为自己埋下了无法逾越的性能枷锁。

赛场设定:一场关于“转账”的终极对决

Greef的实验设计极其巧妙,他回归了OLTP(在线事务处理)的本质,重拾了图灵奖得主Jim Gray定义的最小交易单元:“借贷记”(Debit-Credit),即我们熟知的“转账”操作。

这个工作负载的核心是:在两个账户之间转移价值,并记录一笔历史。它的关键挑战在于竞争(Contention)。在高流量的真实世界系统中,总会有大量的交易集中在少数“热门”账户上,这就是帕累托法则(80/20原则)的体现。

传统接口:交互式事务

大多数通用数据库处理这种事务的标准接口是“交互式”的,即一个业务操作需要多次网络往返才能完成:
1. 第一步(读):客户端发起一个网络请求,SELECT Alice和Bob的账户余额。
2. 第二步(计算):数据返回到客户端,应用代码在本地检查余额是否充足。
3. 第三步(写):客户端发起第二个网络请求,在一个事务中UPDATE两个账户的余额,并INSERT一条转账记录。

这个看似天经地义的流程,隐藏着一个致命的缺陷。

百万美元的“滑铁卢”:当硬件和实现都失灵

Greef设立了三组“选手”来进行一场性能对决:

  1. Postgres (单机): 经典的、备受尊重的开源数据库。
  2. “迈凯伦” (16节点集群): 一个匿名的、顶级的云原生分布式数据库,年费超过一百万美元。
  3. TigerBeetle: Greef自己设计的、专为OLTP优化的新一代数据库。

比赛结果令人瞠目结舌:

  • 在零竞争下,“迈凯伦”集群的性能甚至不如单机Postgres。
  • 随着竞争率提升,16台机器的“迈凯伦”性能暴跌,甚至出现了节点越少、性能越高的荒谬情况。
  • 在整个高竞争测试期间,这百万美元硬件的CPU利用率从未超过12%

为什么? 硬件在空转,代码在等待。钱,并没有买来性能。

性能的枷锁:跨网络持有锁

问题的根源,就出在那个“交互式事务”的接口设计上。

当一个事务开始时,数据库为了保证ACID,必须锁定被操作的行。在这个接口模型中,锁的持有时间 = 数据库处理时间 + 两次网络往返(RTT)的时间 + 客户端应用的处理时间。

Greef指出,数据库内部的处理时间可能是微秒级的,但一次跨数据中心的网络往返,轻易就是几十甚至上百毫秒。这意味着,数据库中最宝贵的锁资源,其生命周期被廉价且缓慢的网络I/O牢牢绑架了。

阿姆达尔定律的诅咒

这完美地印证了阿姆达尔定律:系统的总性能,取决于其串行部分的速度。在这个场景中,“跨网络持有锁”就是那个不可并行的、绝对的串行瓶颈。

  • 当网络延迟为1ms,竞争率为10%时,即使你的数据库是无限快的,理论性能上限也只有10,000 TPS
  • 当网络延迟上升到10ms,这个上限会骤降到1,000 TPS

无论你增加多少台机器(水平扩展),都无法打破这个由接口设计决定的物理定律。

对Go API和系统设计的深刻启示

这场数据库之战,对我们Go开发者来说,是一面镜子。我们必须审视自己日常的设计,是否也在不经意间构建了类似的“性能枷锁”。

1. 警惕你的Go API是否“跨网络持有锁”

在微服务架构中,一个常见的反模式是“编排式事务”。想象一个创建订单的流程:

// 反模式:一个跨多个网络调用、持有远端锁的接口
func CreateOrder(ctx context.Context, userID, productID int) error {
    // 步骤1:锁定库存 (通过RPC调用库存服务)
    lock, err := inventoryService.LockStock(ctx, productID, 1)
    if err != nil {
        return err
    }
    // 注意:从此刻起,该商品的库存在inventoryService中被锁定!

    // 步骤2:扣减用户余额 (通过RPC调用账户服务)
    err = accountService.Debit(ctx, userID, product.Price)
    if err != nil {
        inventoryService.UnlockStock(ctx, lock.ID) // 必须记得解锁
        return err
    }

    // 步骤3:创建订单记录
    // ...

    // 成功!最后解锁库存
    return inventoryService.UnlockStock(ctx, lock.ID)
}

这个CreateOrder函数,在其执行期间,跨越了多次网络调用,却一直持有着库存服务的锁。这与Postgres的交互式事务犯了完全相同的错误。这个糟糕的接口设计决定了系统的性能上限。

2. TigerBeetle的解决方案:重新定义接口

TigerBeetle的接口设计哲学截然不同。它不接受交互式的、一次一笔的事务。取而代之的是:
- 批处理 (Batching): 客户端将成千上万个“转账”意图打包成一个大的请求。
- 一次性提交 (One-Shot Commit): 将这个大包一次性发送给数据库。
- 异步处理: 数据库在内部高效地处理这个批次,然后一次性返回所有结果。

在这个模型中,网络延迟只发生一次,且与锁的持有时间完全解耦。

3. 转化为Go的设计模式:

我们可以将TigerBeetle的思想应用到我们的Go服务设计中,重新定义我们的“接口”:

  • 使用异步消息传递:CreateOrder服务不应直接调用其他服务并等待。它应该发布一个OrderCreationRequested事件到消息队列(如NATS或Kafka)。后续的服务订阅此事件,并以异步、解耦的方式处理各自的逻辑(通常需要Saga等模式保证最终一致性)。
  • 设计“意图驱动”的API:不要创建需要多次交互才能完成一个业务流程的API。取而代之,设计一个能接收完整“业务意图”的API。例如,提供一个/orders/batch_create端点,让客户端一次性提交多个订单创建的请求。
  • 将状态检查移至服务端:与其让客户端先读数据再决定如何写,不如提供一个API,让客户端直接声明它的意图,由服务端在一个原子操作内完成“检查并写入”。

小结

Joran Greef的演讲最终以TigerBeetle在高竞争下,性能达到Postgres数千倍的结果震撼全场。这并非因为TigerBeetle的代码实现比Postgres好了几个数量级,而是因为它的接口设计从根本上绕开了阿姆达尔定律的诅咒。

对于Go开发者,这场演讲的启示也是深远的:

  • 性能瓶颈往往在白板上就已注定:在你写下第一行代码之前,你的API设计、服务间的交互模型,可能已经为你的系统设定了无法逾越的性能天花板。
  • 减少网络往返,尤其是持有锁的往返,是性能优化的第一要务
  • 拥抱批处理和异步化:这是打破“一次交互一件事”思维定势、实现数量级性能提升的关键。

下一次,当你面对性能问题时,与其一头扎进pprof的火焰图,试图优化某个函数的CPU占用,不如先退后一步,审视你的系统和API的接口设计。或许,那个锁住你系统性能的真正枷锁,并非隐藏在代码的细枝末节里,而是明晃晃地写在你的设计文档的第一页。


想系统学习Go,构建扎实的知识体系?

我的新书《Go语言第一课》是你的首选。源自2.4万人好评的极客时间专栏,内容全面升级,同步至Go 1.24。首发期有专属五折优惠,不到40元即可入手,扫码即可拥有这本300页的Go语言入门宝典,即刻开启你的Go语言高效学习之旅!


商务合作方式:撰稿、出书、培训、在线课程、合伙创业、咨询、广告合作。如有需求,请扫描下方公众号二维码,与我私信联系。

如发现本站页面被黑,比如:挂载广告、挖矿等恶意代码,请朋友们及时联系我。十分感谢! Go语言第一课 Go语言进阶课 AI原生开发工作流实战 从 0 开始构建 Agent Harness Go语言精进之路1 Go语言精进之路2 Go语言第一课 Go语言编程指南
商务合作请联系bigwhite.cn AT aliyun.com
这里是 Tony Bai的个人Blog,欢迎访问、订阅和留言! 订阅Feed请点击上面图片

如果您觉得这里的文章对您有帮助,请扫描上方二维码进行捐赠 ,加油后的Tony Bai将会为您呈现更多精彩的文章,谢谢!

如果您希望通过微信捐赠,请用微信客户端扫描下方赞赏码:

如果您希望通过比特币或以太币捐赠,可以扫描下方二维码:

比特币:

以太币:

如果您喜欢通过微信浏览本站内容,可以扫描下方二维码,订阅本站官方微信订阅号“iamtonybai”;点击二维码,可直达本人官方微博主页^_^:
本站Powered by Digital Ocean VPS。
选择Digital Ocean VPS主机,即可获得10美元现金充值,可 免费使用两个月哟! 著名主机提供商Linode 10$优惠码:linode10,在 这里注册即可免费获 得。阿里云推荐码: 1WFZ0V立享9折!


View Tony Bai's profile on LinkedIn
DigitalOcean Referral Badge

文章

评论

  • 正在加载...

分类

标签

归档



View My Stats