熔断器(Hystrix)、统一配置中心、网关

使用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

  1. 引入依赖

    spring-cloud-config-server,spring-cloud-starter-eureka
    
  2. 入口类添加注解

    @EnableConfigServer
    @SpringBootApplication
    @SpringCloudApplication
    
  3. 在resources添加配置

在这里插入图片描述

  1. 远程仓库的访问方式:

在这里插入图片描述
order:表示远程仓库配置文件的名称(order.yml)
order-dev:表示访问的是dev环境(order-dev.yml),如果没有指定访问名称,默认访问的是order的原始配置。
主配置中(order)可以写公共配置,被任何环境所使用
在这里插入图片描述
如果有分支,需要访问分支的配置文件,前面应该加上分支的名称(release)

统一配置中心的客户端使用:

  1. 引入依赖

    spring-cloud-config-client
    
  2. 修改客户端的resources的名称为bootstrap.yml

    如果使用远程的config配置中心,需要指定资源名为 bootstrap.yml
    

在这里插入图片描述

  1. 将客户端的配置文件内容改为以下内容(label: 分支名称 默认是master分支)

在这里插入图片描述

Zuul 网关

  1. 引入依赖

    spring-cloud-starter-zuul,spring-cloud-starter-eureka
    
  2. 入口类添加注解

    @SpringBootApplication
    @EnableDiscoveryClient
    @EnableZuulProxy
    
  3. 修改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可以查看服务访问的路径

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值