腾讯新闻放弃 PHP,全面转向 Go 语言,重写代码超十万行!

最近看到一篇关于腾讯新闻团队的技术分享,讲的是他们做了一次比较大的架构调整——将底层系统从PHP全面迁移到了Go语言,重写代码超过十万行。这种规模的重构升级,确实需要不小的决心和投入。
当初为什么用 PHP?
腾讯新闻早期选择 PHP 是很好理解的。PHP 上手快、开发效率高,很适合业务需要快速验证和迭代的阶段。团队能够迅速推出功能、抢占市场,这在项目起步期非常关键。
后来为什么又要换掉?
随着业务不断增长,尤其是用户量和访问量上升之后,PHP 在高并发压力下的表现开始吃力。腾讯新闻每天要承载很大流量,遇到热点事件时并发请求会暴涨,PHP 处理起来效率不够,资源消耗也比较大。
此外,PHP 常见的部署方式是每个请求都要初始化一次环境,这种模式在流量大时对服务器资源占用较多。虽然可以通过加机器来解决,但成本也随之增加。
积累下来的问题
长期使用 PHP 开发,系统里逐渐积累了不少历史遗留代码。各个业务模块耦合在一起,结构变得复杂,每次改动都可能牵一发而动全身。代码库里也存在不少冗余或者临时写的片段,时间久了谁都不敢轻易去动,维护起来越来越麻烦。
为什么选了 Go,而不是优化 PHP?
可能有人会想到用 Workerman、Swoole 这类 PHP 扩展来提升性能,团队也确实评估过。但问题在于,这些工具主要提升的是单机性能,并不能从根本上改善已经臃肿的架构。而且引入它们还会增加系统的复杂度和学习成本,有点“修补补”的感觉。
相比之下,Go 语言提供了不一样的思路。它本身在语言层面就支持高并发,通过 goroutine 可以比较优雅地处理大量并发任务。作为编译型语言,Go 在运行时性能上有明显优势。另外,Go 的语法比较简洁,代码规范也比较严格,有助于写出更清晰、好维护的代码。
重构之后有什么变化?
重构完成后,效果还是比较明显的。系统响应更快,CPU 和内存的使用效率都有提升,同等硬件条件下能够支撑更高的并发量。
对开发团队来说,Go 的强类型和简洁语法让代码更容易阅读和维护,新人上手也更快。编译阶段就能发现一些潜在问题,减少了线上故障的概率。
部署也变得简单许多。Go 程序编译后是一个二进制文件,不需要像 PHP 那样配置复杂的运行环境,分发和启动都更轻量。
一点感想
腾讯新闻这次技术迁移,看起来不只是换一门编程语言,更是一次系统架构的全面升级。从早期追求快速上线,转向更关注性能、可维护性和长期稳定性。
当然,这种大规模重写对团队资源和勇气都是考验,并不适合所有项目。但它也提醒我们,技术选型需要考虑业务的发展阶段,及早重视架构整洁和代码质量,否则以后要付出的代价可能会更大。
技术环境一直在变,今天合适的方案未来未必依旧适用。保持学习、适时调整,可能才是做技术的人需要持续面对的常态。
正好我们是 Go 这方面的专家,需要简历优化、就业辅导、学习路线规划的朋友可以关注我,私信我。
版权声明: 本文为 InfoQ 作者【王中阳Go】的原创文章。
原文链接:【http://xie.infoq.cn/article/31048e21ec2cef4d7bbfa1e7b】。文章转载请联系作者。







评论