【企业开源系列】Twitter:收发一条推文的背后

article/2025/9/8 21:44:56

http://www.iteye.com/news/28556

 

Twitter被称为“互联网的短信服务”,允许用户发布不超过140个字的微博客,该创意来自Twitter的联合创始人Jack Dorsey,这个在7年前被分析师称为“有史以来最愚蠢”的创意,不料如今已经成为了风靡全世界的社交网络和微博客服务,月活跃用户达到了2.183亿人,每天大约有5亿条推文(tweet)被发送,几乎每秒钟就产生了超过6000条推文。 

2013年11月7日,Twitter正式在纽约证券交易所上市,发行价26美元,但开盘即大涨73%至45.1美元。 

Twitter可以称之为构建于开源项目之上,该公司开源负责人Chris Aniszczyk表示,如果没有开源软件,Twitter将不会存在,用户在移动端和PC端发送和接收的每一条推文都会需要开源软件。 

在Twitter公司,当计划开展一个新项目时,工程师会首先衡量需求以及开源项目的能力,并通过定制开源项目来更好地满足需求。正是如此,Twitter才发展如此迅速,并轻松解决了日益飞速扩增的流量和请求。 



Twitter所使用的开源项目 

Twitter每天需要处理用户发送的推文数超过4亿条,此外还要处理大量的时间线(来自用户关注的人的所有推文),这一工程是相当浩大和复杂的。Twitter使用了大量的开源项目,从各种工具到各种库。如果没有这些开源项目,日常工作将无法正常运作。 

下面来看看推文传递的背后都用到了哪些开源项目。 

1.  分析和搜索服务 

Twitter的搜索服务每天支持超过10亿次的查询,其背后的开源项目包括: 

  • Apache Cassandra:一套分布式NoSQL数据库系统,以Amazon专有的完全分布式的Dynamo为基础,结合了Google BigTable基于列族(Column Family)的数据模型,是一个网络社交云计算方面理想的数据库。该项目最初由Facebook开发,于2008开源并捐赠给Apache基金会。
  • Apache Hadoop:由Apache基金会所开发的分布式系统基础架构,可使应用程序充分利用集群的威力高速运算和存储,用户可以在不了解分布式底层细节的情况下,开发分布式程序。
  • Apache Lucene:一个全文检索引擎工具包,目的是为软件开发人员提供一个简单易用的工具包,以方便的在目标系统中实现全文检索的功能,或者是以此为基础建立起完整的全文检索引擎。
  • Apache Pig:一个基于Hadoop的大规模数据分析平台,它提供的类SQL语言称为Pig Latin,该语言的编译器会把类SQL的数据分析请求转换为一系列经过优化处理的MapReduce运算。Pig为复杂的海量数据并行计算提供了一个简单的操作和编程接口。

2. 服务器和存储 

Twitter需要将每天用户发送的推文存储到数据库,并推送给其他相关的用户。该过程用到的开源项目包括: 

  • Linux:主要用于Twitter服务器。
  • Memcached:主要用于Twitter的缓存基础设施,作用是加速动态Web应用程序,减轻数据库负载。
  • Mysql:流行的开源关系型数据库,被Twitter大量用于存储Twitter消息。
  • Node.js:一套用来编写高性能网络服务器的JavaScript工具包,在Twitter中用于队列处理(接收推文并写入数据库),使服务器能处理每个连接而不会阻塞通道。

3.  Twitter工程师的工具箱 

  • Apache Subversion:开源的版本控制系统
  • Git:一个分布式的版本控制系统
  • Eclipse:大名鼎鼎的Java IDE。
  • Gerrit:一个基于Web的代码评审和项目管理的工具,主要面向基于Git版本控制系统的项目
  • Jenkins:一个持续集成引擎,主要用于持续、自动地构建/测试软件项目,以及监控一些定时执行的任务
  • RSpec:一个BDD 测试工具

4.  Twitter背后的编程语言和框架 

  • OpenJDK:Java的开源版本。Twitter陆续将一些项目从Rails迁移到了Java。
  • Python:一种高效的动态解释型Web编程语言。
  • Ruby和Ruby on Rails:Twitter最初主要由Ruby和Rails开发。
  • Scala:Twitter使用的主要应用编程语言之一,很多Twitter的基础架构都是用Scala编写。
  • Clojure:Clojure是一种运行在Java平台上的Lisp方言,在任何具备Java虚拟机的地方,都可以利用Lisp的强大功能。Twitter的大数据处理系统Storm就是基于Clojure。
  • Drupal:使用PHP语言编写的开源内容管理框架(CMF),由内容管理系统(CMS)和PHP开发框架共同构成。Twitter的开发者社区基于Drupal构建。
  • Sinatra:一个轻量、快速的Ruby开发框架。

5.  Twitter的前端解决方案 

  • jQuery:全球使用最广泛的JavaScript框架。
  • Less:一个使用广泛的CSS预处理器,通过简单的语法和变量对CSS进行扩展,可减少很多CSS的代码量。
  • MooTools:一个简洁、模块化、面向对象的开源JavaScript框架,为开发者提供了一个跨浏览器的JS解决方案
  • Zepto.js:一个轻量级的Javascript框架,主要用于移动开发

6.  Twitter服务开发框架 

  • TwistedMatrix:一个Python 框架,用来开发非阻塞异步的网络服务和应用程序。
  • Netty:一个异步的、事件驱动的Web应用框架和工具,用于快速开发高性能、高可靠性的网络服务器和客户端程序。Netty目前作为Twitter的核心队列Kestrel的通信模块。
  • Apache Thrift:一个由Facebook开源的远程服务调用框架,采用接口描述语言定义并创建服务,支持可扩展的跨语言服务开发,所包含的代码生成引擎可以在多种语言中创建高效的、无缝的服务。

Twitter公司所开源的项目 

Twitter从开源社区中获得了大量的好处,而Twitter也在不断地回馈社区,开源了大量基础设施和工具,使得其他企业和开发者不必重新发明轮子,在这些开源项目的基础上更加快速地实现自己所需。 

1.  大数据处理 

  • scalding:一个用于Cascading的Scala API。Cascading是一个构建于Hadoop上的API,用来创建复杂和容错数据处理工作流,它抽象了集群拓扑结构和配置,允许开发者快速开发复杂分布式的应用,而不用考虑背后的MapReduce。
  • summingbird:允许开发者以类似于本地Scala或Java的方式编写MapReduce程序,并在大部分著名的分布式MapReduce平台(包括Storm和Scalding)中执行它们。

2.  前端项目 

  • Bootstrap:一个用于前端开发的工具包,包含了基本的CSS、HTML组件,包括排版、表单、按钮、表格、网格、导航等。
  • TwUI:针对Mac平台的、支持硬件加速的UI框架,受到了UIKit的启发。
  • typeahead.js:一个快速、全功能的自动完成库
  • hogan.js:一个Mustache模板语言的编译器

3.  后端服务 

  • Twitter Mysql:Twitter的MySQL分支
  • Parquet:一种Twitter内部供Hadoop使用的列式存储格式,为Hadoop生态系统中的所有项目提供支持高效率压缩的列式数据表达,而且与数据处理框架、数据模型或编程语言无关。
  • Finagle:一个允许开发者使用Java、Scala或其他JVM语言来构建异步RPC服务器和客户端的库,主要用于Twitter的后端服务。
  • iago:一个负载生成器,用来在产品正式发布前做流量负载测试。
  • twemproxy:一个快速、轻量级的memcached和redis代理服务器
  • zipkin:一个分布式的跟踪系统。在Twitter中用于收集各个服务上的监控数据,并提供查询接口。

4.  Twitter基础设施通用库 

  • commons:Twitter的Python、JVM公共库
  • util:Twitter的一些可重用的代码库
  • cassovary:一个基于JVM的简单的大图形处理库

5.  收购其他公司后开源的项目 

Twitter还收购了一些公司,并将这些公司的软件以开源形式发布。 

  • Storm:这是一个类似于Hadoop的实时数据处理框架,最初由BackType开发,后来BackType被Twitter收购,Twitter将Storm作为其实时数据分析系统。
  • Whisper Systems的所有项目:Whisper Systems是一家移动安全初创公司,主要为Android手机和平板用户提供企业级的安全和管理解决方案。Twitter于2011年12月收购该公司,随后宣布将逐步开放Whisper Systems所有软件源代码。

更多的开源项目:http://twitter.github.io/ 

Twitter内部的开源氛围 

1.  比Google更自由 

尽管Google也开源了大量的项目,但是其开源程度并没有Twitter彻底。比如在数据中心方面,Google做了大量的保密工作,而在Twitter公司,这些要开放得多,员工自由实验的空间更大。 

在一些大型企业中,所使用的软件或系统是相当固定的,员工需要在该基础设施上开发东西。而据Twitter员工透露,Twitter允许员工尝试新的不同的东西,甚至允许使用不同的语言和开源项目来重构Twitter的一些服务。 

之前Google“20%的自由时间”为人津津乐道,如今该福利已经取消了。而在Twitter,每季度公司会举办hackweeks,员工可以拿出一周的时间从事各式各样的项目,这些项目不需要和他们每天的职责相关。 

2.  在公司内部培训开源技术 

2013年8月,Twitter收购了致力于开源技术培训的Marakana公司,成立了Twitter大学(Twitter University),其目的主要是为内部员工提供更丰富的培训资源,同时也希望吸引更好的工程技术人才加入公司。 

Twitter大学将陆续向大众开放,Twitter也将部分教育资源放到了网上。比如scala_school(这是针对Scala编程语言的一系列教程)。 

Twitter对开源基金会的支持 

Twitter也通过资金和代码赞助了一些开源基金会和组织。 

  • Ada Initiative:一个在技术和文化上支持妇女参与开源技术的组织。
  • Apache软件基金会:Twitter工程师也参与贡献了Apache软件基金会的部分项目。
  • Eclipse基金会
  • JCP:Java社区进程,主要负责制定Java规范和标准。
  • Linux基金会:负责协调和推动Linux系统的发展。
  • OIN:Open Invention Network(开放创新网络),一个旨在减轻Linux开发人员受到专利诉讼压力的机构。
  • OpenJDK:Java的开源实现。

总结 

Twitter在2011年就专门成立了一个“开源办公室”,用来支持对Twitter至关重要的开源组织。这足以见得开源对于Twitter的重要性。 

Twitter公司开源负责人Chris Aniszczyk称,如果在开源社区花费一些精力,将会意识到信息的开放对于整个世界所带来的积极影响,在Twitter,从内到外都保持着开放的心态和浓厚的开源氛围,而且每个员工都有机会参与其中。同时Twitter对开源社区所做出的伟大工作充满感恩,并将一直和开源社区保持健康的关系。 

再来看国内,如今一些大型互联网公司也开始重视开源,在使用开源项目构建基础服务的同时,也不忘回馈开源社区。【企业开源系列】后面也将会聚焦国内开源企业,带领大家认识一个全新的国内开源生态。 

更多信息可参考Twitter公司开源负责人Chris Aniszczyk在LinuxCon EU 2013大会上的演讲PPT,以及以及Twitter公司的开源站点。 

相关阅读: 

  • 【企业开源系列】Google背后的开源力量
  • 【企业开源系列】后起之秀Facebook凭什么挑战互联网霸主Google?

http://chatgpt.dhexx.cn/article/gLyOQd0y.shtml

相关文章

Twitter在15岁终于迎来蜕变

热点追踪 / 深度探讨 / 实地探访 / 商务合作 弹指一挥间,Twitter已经15岁了。15年前,Twitter还被叫做“微型博客”。而今天,再用“微型博客”来称呼她显然已经不合适了。仅今年,Twitter就进行了一系列少有的大动作,不但…

开发者福利!Twitter 推出开源 iOS 文本编辑器 API

点击⬇️方“逆锋起笔”,公众号回复 pdf 领取大佬们推荐的学习资料技术编辑:宗恩丨发自 思否编辑部 近日,Twitter 宣布将为 iOS 开发人员提供一种独立且灵活的开源 API——Twitter Text Editor,该 API 可以为应用程序提供功能全面…

相关性研究思路及代码实现(MIC-最大信息系数、Relif-F特征选择算法、pearson、spearman、kendall、卡方检验、fisher精确检验、F检验、简单粗暴的分层聚合)

相关性研究思路及代码实现(MIC-最大信息系数、Relif-F特征选择算法、pearson、spearman、kendall、卡方检验、fisher精确检验、F检验、简单粗暴的分层聚合) 为什么要研究相关性?相关性计算方法选择与代码实现1. 数据预览与清洗a. 连续变量b. …

列联表与独立性检验(一维列联表 二维列联表 三维列联表 ; 卡方检验 Fisher精确检验 Cochran-Mantel-Haenszel检验)

文章目录 列联表一维列联表二维列联表三维列联表 独立性检验卡方检验Fisher精确检验Cochran-Mantel-Haenszel检验 列联表 列联表可以告诉你组成表格的各种变量组合的频数或比例 一维列联表 data <- with(Arthritis,table(Improved)) ## 简单的频数统计表dataprop.table(…

知识小结------数据分析------Fisher‘s exact test(费希尔检测)

系列知识小结目录 Cox比例风险回归模型&#xff08;proportional hazards model&#xff09; Fishers exact test费希尔检测 系列知识小结目录前言一、Fishers exact test费希尔检测是什么&#xff1f;二、原理与公式1.适用范围和目的2.公式的应用1.进行假设2.运用公式求概率P值…

7. R语言【独立性检验】:卡方独立性检验、Fisher精确检验 、Cochran-Mantel-Haenszel检验

文章目录 1. 卡方检验2. 费希尔精确检验&#xff08;Fisher Exact Test&#xff09;3. Cochran-Mantel-Haenszel检验 独立性检验&#xff1a;用来判断变量之间相关性的方法&#xff0c;如果两个变量彼此独立&#xff0c;那么两者统计上就是不相关的 1. 卡方检验 可以使用chis…

R语言检验独立性:卡方检验(Chi-square test)和费舍尔Fisher精确检验分析案例报告

统计检验最常见的领域之一是检验列联表中的独立性。在这篇文章中&#xff0c;我将展示如何计算列联表&#xff0c;我将在列联表中引入两个流行的检验&#xff1a;卡方检验和Fisher精确检验。 什么是列联表&#xff1f; 列联表提供关于两个分类变量的测量的整数计数。最简单的…

SPSS图文教程:两个率的比较(卡方检验)及Fisher精确检验

很多小伙伴在第一次做四格表卡方检验时&#xff0c;看着输出结果可能会疑惑&#xff0c;我是看Pearson卡方结果呢&#xff0c;还是看Fisher精确检验的结果呢&#xff1f;如果你正好有此疑问&#xff0c;希望这篇文章能对你有所帮助。 本篇文章图片较多&#xff0c;加载可能略慢…

Fisher精确检验【转载】

转自:https://en.wikipedia.org/wiki/Fisher%27s_exact_test https://www.cnblogs.com/Dzhouqi/p/3440575.html 1.定义 Fishers exact test( 费希尔精确检验) 是用于分析列联表(contingency tables)统计显著性检验方法,它用于检验两个分类的关联(association)。虽然实际…

如何在 R 中进行 Fisher 精确检验

Fisher 精确检验 是一种显着性检验,当样本量较小时,它用于代替 22 表中的卡方检验。 本教程解释了如何在 R 中进行 Fisher 精确检验。 R中的Fisher精确检验 为了在 R 中进行 Fisher 精确检验,您只需要一个 22 数据集。使用下面的代码,我生成了一个假的 22 数据集作为示例…

Fisher精确检验

检验两个二进制变量是否是独立的。该检验可以分析 2x2 列联表&#xff0c;并产生精确的 p 值&#xff0c;以检验以下假设&#xff1a; H0&#xff1a;行变量和列变量是独立的 H1&#xff1a;行变量和列变量是相关的 Fisher 精确检验中的 p 值对于所有样本数量都是准确…

方差分析/卡方/fisher精确检验

方差分析 前提条件&#xff1a; 1、各样本须是相互独立的随机样本; 2、各样本来自正态分布总体; 3、各总体方差相等,即方差齐。&#xff08;方差不齐&#xff0c;用非参数检验&#xff09; 适用数据情况&#xff1a; 分类变量的连续变量 例如&#xff1a; 卡方检验 **分层…

Fisher exact test费雪精确检验

参考&#xff1a;https://wenku.baidu.com/view/2296e667b6360b4c2e3f5727a5e9856a5612268a.html https://en.wikipedia.org/wiki/Fisher%27s_exact_test 概述 Fisher精确检验是在列联表分析中使用的统计显着性检验。[1] [2] [3]尽管实际上是在样本量较小的情况下使用的&…

数学建模拓展内容:卡方检验和Fisher精确性检验(附有SPSS使用步骤)

卡方检验和Fisher精确性检验 卡方拟合度检验卡方独立性检验卡方检验的前提假设Fisher精确性检验 卡方拟合度检验 卡方拟合度检验概要&#xff1a;卡方拟合度检验也被称为单因素卡方检验&#xff0c;用于检验一个分类变量的预期频率和观察到的频率之间是否存在显著差异。 卡方…

Fisher精确检验.医学统计实例详解-医学统计助手★卡方检验,t检验,F检验,秩和检验,方差分析

Fisher精确检验是一种在统计分析中经常使用的方法&#xff0c;旨在评估两个分类变量之间是否存在显著关系。这种方法由罗纳德A费舍尔&#xff08;Ronald A. Fisher&#xff09;于20世纪20年代提出&#xff0c;并被广泛应用于小样本数据集的分析。与卡方检验相比&#xff0c;Fis…

运维之道 | Mysql主从复制+mycat读写分离

运维之道 | Mysql主从复制 Mycat读写分离 1、什么是读写分离 读写分离&#xff0c;基本的原理是让主数据库处理事务性增、删、改操作&#xff08;INSERT、UPDATE、DROP&#xff09;,而从数据库处理SELECT查询操作。数据库复制被用来把事务性操作导致的变更同步到集群中的从数据…

生产上遇到的一例mycat读写分离延时问题

问题描述 场景是这样的&#xff0c;我们的支付系统在一笔支付完成后&#xff0c;需要发出通知给到商户。支付完成的消息通过消息队列发送给通知的服务。通知服务的有一部分处理逻辑是这样的&#xff1a; notifyPersist.saveNotifyRecord(notifyRecord);notifyRecord rpNotify…

MySQL数据库mycat读写分离

mycat读写分离 Mycat的读写分离是建立在Mysq的主从复制的基础上的 修改配置文件 schema.xml <?xml version"1.0"?> <!DOCTYPE mycat:schema SYSTEM "schema.dtd"> <mycat:schema xmlns:mycat"http://io.mycat/"><schem…

MySQL主从配置与Mycat读写分离

MySQL主从配置与Mycat读写分离 一、主数据库配置 编辑配置文件 添加如下内容 server-id1 binlog-do-dbmaster_db1 #备份的数据库 log-binmysql-bin binlog-ignore-dbmysql重启mysql 创建一个允许从服务器来访问的用户(主服务器)&#xff1a; grant replication slave on *.* …

mycat读写分离实验

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程 首先搭建mysql主从环境&#xff0c;及mycat安装 配置mycat的schema.xml文件 <?xml version"1.0"?> <!DOCTYPE mycat…