Uber平台架构设计介绍.pdf

  1. 1、本文档共13页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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 , 这是非常

文档评论(0)

147****2695 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档