- 1、本文档共13页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
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
- 2022年部编人教版九年级数学上册期末考试题及答案【最新】.doc
- 人教部编版四年级数学(上册)期末质量分析卷及答案.doc
- 人教版一年级科学下册期中试卷及答案【一套】.doc
- 2023年人教版九年级地理(上册)期末考试卷及答案.doc
- 2022-2023年人教版七年级数学下册期中测试卷及答案【全面】.doc
- 苏教版五年级《数学》下册全单元测试题【附答案】.docx
- 人教版三年级语文上册期末考试卷及答案【全面】.doc
- 部编版五年级数学下册期中考试题及答案【完美版】.doc
- 2022年部编版六年级数学上册期末试卷加答案.doc
- 2021—2022年部编人教版三年级语文上册期末试卷(参考答案).doc
文档评论(0)