- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Uber 平台架构设计介绍
1
首先谈到 Uber 的初心,他们想实现一键打车功能。左边是 Uber 最早期的界面,大家可以看到跟现
在有很大的区别,按一下就可以打到车了。
Uber 的最初架构
为了支持这样的服务, Uber 最初的架构是怎么样的呢?会很复杂吗?其实不会。
2
前面是一个手机,中间是 PHP 来负责业务逻辑,最后是 MySQL 的数据。司机每隔 4 秒上传自己的
经纬数据来更新自己的位置,而这些数据会存在 MySQL 里,当用户请求来的时候, PHP 会调用
MySQL 的查询语句来寻找匹配的司机。这是一个非常简单的架构,能够快速的支撑 Uber 的需求。
架构扩展
那这样的架构如何扩展呢?因为 Uber 非常火爆,用户蜂拥而至,很简单的方法就是将 PHP 变成多
进程多线程,可以同时访问 MySQL 得到数据。
3
但是这样的架构有很多缺点:
缺点一:一个司机两个乘客
因为每个 PHP 是独立访问 MySQL 的,而有些机制没有做好的话,很可能一个司机被两个 PHP 进程
查询到了后台,同时返回给两个用户,所以会出现一个司机被派给两个用户的情况。
缺点二:两个司机一辆车
有时候两个司机公用一辆车,他们用两个 APP ,这时候只能派遣一次,就会出问题。
缺点三:一个账号两辆车
4
两个用户登录同一个账号,这时你会看到用户的位置在不断的漂移,你会非常困惑。
出现这么多问题,我们应该如何改进呢?
谈到改进,我们再把刚才的服务具体化,会有派遣服务,派遣服务后面是 MySQL 的存储状态,整体
是一个实时逻辑,用户可以通过 iphone ,Android ,SMS 连在上面。谈到改进,这是一个逐步的过
程,不可能一口吃一个胖子。
5
我们首先可以把一些 影响我们派遣服务的逻辑拿出来。 比如商业逻辑, 像用户绑定手机号, 付款之列,
可以通过 Python 的 API 进行调用,因此减轻了派遣服务的能力。再进一步,我们 可以在中间加上消
息队列 ,因为有各种请求,不见得所有请求都通过派遣服务走,像商业逻辑可以直接走 API 。而且消
息队列在这里面可以抵挡更大的连接,更多的请求,本身还有个消息队列的机制。同时为了存储一些
比如 GPS 日志,可以 在 MongoDB 里保存 ,从而也减轻了派遣服务。我们可以看到逐渐减轻派遣服
务的压力。这之后大家如果在各个层级里出问题可以重试。重试很好,因为便于出错以后的恢复。但
也存在一个隐患,稍后会讲到。
6
在这个基础上,我们还可以进一步变化, 将派遣服务也变成 Node.js ,派遣数据变成 MongoDB ,
这是非常
您可能关注的文档
- H3CCAS高可靠性和高可用性技术白皮书.pdf
- H3Cloud云操作系统产品概述.pdf
- H3CSecPathGAP2000数据库同步配置指南.pdf
- Hadoop和Spark大数据项目案例分析.pdf
- Hyper-V虚拟化平台最佳技术实践.pdf
- IBMSpectrumScale技术和架构详解.pdf
- InfiniBand网络技术及主流厂商分析.pdf
- ITSM运维平台-技术方案建议书.pdf
- IT自动发现与运维解决方案.pdf
- Java构建微服务指南.pdf
- 新解读《GB_T 28923.5-2012自然灾害遥感专题图产品制作要求 第5部分:救助与恢复重建评估专题图产品》.pptx
- 新解读《GB_T 28926-2012信息技术 射频识别 2.45GHz空中接口符合性测试方法》.pptx
- 新解读《GB_T 29332-2012半导体器件 分立器件 第9部分:绝缘栅双极晶体管(IGBT)》.pptx
- 新解读《GB_T 29459.1-2012在役承压设备金属材料小冲杆试验方法 第1部分:总则》.pptx
- 新解读《GB_T 28878.1-2012空间科学实验转动部件规范 第1部分:设计总则》.pptx
- 新解读《GB_T 3883.20-2012手持式电动工具的安全 第2部分:捆扎机的专用要求》.pptx
- 新解读《GB_T 28768-2012车用汽油烃类组成和含氧化合物的测定 多维气相色谱法》.pptx
- 新解读《GB_T 4324.7-2012钨化学分析方法 第7部分:钴量的测定 电感耦合等离子体原子发射光谱法》.pptx
- 新解读《FZ_T 10013.2-2011温度与回潮率对棉及化纤纯纺、混纺制品断裂强力的修正方法 本色布断裂强力的修正方法》最新解读.pptx
- 新解读《FZ_T 50010.13-2011粘胶纤维用浆粕 反应性能的测定》最新解读.pptx
文档评论(0)