使用RestTemplete+Ribbon的熔断器实现
1. 引入pom依赖(断路器的依赖)
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-hystrix</artifactId>
</dependency>
2. 在入口类上添加断路器注解
@SpringBootApplication
@EnableDiscoveryClient
@EnableHystrix //断路器注解
public class TempleteApplication {
public static void main(String[] args) {
SpringApplication.run(TempleteApplication.class,args);
}
@Bean
@LoadBalanced
RestTemplate getRestTemplete(){
return new RestTemplate();
}
}
3. 改造服务调用类(controller中的方法)
在hello方法上加上@HystrixCommand注解。该注解对该方法创建了熔断器的功能,并指定
了fallbackMethod熔断方法,熔断方法直接返回了一个字符串,字符串为”hi,”+name+”,sorry,error!”
如果需要些默认的断路器,在controller类上添加@DefaultProperties(defaultFallBack="defaultError")这个注解
Feign中使用熔断器
1. 入口类注解不变
@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
2. 自带的断路器,不需要引入关于断路器的pom文件
3. 在interface接口上添加interface的实现类
interface接口:
序号1表示服务在注册中心的服务名
序号2使用断路器时添加的注解,指向断路器返回信息
序号3表示要调用的接口的路径,如果配置文件中有项目名(content-path),需要加上项目名
序号4使用feign方式调用客户端服务,传入的参数需要用@RquestMapping接收
接口:
实现类:
4. 在配置文件(application.yml)中添加一下代码
feign.hystrix.enabled=true
server:
port: 8079
spring:
application:
name: feign-client
eureka:
client:
service-url:
defaultZone: http://localhost:8761/eureka
feign: #使用feign熔断器
hystrix:
enabled: true
统一配置中心:config
- 引入依赖
spring-cloud-config-server,spring-cloud-starter-eureka
- 入口类添加注解
@EnableConfigServer
@SpringBootApplication
@SpringCloudApplication
- 在resources添加配置
- 远程仓库的访问方式:
order:表示远程仓库配置文件的名称(order.yml)
order-dev:表示访问的是dev环境(order-dev.yml),如果没有指定访问名称,默认访问的是order的原始配置。
主配置中(order)可以写公共配置,被任何环境所使用
如果有分支,需要访问分支的配置文件,前面应该加上分支的名称(release)
统一配置中心的客户端使用:
- 引入依赖
spring-cloud-config-client
- 修改客户端的resources的名称为bootstrap.yml
如果使用远程的config配置中心,需要指定资源名为 bootstrap.yml
- 将客户端的配置文件内容改为以下内容(label: 分支名称 默认是master分支)
Zuul 网关
- 引入依赖
spring-cloud-starter-zuul,spring-cloud-starter-eureka
- 入口类添加注解
@SpringBootApplication
@EnableDiscoveryClient
@EnableZuulProxy
- 修改resources配置文件:
server:
port: 8760
eureka:
client:
service-url:
defaultZone: http://localhost:8761/eureka
spring:
application:
name: zuul
hystrix:
command:
default:
execution:
isolation:
thread:
timeoutInMilliseconds: 5000 #设置断路器时间
management:
security:
enabled: false #开启默认查看配置
zuul:
routes:
product:
path: /aa/**
serviceId: PRODUCT #指定一级访问路径
aaaa:
path: /bb/**
serviceId: ORDER
management:
security:
enabled: false #开启默认查看配置 ,访问routes可以查看服务访问的路径