`
chinese.darren
  • 浏览: 101678 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Twitter架构(转自hideto)

阅读更多

Twitter是目前为止最大的Ruby on Rails应用,几个月间页面点击由0增长到几百万,现在的Twitter比今年月快了10000%

平台
Ruby on Rails
Erlang
MySQL
Mongrel
Munin
Nagios
Google Analytics
AWStats
Memcached

状态
成千上万的用户,真实数量保密
每秒钟600请求
每秒钟平均200-300个连接,峰值为800个连接
MySQL每秒钟处理2,400个请求
180个Rails实例,使用Mongrel作为Web服务器
1个MySQL服务器(one big 8 core box)和1个slave用于只读的统计和报告
30+进程用于处理其余的工作
8台Sun X4100s
Rails在200毫秒内处理一个请求
花费在数据库里的平均时间是50-100毫秒
超过16GB的memcached

架构
1,遇到非常常见的伸缩性问题
2,最初Twitter没有监听,没有图,没有统计,这让解决问题非常困难。后来添加了Munin和Nagios。在Solaris上使用工具有点困难,虽然有Google Analytics但是页面没有loading所以它没什么用
3,大量使用memcached作缓存
-例如,如果获得一个count非常慢,你可以将count在1毫秒内扔入memcached
-获取朋友的状态是很复杂的,这有安全等其他问题,所以朋友的状态更新后扔在缓存里而不是做一个查询。不会接触到数据库
-ActiveRecord对象很大所以没有被缓存。Twitter将critical的属性存储在一个哈希里并且当访问时迟加载
-90%的请求为API请求。所以在前端不做任何page和fragment缓存。页面非常时间敏感所以效率不高,但Twitter缓存了API请求
4,消息
-大量使用消息。生产者生产消息并放入队列,然后分发给消费者。Twitter主要的功能是作为不同形式(SMS,Web,IM等等)之间的消息桥
-使用DRb,这意味着分布式Ruby。有一个库允许你通过TCP/IP从远程Ruby对象发送和接收消息,但是它有点脆弱
-移到Rinda,它是使用tuplespace模型的一个分享队列,但是队列是持久的,当失败时消息会丢失
-尝试了Erlang
-移到Starling,用Ruby写的一个分布式队列
-分布式队列通过将它们写入硬盘用来挽救系统崩溃。其他大型网站也使用这种简单的方式
5,SMS通过使用第三方网关的API来处理,它非常昂贵
6,部署
-Twitter做了一次review并推出新的mongrel服务器,还没有优雅的方式
-如果mongrel服务器替换了则一个内部错误抛给用户
-所以的服务器一次杀死。没有使用rolling blackout方式因为消息队列状态保持在mongrel里,这将导致剩余的mongrel被堵塞
7,误用
-系统经常宕机,因为人们疯狂的添加任何人为朋友,24小时内有9000个朋友,这将让站点崩溃
-构建工具来检测这些问题,这样你可以找到何时何地发生这些错误
-无情的删除这些用户
8,分区
-将来计划分区,目前还没有。当前所做的改变已经足够
-分区的计划基于时间,而不是用户,因为大部分请求都是本地的
-由于memoization分区会很难。Twitter不能保证只读的操作真的为只读,有可能写入一个只读的slave,这很糟糕
9,Twitter的API流量是Twitter站点的10倍
-Twitter所做的最重要的事情就是API
-保持服务简单允许开发人员在Twitter的基础组织上构建一些比Twitter自己所想到的更好的主意。例如,Twitterrific是一个使用Twitter优美的方式

学到的东西
1,和社区交流。不要隐藏并尝试自己解决所有问题。如果你提问,有许多聪明的人士愿意帮忙
2,将你的伸缩计划当成一个商业计划,聚集一帮顾问来帮助你
3,自己构建它。Twitter花费大量时间来尝试其他人的似乎可以工作的解决方案,但是失败了。自己构建一些东西会更好,这样你至少可以控制它并且构建你需要的特性
4,在用户的限度上构建。人们可能尝试弄垮你的系统。提高理由的限度和检测机制来保护你的系统不被杀死
5,不要让数据库成为首要瓶颈,并不是所有东西都需要一个很大的join,缓存数据,考虑其他创造性的方式来获得结果。一个好例子在里Twitter, Rails, Hammers, and 11,000 Nails per Second谈到
6,让你的应用一开始就很容易分区。这样你会一直有一种方式来伸缩你的系统
7,认知你的系统是很慢的,马上添加报告来跟踪问题
8,优化数据库
-索引所有东西,Rails不会为你做这件事
-解释你的查询是怎样运行的,索引可能不是按你想像的去做
-大量的非常规化。例如,Twitter一起存储用户ID和朋友ID,这预防了大量的开销昂贵的join
9,缓存所有东西,个别的ActiveRecord对象目前没有被缓存。目前查找已经足够快
10,测试一切
-你想知道当你部署时一起工作正常
-Twitter现在有一个完整的test suite。所以当缓存失效时Twitter可以在go live之前找到问题
11,使用异常提示和异常日志来获得立即的错误提示,这样你可以发现正确的方式
12,不要做傻事
-伸缩改变了傻东西
-尝试一次加载3000个朋友到内存中可能带来服务器崩溃,但是当只有4个朋友时它工作的很好
13,大部分性能不是来自语言,而是来自应用设计
14,通过创建一个API来让你的站点开放服务。Twitter的API是它成功的一个大原因。它允许用户创建一个扩展和生态系统。你可以从不做你的用户可以做的工作,这样你就不会有创造性。所以开发你的系统并且让其他人将他们的应用与你的应用集成变容易

分享到:
评论

相关推荐

    Kubernetes Cookbook - Hideto Saito 2016

    Hideto Saito所著的《Kubernetes Cookbook》这本书于2016年出版,是一本面向希望掌握Kubernetes实践知识的读者的实用指南。本书通过对实际案例和操作步骤的讲解,帮助读者了解Kubernetes的架构组成、安装部署、操作...

    Google文件系统

    "Google架构学习 - hideto - JavaEye技术网站.htm"可能包含对Google整体架构的理解,而"Google文件系统(英文).pdf"和"p125-ghemawat.pdf"可能是原始论文或相关的技术文献,可以帮助你理解GFS的原始设计思路。...

    Kubernetes Cookbook(EN)

    1. **Hideto Saito**:拥有20年计算机行业经验的作者之一,对UNIX、MacOSX操作系统有深入研究,对Objective-C编程有特别见解,同时也是一位日本动漫、戏剧和赛车运动的爱好者。 通过上述内容的深入学习,Kubernetes...

    Ruby入门培训ppt/pdf及代码

    博文链接:https://hideto.iteye.com/blog/123956

    Spring基础培训ppt

    博文链接:https://hideto.iteye.com/blog/107059

    实战Mule:利用Mule调用XFire发布的Web服务

    博文链接:https://hideto.iteye.com/blog/65607

    Rails里给文件上传添加progress_bar

    css和图片 博文链接:https://hideto.iteye.com/blog/197517

    Django绝对简明手册.doc

    Django是一个用Python编写的开源Web应用框架,它遵循模型-视图-控制器(MVC)架构模式,强调“约定优于配置”的原则,使得开发过程更加高效。 1. **序言**:作者提到写作的初衷是为了防止遗忘所学知识,通过记录来...

    FreeWheel press release

    博主Hideto可能分享了他对FreeWheel新发布的内容的理解,包括它如何影响行业动态、技术创新或者可能带来的商业机遇。然而,由于没有直接访问这个链接的能力,我们只能推测这个博客可能涉及的内容。 【标签】"源码...

    Google's Neural Machine Translation System - Bridging the Gap between Human and Machine Translation - 2016 (1609.08144v1)-计算机科学

    Jeff Klingner, Apurva Shah, Melvin Johnson, Xiaobing Liu, Łukasz Kaiser,Stephan Gouws, Yoshikiyo Kato, Taku Kudo, Hideto Kazawa, Keith Stevens, George Kurian, Nishant Patil, Wei Wang, Cliff Young, ...

    Python DjangoBook中文版

    这本书由hideto翻译并发布在JavaEye社区,为中文阅读者提供了方便的学习资源。 Django是一个用Python编写的开源Web应用框架,它遵循“DRY(Don't Repeat Yourself)”原则,致力于简化网页开发过程,提供高效、可...

    Kubernetes.Cookbook

    本书的作者之一Hideto Saito拥有超过20年的计算机行业经验,而其他作者如Hui-Chuan Chloe Lee、Ke-Jou Carol Hsu等在Linux和MacOSX上的产品和服务开发方面也具有深厚的技术背景。 Kubernetes Cookbook的版权归属于...

    智慧拼珠求解及智慧金字塔求解

    接下来,我们提到的"Dancing Links"(舞蹈链),是日本数学家Hideto Kanada提出的一种高效算法,特别适合解决0-1背包问题、完全图着色问题等组合优化问题。Dancing Links的核心思想是用稀疏矩阵表示问题的约束关系,...

Global site tag (gtag.js) - Google Analytics