博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Timehop为什么使用Go替代Rails
阅读量:6910 次
发布时间:2019-06-27

本文共 1072 字,大约阅读时间需要 3 分钟。

Go语言从一面世就受到了很多开发者的关注,尤其它的并行机制使得开发者能够非常容易地编写多核和网络应用。当前,越来越多的项目基于Go语言实现,如著名的、、Google的等。此外,还有众多项目迁移到了Go技术栈,如、等。近日,社交应用Timehop(中文译为时光机)的联合创始人发布了一篇题为《》的文章,该文章对从Rails转向Go的经历进行了总结。从文章中得知,Timehop的技术栈于2013年经历了从Rails到Go的转变;至今,Timehop已经高效、稳定地运行了,并且每天活跃用户数达到了600万,其中95%的请求响应时间从Rails时代的700毫秒减少到70毫秒。InfoQ编辑现对文章进行了整理和汇总以供读者参考和学习,具体内容如下:

\\

为什么需要技术栈的转变

\\

Timehop自上线以来,其用户规模不断扩大和访问量不断增长,基于Rails/Ruby的Timehop渐渐地出现了性能瓶颈,Timehop急需高性能、支持并行处理、真正多线程的平台/语言以解决遇到的性能瓶颈问题。

\\

为什么选择了Go

\\

Go能够完全满足Timehop对高并发和并行处理的需要,其具有以下主要特征:

\\
  • 性能方面:Go代码被编译为机器代码,所以不存在虚拟机或解析器等带来的额外开销 \\
  • 静态编写方面:Go利用计算机来处理所有的编写错误,从而减轻了自己的负担\\
  • 并行处理方面:Go提供了语言级别的并发特性,这些特性使得Go的并行代码具有较高的可读性、条理性、安全性\\
  • 其他方面:Go还具有程序部署非常简便、标准库非常丰富等特征 \

Timehop的开发团队还对选择Go进行了一些讨论,如使用Go后会出现哪些意外、如何完成团队的技术切换、Go有哪些不足、部署时有哪些关键的库需要注意、如何进行托管和部署、能否使用Go创建API、Go程序在多态性和模块化方面是如何处理的、Google对Go的支持情况等,这些讨论内容为大家将自己应用的技术栈转向Go提供了参考依据。

\\ \\

此外,有关转向Go技术栈的经验总结,读者还可以阅读InfoQ去年发布的一篇题为《》的文章,文章总结了基于云技术的开发平台Bowery从Node.js转向Go的原因,这些原因包括Go具有强大的跨平台编程能力、快速部署、并发原语的支持、标准化的集成测试框架、强大的标准库、强大的开发者工作流工具等。


感谢对本文的审校。

\

给InfoQ中文站投稿或者参与内容翻译工作,请邮件至。也欢迎大家通过新浪微博()或者腾讯微博()关注我们,并与我们的编辑和其他读者朋友交流。

转载地址:http://nrfcl.baihongyu.com/

你可能感兴趣的文章
metabase实施文档
查看>>
10.3 定位连续值范围的开始点和结束点
查看>>
解析iscroll-小demo
查看>>
基站定位接口说明文档
查看>>
java实现邮件定时发送
查看>>
差分约束 【bzoj2330】[SCOI2011]糖果
查看>>
ArrayList和LinkedList区别
查看>>
Error_GL_KeyflexfieldDefinitionFactory.getStructureNumber无法找到应用产品
查看>>
js作用域及闭包
查看>>
CSS overflow 属性
查看>>
通过改变uiview的layer的frame来实现进度条
查看>>
ADB am 命令详细参数
查看>>
NOIp 数学基础
查看>>
nginx支持ipv6
查看>>
点名器
查看>>
Codeforces Problems-122A. Lucky Division
查看>>
移动端适配代码
查看>>
Js设置所有连接是触发/swt/的代码
查看>>
JS高级程序设计2nd部分知识要点1
查看>>
mac10.8 更新系统出错
查看>>