- 1、本文档共17页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
- 嵌入式软件开发课程设计-俄罗斯方块游戏.pdf
- 企业文档管理系统-文档资料.pdf
- 禅道项目管理系统实施说明.pdf
- 《精选18套试卷》辽宁省大连西岗区七校联考2021年物理八年级第二学期期末学业水平测试试题含解析.pdf
- 2022年辽宁省普通高中学生学业水平考试信息技术真题.pdf
- 辽宁省抚顺一中2020学年高一英语下学期学业水平模拟测试试题.pdf
- 辽宁省沈阳市2015年学业水平测试预测数学试题2 Word版含答案.pdf
- 辽宁省辽阳市二年级下册语文期中学业水平测试卷A卷.pdf
- 辽宁省辽阳市二年级下册语文期中学业水平测试卷D卷.pdf
- 辽宁省沈阳市2018年学业水平测试预测数学试题1Word版含答案.pdf
文档评论(0)