【Spring Cloud】服务熔断

目录

  • 服务雪崩效应
    • 服务雪崩效应形成的原因及应对策略
    • 小结
  • Hystrix
    • 介绍
    • Hystrix可以做什么
      • 1.资源隔离
      • 2.请求熔断
      • 3.服务降级
    • 小结
  • Hystrix实现服务降级
    • 方式一:@HystrixCommand注解方式
      • 1.服务提供者
        • 1.1业务接口和业务实现中添加方法hystrixTimeout
        • 1.2控制器中处理/provider/hystrix/timeout/{id}请求
      • 2.服务消费者
        • 2.1demo-user-consumer添加依赖
        • 2.2在启动类上添加@EnableHystrix
        • 2.3在UserFeignClient接口创建远程调用的方法hystrixTimeout
        • 2.4在RPC调用方法上加上注解@HystrixCommand
      • 3.添加ribbon配置
      • 4.yml添加配置
      • 5.测试
        • 5.1场景一服务正常调用
        • 5.2场景二当被调服务停止运行时
        • 5.3场景三当调取服务超时时
        • 5.4场景四发生异常
      • 改进服务消费者-定义全局服务降级
    • 方式二:定义统一fallback接口
      • 1.创建降级(兜底)处理类UserFeignClientFallBack
      • 2.为接口指定容错处理
      • 3.测试
    • 方式三:定义fallbackFactory
      • 1.创建接口UserFeignClientWithFactory继承UserFeignClient接口
      • 2.HystrixClientFactory类实现FallbackFactory接口
      • 3.并使用内部匿名方法类,实现UserFeignClient接口中的方法
      • 4.测试:发生异常

服务雪崩效应

  • 在微服务架构中通常会有多个服务调用,基础服务的故障可能会导致级联故障,进而造成整个系统不可用的情况,这种现象被称为服务雪崩效应。
  • 服务雪崩效应是一种因“服务提供者”的不可用导致“服务消费者”的不可用,并将不可用逐渐放大的过程。
    在这里插入图片描述

服务雪崩效应形成的原因及应对策略

原因描述应对策略
硬件故障如服务器宕机,机房断电,光纤被挖断等多机房容灾、异地多活等。
程序Bug如程序逻辑导致内存泄漏,JVM长时间FullGC等修改程序bug、及时释放资源等。
缓存击穿一般发生在应用重启,所有缓存失效时,以及短时间内大量缓存失效时。大量的缓存不命中,使请求直击后端服务,造成服务提供者超负荷运行,引起服务不可用。缓存预加载、缓存异步加载等。
流量激增如异常流量,用户重试,代码逻辑重试加大流量等。服务自动扩容、流量控制(服务限流、关闭重试)等。
同步等待服务间采用同步调用模式,同步等待造成的资源耗尽。资源隔离、MQ解耦、不可用服务调用快速失败等。资源隔离通常指不同服务调用采用不同的线程池;不可用服务调用快速失败一般通过熔断器模式结合超时机制实现。

小结

  • 如果一个应用不能对来自依赖的故障进行隔离,那该应用本身就处在被拖垮的风险中。
  • 因此,为了构建稳定、可靠的分布式系统,我们的服务应当具有自我保护能力,当依赖服务不可用时,当前服务启动自我保护功能,从而避免发生雪崩效应。
  • 在SpringCloud中,将重点介绍使用Hystrix解决同步等待的雪崩问题。

Hystrix

介绍

  • Hystrix 是由Netflix发布,旨在应对复杂分布式系统中的延时和故障容错,基于Apache License 2.0协议的开源的程序库,目前托管在GitHub上。
  • 在分布式系统中,许多依赖不可避免的会调用失败,比如超时、异常等,Hystrix能保证在一个依赖出问题的情况下,不会导致整体服务失败,避免级联故障,以提高分布式系统的弹性。
  • 官网:https://github.com/Netflix/Hystrix
  • Hystrix的中文含义是豪猪, 因其背上长满了刺,而拥有自我保护能力。

Hystrix可以做什么

1.资源隔离

  • 货船为了进行防止漏水和火灾的扩散,会将货仓分隔为多个, 这种资源隔离减少风险的方式被称为:Bulkheads(舱壁隔离模式)。
  • Hystrix将同样的模式运用到了服务调用者上.如下图所示:
    在这里插入图片描述- 资源隔离:在Hystrix中, 主要通过线程池来实现资源隔离. 通常在使用的时候我们会根据调用的远程服务划分出多个线程池。
  • 在一个高度服务化的系统中,我们实现的一个业务逻辑通常会依赖多个服务,比如: 商品详情展示服务会依赖商品服务, 价格服务和商品评论服务 如图所示:
    在这里插入图片描述
  • 调用三个依赖服务会共享商品详情服务的线程池。如果其中的商品评论服务不可用, 就会出现线程池里所有线程都因等待响应而被阻塞, 从而造成服务雪崩。如图所示:
    在这里插入图片描述
  • Hystrix通过将每个依赖服务分配独立的线程池进行资源隔离, 从而避免服务雪崩。如下图所示, 当商品评论服务不可用时, 即使商品服务独立分配的20个线程全部处于同步等待状态,也不会影响其他依赖服务的调用。
    在这里插入图片描述

2.请求熔断

  • “断路器”本身是一种开关装置,当某个服务单元发生故障之后,通过断路器的故障监控(类似熔断保险丝),向调用方返回一个符合预期的、可处理的备选响应(FallBack),而不是长时间的等待或者抛出调用方无法处理的异常,这样就保证了服务调用方的线程不会被长时间、不必要地占用,从而避免了故障在分布式系统中的蔓延,乃至雪崩。
  • 当Hystrix Command请求后端服务失败数量超过一定比例(默认50%), 断路器会切换到开路状态(Open)。这时所有请求会直接失败而不会发送到后端服务。
  • 断路器保持在开路状态一段时间后(默认5秒), 自动切换到半开路状态(HALF-OPEN)。这时会判断下一次请求的返回情况, 如果请求成功, 断路器切回闭路状态(CLOSED), 否则重新切换到开路状态(OPEN)。
  • Hystrix的断路器就像我们家庭电路中的保险丝, 一旦后端服务不可用, 断路器会直接切断请求链, 避免发送大量无效请求影响系统吞吐量, 并且断路器有自我检测并恢复的能力.
    在这里插入图片描述

3.服务降级

  • 服务降级是当我们的某个微服务响应时间过长,或者不可用了,讲白了也就是那个微服务调用不了了,我们不能把错误信息返回出来,或者让他一直卡在那里,所以要在准备一个对应的策略(一个方法),当发生这种问题的时候我们直接调用这个方法来快速返回这个请求,不让他一直卡在那 。
  • Fallback相当于是降级操作. 对于查询操作, 我们可以实现一个fallback方法, 当请求后端服务出现异常的时候, 可以使用fallback方法返回的值. fallback方法的返回值一般是设置的默认值或者来自缓存,告知后面的请求服务不可用了,不要再来了。
    在这里插入图片描述

小结

  • 服务降级:服务器忙,请稍后再试,不让客户端等待并立刻返回一个友好提示。会出现服务降级的情况:程序运行异常、超时、服务熔断触发服务降级、线程池/信号量打满也会导致服务降级。
  • 服务熔断:类比保险丝达到最大服务访问后,直接拒绝访问,拉闸限电,然后调用服务降级的方法并返回友好提示。
  • 接近实时的监控:服务的降级->进而熔断->恢复调用链路
  • 服务限流:秒杀高并发等操作,严禁一窝蜂的过来拥挤,大家排队,一秒钟N个,有序进行。

Hystrix实现服务降级

方式一:@HystrixCommand注解方式

1.服务提供者

1.1业务接口和业务实现中添加方法hystrixTimeout
public interface UserService {boolean checkUser() throws Exception;String findFeignTimeOut() throws Exception;String hystrixTimeout(Integer id) throws Exception;
}
@Service
public class UserServiceImpl implements UserService {@Overridepublic boolean checkUser() throws Exception {return true;}@Overridepublic String findFeignTimeOut() throws Exception {//模拟当前业务,当前业务的执行需要3秒钟TimeUnit.SECONDS.sleep(3);return "模拟当前业务,当前业务的执行需要3秒钟";}@Overridepublic String hystrixTimeout(Integer id) throws Exception {//TimeUnit.SECONDS.sleep(6);//return "当前线程的名称:"+Thread.currentThread().getName()+"===,id:"+id;throw new Exception("发生了异常:" + id);}
}
1.2控制器中处理/provider/hystrix/timeout/{id}请求
@RestController
@Slf4j
public class UserController {@Resourceprivate UserService userService;@PostMapping("/provider/checkUser")public boolean checkUser() throws Exception{return userService.checkUser();}@PostMapping("/provider/findFeignTimeOut")public String findFeignTimeOut() throws Exception{return userService.findFeignTimeOut();}@GetMapping("/provider/hystrixTimeout/{id}")public String hystrixTimeout(@PathVariable("id") Integer id) throws Exception{return userService.hystrixTimeout(id);}
}

2.服务消费者

2.1demo-user-consumer添加依赖
        <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-hystrix</artifactId></dependency>
2.2在启动类上添加@EnableHystrix
@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
@EnableHystrix
public class DemoUserConsumerApplication {public static void main(String[] args) {SpringApplication.run(DemoUserConsumerApplication.class, args);}
}
2.3在UserFeignClient接口创建远程调用的方法hystrixTimeout
@FeignClient(name = "DEMO-USER-PROVIDER")
public interface UserFeignClient {/*** 远程调用DEMO-USER-PROVIDER中的/provider/checkUser服务* 调用的路径名称必须和服务提供者保证高度一致* @return* @throws Exception*/@PostMapping("/provider/checkUser")boolean checkUser(@RequestParam String id) throws Exception;@PostMapping("/provider/findFeignTimeOut")String findFeignTimeOut() throws Exception;@GetMapping("/provider/hystrixTimeout/{id}")String hystrixTimeout(@RequestParam @PathVariable("id") Integer id) throws Exception;
}
2.4在RPC调用方法上加上注解@HystrixCommand

注解:@HystrixCommand(fallbackMethod = “hystrixTimeoutFallback”),这就指定了该方法的降级方法是哪个。

@Service
public class LocalUserServiceImpl implements LocalUserService {@Resourceprivate UserFeignClient userFeignClient;@Overridepublic boolean doLogin(String id) throws Exception {//通过http协议调用的服务return userFeignClient.checkUser(id);}@Overridepublic String queryFeignTimeOut() throws Exception {return userFeignClient.findFeignTimeOut();}/*** 当远程调用provider的服务时,如果服务提供者正确响应,获取provider的返回值即可* 当远程调用provider的服务时,如果服务提供者响应失败或出现异常,则返回fallbackMethod中的降级方法* fallbackMethod属性指定的就是降级的方法* @param id* @return* @throws Exception*/@HystrixCommand@Overridepublic String hystrixTimeout(Integer id) throws Exception {return userFeignClient.hystrixTimeout(id);}public String fallbackHystrixTimeout(Integer id){return "服务降级,服务器繁忙,请耐心等待";}
}

3.添加ribbon配置

@Configuration
public class RibbonConfiguration {@Beanpublic IClientConfig ribbonClientConfig() {DefaultClientConfigImpl config = new DefaultClientConfigImpl();return config;}@Beanpublic IRule myRule(IClientConfig config) {config.setProperty(IClientConfigKey.Keys.ConnectTimeout,5000);// 设置连接超时为5000毫秒config.setProperty(IClientConfigKey.Keys.ReadTimeout,5000);// 设置读取超时为5000毫秒return new RoundRobinRule();}
}

4.yml添加配置

在application. yml中添加配置开启容错

server:port: 8085
spring:application:name: demo-user-consumer
eureka:client:service-url:defaultZone: http://localhost:7776/eureka/
logging:level:cn.kgc.feignclient: debug
feign:hystrix:enabled: true
hystrix:command:default:execution:isolation:thread:timeoutInMilliseconds: 5000

5.测试

5.1场景一服务正常调用

在这里插入图片描述

5.2场景二当被调服务停止运行时

在这里插入图片描述

5.3场景三当调取服务超时时

在这里插入图片描述

在这里插入图片描述

5.4场景四发生异常

在这里插入图片描述在这里插入图片描述

改进服务消费者-定义全局服务降级

  • 每一个业务方法都有一个对应的兜底方法,代码会膨胀
  • 和业务代码混在了一起,容易混乱在业务实现类添加注解@DefaultProperties(defaultFallback = “hystrixTimeOutFallback”)
  • 在方法上加注解@HystrixCommand
@Service
@DefaultProperties(defaultFallback = "fallbackHystrixTimeout")
public class LocalUserServiceImpl implements LocalUserService {@Resourceprivate UserFeignClient userFeignClient;@Overridepublic boolean doLogin(String phone,String password) throws Exception {return userFeignClient.checkUser(phone, password);}@Overridepublic List<String> searchUser(Map<String, Object> map) throws Exception {return userFeignClient.findUserList(map);}@HystrixCommand@Overridepublic String queryFeignTimeOut() throws Exception {return userFeignClient.findFeignTimeOut();}/*** 当远程调用provider的服务时,如果服务提供者正确响应,获取provider的返回值即可* 当远程调用provider的服务时,如果服务提供者响应失败或出现异常,则返回fallbackMethod中的降级方法* fallbackMethod属性指定的就是降级的方法* @param id* @return* @throws Exception*/@HystrixCommand@Overridepublic String hystrixTimeout(Integer id) throws Exception {return userFeignClient.hystrixTimeout(id);}public String fallbackHystrixTimeout(){return "服务降级,服务器繁忙,请耐心等待";}
}

方式二:定义统一fallback接口

1.创建降级(兜底)处理类UserFeignClientFallBack

  • 实现UserFeignClient接口,返回预先处理好的默认值。
@Component
public class UserFeignClientFallback implements UserFeignClient {/*** 当调用checkUser方式时,会调用DEMO-USER-PROVIDER的/provider/checkUser API接口* 调用的路径要求DEMO-USER-PROVIDER中路径保持一致* 如果调用的方法包含参数,需要和DEMO-USER-PROVIDER中的参数保持一致** @param phone* @param password* @return* @throws Exception*/@Overridepublic boolean checkUser(String phone, String password) throws Exception {return false;}@Overridepublic String findFeignTimeOut() throws Exception {return "服务调用失败,服务降级测试";}@Overridepublic String hystrixTimeout(Integer id) throws Exception {return "服务调用失败,服务降级测试";}
}

2.为接口指定容错处理

在这里插入图片描述

  • demo-user-consumer-hystrix项目的UserFeignClient接口中,通过@FeignClient注解的fallback属性指定容错处理类。
/*** 通过name或value属性指定远程调用的服务的名字(存在于注册中心)*/
@FeignClient(value = "DEMO-USER-PROVIDER",fallback = UserFeignClientFallback.class)
public interface UserFeignClient {/*** 当调用checkUser方式时,会调用DEMO-USER-PROVIDER的/provider/checkUser API接口* 调用的路径要求DEMO-USER-PROVIDER中路径保持一致* 如果调用的方法包含参数,需要和DEMO-USER-PROVIDER中的参数保持一致* @return* @throws Exception*/@PostMapping("/provider/checkUser")boolean checkUser(@RequestParam String phone, @RequestParam String password) throws Exception;@PostMapping("/provider/findFeignTimeOut")String findFeignTimeOut() throws Exception;@GetMapping("/provider/hystrixTimeout/{id}")String hystrixTimeout(@PathVariable("id") Integer id) throws Exception;
}

3.测试

方式三:定义fallbackFactory

  1. fallback 的方式的缺陷:不能捕获异常打印堆栈信息,不利于问题排查
  2. fallbackFactory 推荐:可以捕获异常信息并返回默认降级结果。可以打印堆栈信息。

1.创建接口UserFeignClientWithFactory继承UserFeignClient接口

public interface UserFeignClientWithFactory extends UserFeignClient {
}

2.HystrixClientFactory类实现FallbackFactory接口

3.并使用内部匿名方法类,实现UserFeignClient接口中的方法

@Component
@Slf4j
public class HystrixClientFactory implements FallbackFactory<UserFeignClient> {@Overridepublic UserFeignClient create(Throwable cause) {log.info("发生了异常:{},异常消息:{}",cause,cause.getMessage());return new UserFeignClientWithFactory() {@Overridepublic boolean checkUser(String phone, String password) throws Exception {return false;}@Overridepublic List<String> findUserList(Map<String, Object> params) throws Exception {return new ArrayList<>();}@Overridepublic String findFeignTimeOut() throws Exception {return "fallbackFactory方式实现服务降级";}@Overridepublic String hystrixTimeout(Integer id) throws Exception {return "fallbackFactory方式实现服务降级";}};}
}

4.测试:发生异常

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/16841.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【pm2 - sdk 集成到程序中,典型用法】

pm2作为一款进程管理神器&#xff0c;除了命令行的启动方式外&#xff0c;其还对应有sdk&#xff0c;集成到程序中&#xff0c;我们可以连接到已有或创建pm2的守护进程&#xff0c;与其进行交互&#xff0c;动态&#xff0c;编程式地控制程序的启停等。以下为示例&#xff1a; …

c++ - vector容器常用接口模拟实现

文章目录 一、成员变量二、常用迭代器接口模拟实现三、一些常用接口模拟四、默认成员函数五、功能测试 一、成员变量 我们通过在堆上申请一个数组空间来进行储存数据&#xff0c;我们的成员变量是三个指针变量&#xff0c;分别指向第一个位置、最后储存有效位置的下一个位置以…

特殊矩阵的压缩矩阵

目录 前提条件&#xff1a; 类型&#xff1a;对称矩阵&#xff0c;三角矩阵、三对角矩阵、稀疏矩阵 1&#xff1a;对称矩阵&#xff1a; 定义&#xff1a;n阶矩阵A 中任意一元素都有ai,jaj,i(1<i,j<n) 图像&#xff1a; 表达式&#xff1a; 计算过程&#xff1a; …

stream-并行流

定义 常规的流都是串行的流并行流就是并发的处理数据&#xff0c;一般要求被处理的数据互相不影响优点&#xff1a;数据多的时候速度更快&#xff0c;缺点&#xff1a;浪费系统资源&#xff0c;数据少的时候开启线程更耗费时间 模版 Stream<Integer> stream1 Stream.of…

【YOLO 系列】基于YOLO V8的学生上课行为检测系统【python源码+Pyqt5界面+数据集+训练代码】

前言 在现代教育环境中&#xff0c;学生上课行为的监测对于提升教学质量和学生学习效率具有重要意义。然而&#xff0c;传统的人工观察方法不仅效率低下&#xff0c;而且难以保证客观性和准确性。为了解决这一问题&#xff0c;我们启动了这个项目&#xff0c;目的是利用YOLOV8…

AI数学知识

AI数学知识 1、线性代数相关&#xff08;矩阵&#xff09;1、什么是秩2、奇异值分解3、特征值分解和奇异值分解4、低秩分解 回归分类知识点2、概率论相关1、先验概率和后验概率2、条件概率、全概率公式、贝叶斯公式、联合概率3、最大似然估计4、贝叶斯公式和最大似然估计5、伯努…

深入理解Kubernetes的调度核心思想

一、引言 Kubernetes&#xff08;简称K8s&#xff09;是一个开源的容器编排系统&#xff0c;用于自动化部署、扩展和管理容器化应用程序。在Kubernetes集群中&#xff0c;调度器是一个核心组件&#xff0c;它负责将Pod&#xff08;Kubernetes中的最小部署单元&#xff09;分配…

Java学习16

目录 一.StringBuffer类&#xff1a; 1.基本介绍&#xff1a; 2.StringBuffer的构造器&#xff1a; 3.String与StringBuffer的相互转换&#xff1a; &#xff08;1&#xff09;String->StringBuffer &#xff08;2&#xff09;StringBuffer->String 4.StringBuffer…

Redis篇 数据的编码方式和单线程模型

编码方式和单线程模型 一.redis中的数据类型二. Redis中查询编码方式命令三. 单线程模型四. 经典面试题,redis为何这么快?什么是IO多路复用? 一.redis中的数据类型 在redis中,数据类型大致分为5种 1.字符串类型 2.哈希 3.列表 4.集合 5.有序集合 redis底层在实现这些数据结构…

防火墙技术基础篇:NAT转发之——NAPT(同时转换地址和端口)

NAT转发之——NAPT&#xff08;同时转换地址和端口&#xff09; 网络地址端口转换NAPT 网络地址端口转换NAPT&#xff08;Network Address Port Translation&#xff09;是人们比较熟悉的一种转换方式。NAPT普遍应用于接入设备中&#xff0c;它可以将中小型的网络隐藏在一个合…

Vue2和Vue3生命周期的对比

Vue2和Vue3生命周期的对比 Vue2 和 Vue3 生命周期对照表Vue2 和 Vue3 生命周期图示 Vue2 和 Vue3 生命周期对照表 触发时机Vue2.xVue3.x组件创建时运行beforeCreate setup createdsetup 挂载在DOM时运行beforeMountonBeforeMountmountedonMounted响应数据修改时运行beforeUpdat…

x264 码率控制原理:x264_ratecontrol_end 函数

x264_ratecontrol_end 函数 原理 函数功能:编码完一帧数据后,保存状态并更新 ratecontrol 状态。函数参数:x264_t *h:编码器上下文结构体int bits:编码该帧所用的比特数int *filler:用于返回一个填充比特数函数调用关系: 函数内部执行流程:初始化x264_ratecontrol_t结…

关于DDos防御...别在听别人瞎扯了.....

前言 无意间刷文章的时候看到一篇文章&#xff0c;写的是遇到ddos&#xff0c;怎么用iptables封IP....... 然后我就百度搜了一下&#xff0c;好多都是这么说的&#xff0c;但是我发现&#xff0c;大多数人只要遭受过长期Ddos的&#xff0c;就不会再信网上的文章 文笔不太好&…

在64位程序中调用SetWindowLong指定窗口处理过程失效问题排查(附C++编译器数据模型)

C软件异常排查从入门到精通系列教程&#xff08;专栏文章列表&#xff0c;欢迎订阅&#xff0c;持续更新...&#xff09;https://blog.csdn.net/chenlycly/article/details/125529931C/C基础与进阶&#xff08;专栏文章&#xff0c;持续更新中...&#xff09;https://blog.csdn…

手把手实现AVL——二叉平衡搜索树

概述&#xff1a;本文介绍AVL树的实现&#xff0c;从零构建一颗AVL树&#xff0c;以及对应的插入、删除、旋转操作 什么是AVL树&#xff1f; AVL树是带有平衡条件的二叉查找树&#xff0c;二叉查找树又区别于二叉树&#xff1a;保证有序 这个平衡条件是每个节点的左右子树高…

[数据集][目标检测]红外人狗检测数据集VOC+YOLO格式185张2类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;185 标注数量(xml文件个数)&#xff1a;185 标注数量(txt文件个数)&#xff1a;185 标注类别…

Python数据分析常用函数

Python基础 数字处理函数 Python提供了用于数字处理的内置函数和内置模块(math)&#xff0c;使用内置模块&#xff0c;需要先导入 import math。 内置函数math模块abs(-5)返回绝对值math.ceil(2.3)返回不小于x的最小整数divmod(9,4)返回商和余数math.floor(2.3)返回不大于x的…

GLCM 特征和LBP特征提取

GLCM 特征 GLCM&#xff08;灰度共生矩阵&#xff09;特征用于描述图像中像素灰度级之间的空间关系&#xff0c;常用于纹理分析。GLCM特征通过统计图像中各个灰度级对之间的出现频率来描述图像的纹理特征。GLCM特征包括能量&#xff08;ASM&#xff09;、对比度&#xff08;Co…

对于创建相关项目时,项目出现红色感叹号,且无jre环境显示,应该怎么解决?

首先&#xff0c;假设你已经下载好了相关你的jre环境&#xff0c;注意&#xff1a;如果你的jre不想用之前用的默认的话&#xff0c;你应该新建一个新的文件路径来存储你的新的jre环境下的项目文件。 先直接new->project->javaproject 点击next: 显示如下&#xff1a;&…

JavaScript表达式语句二

异常处理语句 异常标识一种非中正常得信息&#xff0c;它提示程序在运行过程中发生了意外或错误&#xff0c;然后JavaScript通过一定的方式把它暴露出来&#xff0c;这叫做抛出异常。抛出异常操作表示系统告诉我们当前程序出现了问题&#xff0c;JavaScript使用异常处理语句来…