分布式应用雪崩效用
对雪崩效用的理解
服务C依赖服务B,服务B依赖服务A,当服务A挂掉,这样服务B的请求一直等待,到超时为止,导致服务B的资源耗尽。
雪崩效用的原因
- 服务提供者不可用
- 重试加大流量
- 服务调用者不可用
服务提供者不可用的原因
- 硬件故障:服务器宕机或者网络故障
- 程序bug
- 缓存击穿:一般发生在缓存应用重启, 所有缓存被清空时, 以及短时间内大量缓存失效时。大量的缓存不命中, 使请求直击后端, 造成服务提供者超负荷运行, 引起服务不可用。
- 用户大量请求:在秒杀和大促开始前, 如果准备不充分, 用户发起大量请求也会造成服务提供者的不可用。
重试加大流量的原因
- 用户重试:在服务提供者不可用后, 用户由于忍受不了界面上长时间的等待, 而不断刷新页面甚至提交表单。
- 代码逻辑重试:这是程序自己做的重试
服务调用者不可用产生的主要原因
同步等待造成资源耗尽:
当服务调用者使用 “同步调用” 时, 会产生大量的等待线程占用系统资源. 一旦线程资源被耗尽,服务调用者提供的服务也将处于不可用状态, 于是服务雪崩效应产生了.
解决方案
- 超时机制:设置超时时间
- 服务限流
- 防止缓存击穿
- 服务熔断:服务B检查到服务A的接口不稳定时(如:10次出错5次),然后就断开服务A的访问
- 服务降级:服务B准备一个回退机制,备用接口
- 将同步等待改成异步:防止长时间占用资源导致耗尽
- 服务器自动扩容:这个最好使用云服务器(AWS的auto scaling、Azure),能够有大量冗余,也能实现自动扩容
限流的解决方法
- 程序限流:信号量、线程池 + 队列
- 网关限流:因为Nginx的高性能, 目前一线互联网公司大量采用Nginx+Lua的网关进行流量控制, 由此而来的OpenResty也越来越热门。
- 用户交互限流:1. 采用加载动画,提高用户的忍耐等待时间. 2. 提交按钮添加强制等待时间机制.
防止缓存击穿的方法
- 当多个线程进来查缓存的时候,因为这时缓存中无数据
- 那用setNx()做一个互斥锁,只有一个线程能够拿到这个锁
- 拿到锁的线程就查DB,然后将DB数据放回到缓存
- 拿不到锁的线程,就先等待一段时间(如:5秒),然后再进行第一步的查询
熔断和降级的方法
Hystrix:可以实现限流、熔断、降级
限流:
配置properties
继承HystrixCommoned
重写run方法中实现要限流的服务请求
熔断:
配置properties,满足条件后就会断绝run方法
降级:
配置properties
重写fallback方法,在里面写降级时要调用的方法
相关推荐
无论是 CORBA、DCOM 还是 RMI,它们都在各自的领域内取得了显著的成绩,并且随着技术的进步和应用场景的不断拓展,这些技术还将继续发挥更大的作用。对于开发者来说,了解并掌握这些关键技术将有助于构建更加高效、...
ASP.NET 分布式应用程序是构建在微软.NET框架之上的高级Web应用技术,它允许开发者创建高性能、可伸缩且能够处理大规模并发用户的网络应用。在ASP.NET中,分布式应用程序主要涉及多个独立运行的组件,它们可以分布在...
《Delphi7组件与分布式应用开发》一书深入探讨了使用Delphi 7进行组件编程和构建分布式应用程序的关键技术。Delphi 7是 Borland 公司推出的一款强大的面向对象的编程工具,以其高效的编译器和丰富的VCL(Visual ...
分布式应用程序代码是现代软件开发中的一个重要领域,它涉及到多个计算机节点通过网络协同工作来执行同一程序的不同部分。这种模式能够实现大规模数据处理、高可用性和负载均衡,是云计算和大数据平台的基础。本...
另外,本书介绍了 Actor 模型的一个实现框架 Akka 以及它的工具,而后讨论了在充分利用 actor 架构的基础上使用 Akka 框架来设计软件系统的方法,以及使用它来开发并发性和分布式应用程序的方怯。本书还介绍了领域 ...
### Java分布式应用与SOA概览 在深入探讨Java分布式应用和面向服务架构(SOA)之前,我们首先需要理解这两个概念的基本含义及其在现代IT系统中的重要性。 #### Java分布式应用 Java分布式应用是指利用Java编程...
《Visual Basic6.0分布式应用程序开发》是一本深入探讨如何使用Visual Basic6.0进行分布式系统构建的专业教程。分布式应用程序是指由多个独立组件通过网络进行通信和协作来完成任务的软件系统。在VB6.0中,开发者...
Java 分布式应用程序设计是构建大型、可扩展和高可用性系统的关键技术。在现代企业级应用中,尤其是在云计算和微服务架构盛行的今天,掌握Java分布式应用的设计原则和技术至关重要。下面将详细介绍Java分布式应用...
Java分布式应用程序设计是一种构建大型、可扩展且高可用性系统的方法。在Java中,通过利用网络中的多台计算机,可以创建能够跨越多个节点共享资源、处理任务和存储数据的复杂应用。这种技术允许应用程序的不同部分在...
基于ICE中间件的分布式应用开发研究 本文研究了基于ICE中间件的分布式应用开发,通过介绍中间件的特点,分析了ICE中间件的架构及主要构成,以地面测试人员获取远端被测设备的系统时间为例,介绍了一种基于ICE中间件...
因为DCOM是世界上领先的组件技术COM的无缝扩展,所以你可以将你现在对基于COM的应用、组件、工具以及知识转移到标准化的分布式计算领域中来。当你在做分布式计算时,DCOM处理网络协议的低层次的细节问题,从而使你...
《Akka应用模式:分布式应用程序设计实践指南》是一本深入探讨Akka框架的书籍,旨在帮助开发者理解和掌握在分布式环境中构建高效、容错的应用程序。Akka是基于Actor模型的并行和分布式计算库,使用Scala和Java语言,...
Microsoft Visual Basic6.0分布式应用程序开发
java wrapper 分布式应用组件、可以把java程序以服务的形式分布于不同的服务器
阿里云专有云企业版V3.8.1企业级分布式应用服务产品简介 本文档是阿里云专有云企业版V3.8.1企业级分布式应用服务的产品简介。该产品是阿里云提供的一种企业级分布式应用服务,旨在帮助企业快速构建、部署和管理...
分布式应用源代码主要涉及到在大型系统中如何设计和实现能够跨多台计算机协同工作的应用程序。在现代互联网服务中,分布式应用已经成为主流,因为它们能够提供高可用性、可伸缩性和容错性。这里提到的"分布式应用源...
本篇文章将深入探讨“云计算分布式应用”,特别关注百度和新浪等大型企业在云技术上的应用实践。 首先,我们来理解什么是云计算。云计算是一种通过互联网提供计算资源和服务的模式,用户无需直接管理或拥有硬件基础...
分布式Java应用基础与实践是Java开发领域中的一个重要主题,它涉及到如何通过网络将多个独立的计算机节点连接起来,协同处理任务,以实现系统的高可用性、高性能和可伸缩性。在Java中,分布式系统主要依赖于一些核心...
在IT领域,分布式应用程序开发是构建复杂系统的关键技术,它涉及多个计算机节点通过网络协同工作以执行任务。Visual Basic 6.0(VB6)作为经典的编程环境,提供了丰富的工具和功能来支持分布式应用程序的创建。本...