目录
2.运行登录nacos网站查看运行效果(默认密码nacos,nacos)
[3.开启第二个项目 hystrix2工程](#3.开启第二个项目 hystrix2工程)
[4.关闭第二个项目 hystrix2工程 (模拟熔断)](#4.关闭第二个项目 hystrix2工程 (模拟熔断))
5.修改第一个项目hystrix1的application.yml文件
3.启动类添加注解@EnableHystrixDashboard
[编辑 五.我的项目结构](#编辑 五.我的项目结构)
一.启动nacos和redis
1.查看是否有nacos和redis
docker ps -a
data:image/s3,"s3://crabby-images/d03c4/d03c4731facebf304e9b866f5b876f04347cc455" alt=""
2.启动nacos和redis
docker start nacos
docker start redis-6379
docker ps
data:image/s3,"s3://crabby-images/eba08/eba080b6957e67e7e0a31341e353ce2f1e250b2b" alt=""
二.开始项目
这里用的项目过程在我的另一个博客中OpenFeign微服务部署-CSDN博客
我是粘贴复制后重写的名字,hystrix1对应SpringSessiondemo,hystrix2对应SpringSessiondemo1,
hystrix2工程(没有代码改变)先启动之后断开(模拟宕机),
1.hystrix1工程(修改一下工程的注册名字)
data:image/s3,"s3://crabby-images/c503b/c503b4a7cd4f078d573b54fba0de7d1540df33fa" alt=""
2.运行登录nacos网站查看运行效果(默认密码nacos,nacos)
data:image/s3,"s3://crabby-images/44de5/44de5da14e88a17b4897d553bb31a24811774843" alt=""
3.开启第二个项目 hystrix2工程
用postman测试
data:image/s3,"s3://crabby-images/0d427/0d427ea01d369622f21aaa06afbd1a6b9a65cb21" alt=""
4.关闭第二个项目 hystrix2工程 (模拟熔断)
data:image/s3,"s3://crabby-images/d8cd8/d8cd8616f3cc3030c850dd60da6d890f9d37990c" alt=""
三.应用hystrix
1.在第一个工程里hystrix1添加依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>
2.开启Hystrix
在第一个工程里hystrix1的启动类上添加开启Hystrix的注解
@EnableHystrix
data:image/s3,"s3://crabby-images/e34b8/e34b8e260ae16fb2387be2f9480658ff8b55a6e8" alt=""
此时完成上述两个操作后,再次关闭第二个工程里hystrix2,页面也是报错,但不是"连接超时"的错误,而是"熔断类型"的错误。为了让用户体验度好一些,报错信息不暴露给用户,我们完成下面的编码。
data:image/s3,"s3://crabby-images/c8617/c861707c33911d729abfbec845f1de2b232b172f" alt=""
3.修改第一个项目hystrix1的工具类Result
java
package com.jr.util;
import lombok.Data;
import java.util.HashMap;
import java.util.Map;
@Data
public class Result {
private Integer code;
private String message;
private Map<String, Object> map = new HashMap<>();
private Result() {
}
public static Result ok() {
Result r = new Result();
r.setCode(ResultCode.SUCCESS.getCode());
r.setMessage(ResultCode.SUCCESS.getMessage());
return r;
}
public static Result error() {
Result r = new Result();
r.setCode(ResultCode.ERROR.getCode());
r.setMessage(ResultCode.ERROR.getMessage());
return r;
}
public Result setMessage(String message) {
this.message = message;
return this;
}
public Result put(String key, Object value) {
map.put(key, value);
return this;
}
public Object get(String key) {
return map.get(key);
}
}
data:image/s3,"s3://crabby-images/b5887/b58876853399f08d60c8f7b8e21d1a6c71ae8be0" alt=""
4.修改第一个项目hystrix1的控制类
java
package com.jr.controller;
import com.jr.entry.UserDto;
import com.jr.service.IUserService;
import com.jr.util.Result;
import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;
import org.apache.catalina.servlet4preview.http.HttpServletRequest;
import org.apache.tomcat.jni.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
@RestController
@RequestMapping("/user")
public class UserController {
@Autowired
private IUserService userService;
@GetMapping
@HystrixCommand(fallbackMethod = "infoHystrix") //一旦熔断了,就去执行infoHystrix方法。
public Result info() {
UserDto user = userService.info();
return Result.ok().put("data", user);
}
public Result infoHystrix() {
return Result.error().setMessage("被熔断了");
}
@GetMapping("/{id}")
public Result id(@PathVariable String id) { //url传值
UserDto userDto = userService.id(id);
return Result.ok().put("data", userDto);
}
@PostMapping("/add")
public Result add(@RequestBody UserDto user) { //对象传值
UserDto userDto = userService.add(user);
return Result.ok().put("data", userDto);
}
}
data:image/s3,"s3://crabby-images/1c01f/1c01f231beaede80e37f834197c33fd2e3bd8d78" alt=""
5.修改第一个项目hystrix1的application.yml文件
向其中添加以下代码
java
feign:
hystrix:
enabled: true
data:image/s3,"s3://crabby-images/d0d7e/d0d7e868c049805030b240f05a5de0361c2dfa35" alt=""
6.先同时启动两个项目,在postman进行测试
3.6.1连接成功的情况
data:image/s3,"s3://crabby-images/5d01d/5d01d3864eff9a65f74cc8acc028770925ff31a2" alt=""
3.6.2连接失败的情况(提示)
data:image/s3,"s3://crabby-images/bc127/bc1275aa3f11a92482a9a2503877232f80a31a6d" alt=""
四.添加仪表盘(很少用到,了解)
1.在第一个工程里hystrix1添加依赖
XML
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-hystrix-dashboard</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
2.添加配置类(固定写法)
java
package com.jr.config;
import com.netflix.hystrix.contrib.metrics.eventstream.HystrixMetricsStreamServlet;
import org.springframework.boot.web.servlet.ServletRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import javax.servlet.http.HttpServlet;
@Configuration
public class HystrixConfig {
@Bean
public ServletRegistrationBean<HttpServlet> httpServletServletRegistrationBean() {
ServletRegistrationBean<HttpServlet> result = new ServletRegistrationBean<>(new HystrixMetricsStreamServlet());
result.addUrlMappings("/actuator/hystrix.stream");
return result;
}
}
3.启动类添加注解@EnableHystrixDashboard
data:image/s3,"s3://crabby-images/0ce21/0ce21bf3b43d4abe114c1b0d6b7ab48af0197588" alt=""
4启动项目,访问如下地址
地址栏访问的地址:http://localhost:100/hystrix
地址2:http://localhost:100/actuator/hystrix.stream
点击下面的Monitor Stream
data:image/s3,"s3://crabby-images/d2549/d2549594bca4a000fa818b624b2207b4da2b2250" alt=""
一开始建立的时候全是0,我们需要去访问我们的项目
data:image/s3,"s3://crabby-images/da40a/da40ad04d4d997362d0ba6c9b642cd73f19e6571" alt=""
五.我的项目结构
1.第一个工程hystrix1
data:image/s3,"s3://crabby-images/659e4/659e49a76dd66c56f6781ffca98be5ef9606ac2a" alt=""
2.第一个工程hystrix2
data:image/s3,"s3://crabby-images/99aea/99aeadde106bff5ed289b6b691562b5ed658d6a0" alt=""