做网站工作图深圳网站建设 设计首选
做网站工作图,深圳网站建设 设计首选,wordpress 主题设置中文版,国内 wordpress主题分布式和微服务有什么区别
分布式是把一个集中式系统拆分成多个系统#xff0c;每一个系统单独对外提供部分功能#xff0c;整个分布式系统整体对外提供一整套服务。对于访问分布式系统的用户来说#xff0c;感知上就像访问一台计算机一样. 而分布式架构的具体实现有很多种…分布式和微服务有什么区别
分布式是把一个集中式系统拆分成多个系统每一个系统单独对外提供部分功能整个分布式系统整体对外提供一整套服务。对于访问分布式系统的用户来说感知上就像访问一台计算机一样. 而分布式架构的具体实现有很多种这其中包括了C/S架构、P2P架构、SOA架构、微服务架构.Serverless架构等 所以微服务架构是分布式架构的一种
微服务的优点
它将一个大型的应用程序拆分成一组小型、独立的服务单元每个服务单元都可以独立部署、运行和扩展。每个微服务都专注于执行一个特定的业务功能并通过轻量级的通信机制(如HTTP、RPC、MQ等)来相互调用。
微服务的目的是有效的拆分应用实现敏捷开发和部署 比如把一个原来中心化的商城服务拆分成产品服务、订单服务及用户服务每一个服务把功能内聚系统间通过远程调用解耦。实现高内聚低耦合 并且每一个服务都可以独立的提供子服务。并且他们有自己的应用、自己的存储是独立的互不影响的。
什么是微服务的循环依赖
订单服务下单需要调用库存服务校验库存库存扣减成功后需要调用订单服务接口进行通知这就是循环依赖
危害
1、流量放大: 因为系统之间存在循环依赖那么就会导致本来下单系统可能只有100 QPS但是因为存在循环依赖就会导致这个QPS被放大因为100个请求调用到订单服务订单服务就有100个请求调到库存服务而库存服务又有100个请求再调到订单服务。就导致订单服务有200的QPS了。无形中被放大了流量。 2、性能问题: 因为存在循环依赖那么服务之间需要等待彼此的响应就会无形中拖长请求的RT让接口性能变的更慢。 3、互相影响: 如果一个服务出现问题这个问题可能会通过循环依赖影响到另一个服务。而一个服务中的错误可能通过依赖链传播到其他服务增加了系统出现级联故障的风险。 4、发布困难: 每当一个服务需要更新时我们需要同时考虑他依赖了谁以及谁依赖了他。一般是被依赖的应用先发布。但是因为系统间存在循环依赖那么在上一个新的功能的时候需要发布时就会带来很大的问题那就是谁先发的问题而谁先发都会有问题。 如何解决呢
重新设计一个系统又在上游又在下游那定是设计的不合理所以需要考虑做重新设计
消息通信把直接接口调用改为消息通信实现解耦
引入共享服务当出现循环依赖时候可以考虑将共享部分抽取出来作为一个共享库然后由各个相关服务共同引用这个库
限流、熔断、降级的区别
限流限流的目的是控制流量的并发量常见的限流算法漏桶算法、令牌桶算法、计算器算法、滑动时间窗口算法
熔断熔断是为了防止系统因某个服务的故障而整体崩溃类似于电路的熔断器。在检测到下游服务异常时自动停止向该服务发送请求并在一定时间后尝试恢复举个例子当电商平台上用户支付时收银台发现某个支付渠道如微信支付失败率突增超时严重那么就可以临时把这个支付方式熔断掉。
降级是当系统负载过高时主动关闭一些非核心功能以确保核心功能的正常运行。一般用于在系统资源有限或响应时间过长时通过降低服务质量保障核心服务
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/88738.shtml
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!