网站大量收购独家精品文档,联系QQ:2885784924

分布式、高性能和高可用解决方案(分布式).pdfVIP

分布式、高性能和高可用解决方案(分布式).pdf

  1. 1、本文档共17页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
分布式、⾼性能和⾼可⽤解决⽅案(分布式) 1分布式 分布式系统会把⼀个应⽤系统拆分为可独⽴部署的多个服务,因此需要服务与服务之间远程协作才能完成事务操作。切记,分布式⼀定是存 在⽹络分区的。 2使⽤分布式需要解决哪些问题? 1)分布式 ID 2)rpc通信 3)分布式事务 4)分布式锁 5)分布式协调 下⾯我们逐⼀提供解决⽅法: 3分布式ID ⼀个最基本的分布式 ID 需要满⾜下⾯这些要求: 全局唯⼀ :ID 的全局唯⼀性肯定是⾸先要满⾜的! ⾼性能 : 分布式 ID 的⽣成速度要快,对本地资源消耗要⼩。 ⾼可⽤ :⽣成分布式ID 的服务要保证可⽤性⽆限接近于 100%。 ⽅便易⽤ :拿来即⽤,使⽤⽅便,快速接⼊! 除了这些之外,⼀个⽐较好的分布式 ID 还应保证: 安全 :ID 中不包含敏感信息。 有序递增 :如果要把 ID 存放在数据库的话,ID 的有序性可以提升数据库写⼊速度。并且,很多时候, 我们还很有可能会直接通过 ID 来进⾏排序。 有具体的业务含义 :⽣成的 ID 如果能有具体的业务含义,可以让定位问题以及开发更透明化(通过 ID 就能确定是哪个业务)。 独⽴部署:也就是分布式系统单独有⼀个发号器服务,专门⽤来⽣成分布式 ID。这样就⽣成 ID的服务可以和业务相关的服务解耦。不 过,这样同样带来了⽹络调⽤消耗增加的问题。 总的来说,如果需要⽤到分布式 ID的场景⽐较多的话,独⽴部署的发号器服务还是很 有必要的。 3.1 UUID UUID 可以保证唯⼀性,因为其⽣成规则包括 MAC 地址、时间戳、名字空间(Namespace)、随机或伪随机数、时序等元素,计算机基 于这些规则⽣成的 UUID 是肯定不会重复的。 UUID 的优缺点 : 优点 :⽣成速度⽐较快、简单易⽤ 缺点 : 存储消耗空间⼤(32 个字符串,128 位) 、 不安全(基于 MAC 地址⽣成 UUID 的算法会造成 MAC 地址泄露)、⽆序(⾮⾃ 增)、没有具体业务含义、需要解决重复 ID 问题(当机器时间不对的情况下,可能导致会产⽣重复 ID)。 3.2 Snowflake(雪花算法) Snowflake 是 Twitter 开源的分布式 ID ⽣成算法。Snowflake 由 64 bit 的⼆进制数字组成,这 64bit 的⼆进制被分成了⼏部分,每⼀部 分存储的数据都有特定的含义: 有很多基于 Snowflake 算法的开源实现⽐如美团 的 Leaf、百度的UidGenerator,并且这些开源实现对原有的 Snowflake 算法进⾏了优 化。 Snowflake 算法的优缺点 : 优点 :⽣成速度⽐较快、⽣成的 ID 有序递增、⽐较灵活(可以对 Snowflake 算法进⾏简单的改造⽐如加⼊业务 ID) 缺点 : 需要解决重复 ID 问题(依赖时间,当机器时间不对的情况下,可能导致会产⽣重复 ID)。 3.3 数据库号段模式 将ID存在在内存⾥⾯,需要⽤到的时候,直接从内存⾥⾯拿。数据库的号段模式也是⽬前⽐较主流的⼀种分布式 ID ⽣成⽅式。像滴滴开源 的Tinyid (opens new window) 就是基于这种⽅式来做的。 不过,TinyId 使⽤了双号段缓存、增加多 db ⽀持等⽅式来进⼀步优化。 current_max_id 字段和step字段主要⽤于获取批量 ID,获取的批量 id 为: current_max_id ~ current_max_id+step。version 字段主 要⽤于解决并发问题(乐观锁),biz_type 主要⽤于表⽰业余类型。 数据库号段模式的优缺点: 优点 :ID 有序递增、存储消耗空间⼩ 缺点 :存在数据库单点问题(可以使⽤数据库集群解决,不过增加了复杂度)、ID 没有具体业务含义、安全问题(⽐如根据订单 ID 的递增 规律就能推算出每天的订单量,商业机密啊!) 3 RPC通信 3.1 什么是 RPC? RPC(Remote Procedure Call)—远程过程调⽤,它是⼀种通过⽹络从远程计算机程序上请求服务,⽽不需要了解底层⽹络技术的 议。⽐如两个不同的服务 A、B 部署在两台不同的机器上,那么服务 A 如果想要调⽤服务 B 中的某个⽅法该怎么办呢?使⽤ HTTP请求 当 然可以,但是可能会⽐较慢⽽且⼀些优化做的并不好。 RPC 的出现就是为了解决这个问题。 3.2 RPC原理是什么 服务消费端(client)以本地调⽤的⽅式调⽤远程服务; 客户端 Stub(client

文档评论(0)

134****3224 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档