从Scala进驻Twitter看多语言混杂系统的未来

开发 后端
Twitter计划于09年底将大部分流量的后台使用Scala语言。原本Twitter的前台后台都是Ruby on Rails,但是效果不很理想。作者由此分析,未来的系统会是多语言的混杂系统。让DSL来实现系统的某个部分,比用一种语言到处实现更现实。

51CTO编辑推荐:Scala编程语言专题

Twitter是目前最热的“微博客(Micro Blog)”应用,据说前几天拒绝了Google出价10亿美元的收购意向。Twitter最早是几个工程师为了快速共享AIM(美国排名第一,二的IM,前身是ICQ,被AOL收购后更名为AIM)的状态(Status)而开发的一个应用,使用的是RoR (Ruby on Rail)框架,直到今天Twitter仍然是一个以Ruby为主要开发语言的网站,在Twitter服务器上后台运行着很多进程做异步处理。但Ruby的局限性也逐渐暴露出来了,RoR很适合做前端的开发,但对于比较Heavy的后台处理,Ruby的运行性能还是有些问题,然后Twitter将目光转向了Scala。

下面是一些对话的总结:

1)Ruby不太合适开发长时间运行(Long-Live)的服务器端程序,但JVM很合适,因为Java有10年的经验教训和优化,Scala是运行在JVM上的,所以天生就有了这个优点;

2)  Ruby没有很好的线程(Thread)支持,Ruby多线程会限制在一个CPU上(新的Ruby应该会改善这点吧)且Ruby VM的垃圾收集支持也没有Java先进,就造成每个Ruby进程长时间运行后使用的内存月来越大;

3)  为什么不是JRuby? JRuby缺乏使用广泛的Rem支持(很多优秀的Ruby包都需要C扩展,它们并没有移植到Java),而且性能也不太理想,比MRI(C实现的Ruby VM)要慢;

下面是几点Scala的Concerns:

1) IDE支持还不全面,支持得最好的是IntelliJ IDEA 8.1(自从5年前我残忍的抛弃JBuilder后,就一直用IntelliJ的IDEA了),Mac 上的Textmate支持的较差, Emacs还行;

2) Scala的构建(Build)环境还是要比Ruby, Python, PHP等动态语言多一回事;

3)一开始就要注意Immutability(不变性),为了稳定压倒一切,当然Scala会保证性能底线, JIT compiler对不变对象还有一些性能优化,所以尽量用吧;

4) Scala的Actors对处理客户端连接很合适,(Erlang也是这样的)大量的连接也是小菜一碟。

最后Twitter的计划是到09年底,大部分的流量将Powered by Scala!

我再说一次,未来的系统会是多语言的混杂系统,让专业的语言(Domain Specific Language , DSL)来实现系统的某个部分,比用一种语言到处实现更现实。

【相关阅读】

  1. Scala编程语言专题
  2. Scala的类型系统:取代复杂的通配符
  3. Scala的类型系统 比Java更灵活
  4. Java程序员,你为什么要关注Scala
  5. Scala创始人:创造比Java更好的语言
责任编辑:yangsai 来源: appspot
相关推荐

2009-08-21 16:17:25

ScalaTwitter API

2014-07-09 09:20:06

WPFWPF应用

2014-04-16 14:50:20

Spark

2009-12-09 09:15:47

从Java走进ScalTwitter API

2012-04-19 11:40:21

Titanium

2011-08-05 17:54:33

Cocoa Touch 多语言

2009-08-25 10:44:50

C#实现多语言

2021-09-07 10:17:35

iOS多语言适配设计

2021-06-29 21:48:32

开源语言架构

2024-05-09 08:14:09

系统设计语言多语言

2022-08-09 07:22:15

语言数据库程序

2009-07-17 10:02:29

WPF程序多语言支持

2013-07-04 10:54:27

Windows 8.1系统升级

2023-08-04 10:18:15

2020-04-14 09:50:02

2019-12-05 16:00:15

Vim插件编程文本编辑器

2009-08-31 17:13:09

2009-08-03 17:33:01

ASP.NET多语言支

2021-07-24 11:41:42

前端开发技术

2011-11-16 09:00:39

编程语言
点赞
收藏

51CTO技术栈公众号