Hystrix 集群 及 集群监控 Turbine

本章知识:

1、Hystrix集群及监控turbine
2、Feign、Hystrix整合之 服务熔断服务降级彻底解耦
3、集群后超时设置

Hystrix 集群及监控 turbine

前面Dashboard演示的仅仅是单机服务监控,实际项目基本都是集群,所以这里集群监控用的是turbine。

turbine是基于Dashboard的。

先搞个集群;

在microservice-student-provider-hystrix-1004项目的基础上再创建一个microservice-student-provider-hystrix
在这里插入图片描述
代码和配置都复制一份,然后修改几个地方;
在这里插入图片描述

  1. 配置文件

    pom.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
        <parent>
            <groupId>com.dj</groupId>
            <artifactId>springcloud01</artifactId>
            <version>1.0-SNAPSHOT</version>
        </parent>
        <artifactId>microservice-student-provider-hystrix</artifactId>
    
        <properties>
            <java.version>1.8</java.version>
        </properties>
        <dependencies>
            <dependency>
                <groupId>com.dj</groupId>
                <artifactId>microservice-common</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-test</artifactId>
                <scope>test</scope>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-data-jpa</artifactId>
            </dependency>
            <dependency>
                <groupId>mysql</groupId>
                <artifactId>mysql-connector-java</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-tomcat</artifactId>
            </dependency>
            <dependency>
                <groupId>com.alibaba</groupId>
                <artifactId>druid-spring-boot-starter</artifactId>
            </dependency>
            <!--  修改后立即生效,热部署  -->
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>springloaded</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-devtools</artifactId>
            </dependency>
            <!-- actuator监控引入 -->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-actuator</artifactId>
            </dependency>
            <!--添加注册中心Eureka相关配置-->
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-eureka</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-config</artifactId>
            </dependency>
    
    
            <!--Hystrix相关依赖-->
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-hystrix</artifactId>
            </dependency>
            <dependency>
                <groupId>com.dj</groupId>
                <artifactId>microservice-common</artifactId>
                <version>1.0-SNAPSHOT</version>
                <scope>compile</scope>
            </dependency>
        </dependencies>
    
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
            </plugins>
        </build>
    
    </project>
    
    

    yml配置

    ---
    server:
      port: 1004
      context-path: /
    spring:
      datasource:
        type: com.alibaba.druid.pool.DruidDataSource
        driver-class-name: com.mysql.jdbc.Driver
        url: jdbc:mysql://localhost:3306/springcloud?useUnicode=true&characterEncoding=utf8
        username: root
        password: 123
      jpa:
        hibernate:
          ddl-auto: update
        show-sql: true
      application:
        name: microservice-student
      profiles: provider-hystrix-1004
    
    eureka:
      instance:
        hostname: localhost
        appname: microservice-student
        instance-id: microservice-student:1004
        prefer-ip-address: true
      client:
        service-url:
          defaultZone: http://eureka2001.dj.com:2001/eureka/,http://eureka2002.dj.com:2002/eureka/,http://eureka2003.dj.com:2003/eureka/
    
    info:
      groupId: com.dj.testSpringcloud
      artifactId: microservice-student-provider-hystrix-1004
      version: 1.0-SNAPSHOT
      userName: http://dj.com
      phone: 123
    
    hystrix:
      command:
        default:
          execution:
            isolation:
              thread:
                timeoutInMilliseconds: 1500
    
    ---
    server:
      port: 1005
      context-path: /
    spring:
      datasource:
        type: com.alibaba.druid.pool.DruidDataSource
        driver-class-name: com.mysql.jdbc.Driver
        url: jdbc:mysql://localhost:3306/springcloud?useUnicode=true&characterEncoding=utf8
        username: root
        password: 123
      jpa:
        hibernate:
          ddl-auto: update
        show-sql: true
      application:
        name: microservice-student
      profiles: provider-hystrix-1005
    
    eureka:
      instance:
        hostname: localhost
        appname: microservice-student
        instance-id: microservice-student:1005
        prefer-ip-address: true
      client:
        service-url:
          defaultZone: http://eureka2001.dj.com:2001/eureka/,http://eureka2002.dj.com:2002/eureka/,http://eureka2003.dj.com:2003/eureka/
    
    info:
      groupId: com.dj.testSpringcloud
      artifactId: microservice-student-provider-hystrix-1005
      version: 1.0-SNAPSHOT
      userName: http://dj.com
      phone: 123
    
    hystrix:
      command:
        default:
          execution:
            isolation:
              thread:
                timeoutInMilliseconds: 1500
    
    ---
    server:
      port: 1006
      context-path: /
    spring:
      datasource:
        type: com.alibaba.druid.pool.DruidDataSource
        driver-class-name: com.mysql.jdbc.Driver
        url: jdbc:mysql://localhost:3306/springcloud?useUnicode=true&characterEncoding=utf8
        username: root
        password: 123
      jpa:
        hibernate:
          ddl-auto: update
        show-sql: true
      application:
        name: microservice-student
      profiles: provider-hystrix-1006
    
    eureka:
      instance:
        hostname: localhost
        appname: microservice-student
        instance-id: microservice-student:1006
        prefer-ip-address: true
      client:
        service-url:
          defaultZone: http://eureka2001.dj.com:2001/eureka/,http://eureka2002.dj.com:2002/eureka/,http://eureka2003.dj.com:2003/eureka/
    
    info:
      groupId: com.dj.testSpringcloud
      artifactId: microservice-student-provider-hystrix-1006
      version: 1.0-SNAPSHOT
      userName: http://dj.com
      phone: 123
    
    hystrix:
      command:
        default:
          execution:
            isolation:
              thread:
                timeoutInMilliseconds: 1500
    
    

  1. 启动类配置

    MicroserviceStudentProviderHystrixApplication.java

    package com.dj.microservicestudentproviderhystrix;
    
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    import org.springframework.boot.autoconfigure.domain.EntityScan;
    import org.springframework.cloud.client.circuitbreaker.EnableCircuitBreaker;
    import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
    
    @EnableCircuitBreaker
    @EntityScan("com.dj.*.*")
    @EnableEurekaClient
    @SpringBootApplication
    public class MicroserviceStudentProviderHystrixApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(MicroserviceStudentProviderHystrixApplication.class, args);
        }
    
    }
    
    

    这样的话 ,就有了 Hystrix 集群服务;
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  2. 新建项目 microservice-student-consumer-hystrix-turbine-91
    在这里插入图片描述

    pom.xml加下依赖

    	<dependency>
    	    <groupId>org.springframework.boot</groupId>
    	    <artifactId>spring-boot-starter-actuator</artifactId>
    	</dependency>
    	<dependency>
    	    <groupId>org.springframework.cloud</groupId>
    	    <artifactId>spring-cloud-starter-turbine</artifactId>
    	</dependency>
    

  1. application.yml

    	server:
    	  port: 91
    	  context-path: /
    	eureka:
    	  client:
    	    service-url:
    	      defaultZone: http://eureka2001.dj.com:2001/eureka/,http://eureka2002.dj.com:2002/eureka/,http://eureka2003.dj.com:2003/eureka/
    	turbine:
    	  app-config: microservice-student   # 指定要监控的应用名称
    	  clusterNameExpression: "'default'" #表示集群的名字为default
    	spring:
    	  application:
    	    name: turbine
    

    启动类MicroserviceStudentConsumerHystrixTurbine91Application 加注解:@EnableTurbine

    package com.dj.microservicestudentconsumerhystrixturbine91;
    
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
    import org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration;
    import org.springframework.cloud.netflix.turbine.EnableTurbine;
    
    @EnableTurbine
    @SpringBootApplication(exclude={DataSourceAutoConfiguration.class, HibernateJpaAutoConfiguration.class})
    public class MicroserviceStudentConsumerHystrixTurbine91Application {
    
        public static void main(String[] args) {
            SpringApplication.run(MicroserviceStudentConsumerHystrixTurbine91Application.class, args);
        }
    
    }
    
    

测试:

先启动三个eureka,然后把1004 1005 带hystrix的服务都启动;
microservice-student-consumer-80这个也启动,方便测试;
dashboard,turbine启动;
在这里插入图片描述
一共要启动八个项目!!!

这样的话 http://localhost/student/hystrix 就能调用服务集群;
在这里插入图片描述
在这里插入图片描述

http://localhost:91/turbine.stream 可以监控数据,实时ping 返回data
在这里插入图片描述

输入http://localhost:90/hystrix 进入仪表盘,输入地址
在这里插入图片描述
在这里插入图片描述
点击 进入集群监控仪表:
在这里插入图片描述


Feign、Hystrix整合

前面的代码,用 @HystrixCommand fallbackMethod 是很不好的,因为 业务代码耦合度太高 ,不利于维护,所以需要 解耦 ,这我们讲下 Feign Hystrix整合

  1. microservice-student-provider-hystrix 项目修改

    我们不用原先那套。按照正常的逻辑来写;

    StudentService 加新的接口方法:

       		/**
       		 * 测试Hystrix服务降级
       		 * @return
       		 */
       		public Map<String,Object> hystrix();
    

    StudentServiceImpl 写具体实现:

       		@Override
       		public Map<String, Object> hystrix() {
       		    Map<String,Object> map=new HashMap<String,Object>();
       		    map.put("code", 200);
       		    map.put("info","工号【"+port+"】正在为您服务");
       		    return map;
       		}
    

    StudentProviderController 正常调用service方法:

       		/**
       		     * 测试Hystrix服务降级
       		     * @return
       		     * @throws InterruptedException
       		     */
       		    @ResponseBody
       		    @GetMapping(value="/hystrix")
       		    @HystrixCommand(fallbackMethod="hystrixFallback")
       		    public Map<String,Object> hystrix() throws InterruptedException{
       		        Thread.sleep(2000);
       		//        Map<String,Object> map=new HashMap<String,Object>();
       		//        map.put("code", 200);
       		//        map.put("info","工号【"+port+"】正在为您服务");
       		        return studentService.hystrix();
       		    }
    

  1. microservice-common 项目新建 FallbackFactory 类,解耦服务熔断服务降级

    StudentClientService接口,新增getInfo方法;

       		/**
       		 * 服务熔断降级
       		 * @return
       		 */
       		@GetMapping(value="/student/hystrix")
       		public Map<String,Object> hystrix();
    

    新建 StudentClientFallbackFactory 类,实现 FallbackFactory< StudentClientService> 接口

    package com.dj.microservicecommon.service;
    
    import com.dj.microservicecommon.entity.Student;
    import feign.hystrix.FallbackFactory;
    
    import java.util.HashMap;
    import java.util.List;
    import java.util.Map;
    
    
    /**
     * @author dj
     * @company xxx公司
     * @create 2019- 11 - 23 - 16:48
     *
     * 作用:将所有service层业务方法可能出现的故障,需要定义对应的快速返回方法的处理集合
     * service层
     * add/del/query.....
     * StudentClientFallbackFactory
     * add/del/query.....对应的快速回退措施
     *
     */
    public class StudentClientFallbackFactory implements FallbackFactory<StudentClientService> {
    
        @Override
        public StudentClientService create(Throwable throwable) {
            return new StudentClientService() {
    
                @Override
                public boolean save(Student student) {
                    return false;
                }
    
                @Override
                public List<Student> list() {
                    return null;
                }
    
                @Override
                public Map<String, Object> hystrix() {
                    Map<String,Object> map=new HashMap<String,Object>();
                    map.put("code", 500);
                    map.put("info", "系统繁忙,稍后重试");
                    return map;
                }
    
                @Override
                public Student get(Integer id) {
                    return null;
                }
    
                @Override
                public boolean delete(Integer id) {
                    return false;
                }
    
                @Override
                public String ribbon() {
                    return null;
                }
            };
        }
    }
    
    

    StudentClientService 接口的**@FeignClient**注解加下 fallbackFactory属性

       		@FeignClient(value="MICROSERVICE-STUDENT",fallbackFactory=StudentClientFallbackFactory.class)
    

    在这里插入图片描述
    这类我们实现了 降级处理方法实现;


  1. microservice-student-consumer-feign-80修改 支持Hystrix

    StudentConsumerFeignController新增方法调用

       		/**
       		 * Feign整合Hystrix服务熔断降级
       		 * @return
       		 * @throws InterruptedException
       		 */
       		@GetMapping(value="/hystrix")
       		public Map<String,Object> hystrix() throws InterruptedException{
       		    return studentClientService.hystrix();
       		}
    

  1. microservice-commonapplication.yml 加上Hystrix支持

    feign:
      hystrix:
        enabled: true
    

测试:

开启三个eureka,以及带hystrix的provider,和带feign,hystrix的consummer。
在这里插入图片描述
在这里插入图片描述

测试的话,也是没问题的。

0.9秒的话,返回正常信息;超过1秒的话,就返回错误提示;
在这里插入图片描述


集群后超时设置

上面错误是什么原因呢?咱们明明在Hystrix中的application.yml中设置了

hystrix:
  command:
    default:
      execution:
        isolation:
          thread:
            timeoutInMilliseconds: 1500

这里因为还有一个 feign 也有一个超时时间的设置,当然feign底层是 ribbon的封装,所以 直接配置ribbon,ribbon默认超时也是1秒。

所以这里都是强制要求,Ribbon的超时时间要大于hystrix的超时时间,否则 hystrix自定义的超时时间毫无意义。
所以还得microservice-student-consumer-feign-80上加个 ribbon超时时间设置

	ribbon:
	  ReadTimeout: 10000
	  ConnectTimeout: 9000
	feign:
	  hystrix:
	    enabled: true

在这里插入图片描述
除此之外还得在 microservice-student-consumer-feign-80 上加个注解:

		@ComponentScan(basePackages = {"com.dj.microservicecommon","com.dj.microservicestudentconsumerfeign80"})

在这里插入图片描述

这样就OK了。可以自行测试, o( ̄▽ ̄)ブ 。

在这里插入图片描述

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
资源包主要包含以下内容: ASP项目源码:每个资源包中都包含完整的ASP项目源码,这些源码采用了经典的ASP技术开发,结构清晰、注释详细,帮助用户轻松理解整个项目的逻辑和实现方式。通过这些源码,用户可以学习到ASP的基本语法、服务器端脚本编写方法、数据库操作、用户权限管理等关键技术。 数据库设计文件:为了方便用户更好地理解系统的后台逻辑,每个项目中都附带了完整的数据库设计文件。这些文件通常包括数据库结构图、数据表设计文档,以及示例数据SQL脚本。用户可以通过这些文件快速搭建项目所需的数据库环境,并了解各个数据表之间的关系和作用。 详细的开发文档:每个资源包都附有详细的开发文档,文档内容包括项目背景介绍、功能模块说明、系统流程图、用户界面设计以及关键代码解析等。这些文档为用户提供了深入的学习材料,使得即便是从零开始的开发者也能逐步掌握项目开发的全过程。 项目演示与使用指南:为帮助用户更好地理解和使用这些ASP项目,每个资源包中都包含项目的演示文件和使用指南。演示文件通常以视频或图文形式展示项目的主要功能和操作流程,使用指南则详细说明了如何配置开发环境、部署项目以及常见问题的解决方法。 毕业设计参考:对于正在准备毕业设计的学生来说,这些资源包是绝佳的参考材料。每个项目不仅功能完善、结构清晰,还符合常见的毕业设计要求和标准。通过这些项目,学生可以学习到如何从零开始构建一个完整的Web系统,并积累丰富的项目经验。
资源包主要包含以下内容: ASP项目源码:每个资源包中都包含完整的ASP项目源码,这些源码采用了经典的ASP技术开发,结构清晰、注释详细,帮助用户轻松理解整个项目的逻辑和实现方式。通过这些源码,用户可以学习到ASP的基本语法、服务器端脚本编写方法、数据库操作、用户权限管理等关键技术。 数据库设计文件:为了方便用户更好地理解系统的后台逻辑,每个项目中都附带了完整的数据库设计文件。这些文件通常包括数据库结构图、数据表设计文档,以及示例数据SQL脚本。用户可以通过这些文件快速搭建项目所需的数据库环境,并了解各个数据表之间的关系和作用。 详细的开发文档:每个资源包都附有详细的开发文档,文档内容包括项目背景介绍、功能模块说明、系统流程图、用户界面设计以及关键代码解析等。这些文档为用户提供了深入的学习材料,使得即便是从零开始的开发者也能逐步掌握项目开发的全过程。 项目演示与使用指南:为帮助用户更好地理解和使用这些ASP项目,每个资源包中都包含项目的演示文件和使用指南。演示文件通常以视频或图文形式展示项目的主要功能和操作流程,使用指南则详细说明了如何配置开发环境、部署项目以及常见问题的解决方法。 毕业设计参考:对于正在准备毕业设计的学生来说,这些资源包是绝佳的参考材料。每个项目不仅功能完善、结构清晰,还符合常见的毕业设计要求和标准。通过这些项目,学生可以学习到如何从零开始构建一个完整的Web系统,并积累丰富的项目经验。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值