黄页网络的推广网站有哪些好,怎样搭建一个个人网站,达州高端网站建设,二手车网站开发PPT前言
SpringCloud 是微服务中的翘楚#xff0c;最佳的落地方案。
使用 SpringCloud 的Hystrix Dashboard 组件可以监控单个应用服务的调用情况#xff0c;但如果是集群环境#xff0c;可能就
不能满足需求了#xff0c;这时就用到了SpringCloud 另一个组件#xff1a;T…前言
SpringCloud 是微服务中的翘楚最佳的落地方案。
使用 SpringCloud 的Hystrix Dashboard 组件可以监控单个应用服务的调用情况但如果是集群环境可能就
不能满足需求了这时就用到了SpringCloud 另一个组件Turbine。
Turbine 将每个应用服务的调用情况聚合在一起展示出来。
如果了解过Hystrix Dashboard那么可以简单认为 Turbine 就相当于另起了一个工程把其他工程的监控情况
全部显示到了 Turbine 工程中。
源码
GitHub地址https://github.com/intomylife/SpringCloud
环境
JDK 1.8.0 Maven 3.0 SpringBoot 2.0.3SpringCloud Finchley.RELEASE
开发工具
IntelliJ IDEA
正文
commons 工程
commons 工程 - POM 文件
?xml version1.0 encodingUTF-8?
project xmlnshttp://maven.apache.org/POM/4.0.0 xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsdmodelVersion4.0.0/modelVersion!-- 三坐标 --groupIdcom.zwc/groupIdartifactIdspringcloud-turbine-commons/artifactIdversion1.0/version!-- 工程名称和描述 --namespringcloud-turbine-commons/namedescription公用工程/description!-- 打包方式 --packagingjar/packaging!-- 在 properties下声明相应的版本信息然后在dependency下引用的时候用 ${} 就可以引入该版本jar包了 --properties!-- 编码 --project.build.sourceEncodingUTF-8/project.build.sourceEncoding!-- jdk --java.version1.8/java.version!-- SpringBoot --platform-bom.versionCairo-SR3/platform-bom.version!-- SpringCloud --spring-cloud-dependencies.versionFinchley.RELEASE/spring-cloud-dependencies.version/properties!-- 加入依赖 --dependencies/dependencies!-- 依赖 jar 包版本管理的管理器 --!-- 如果 dependencies 里的 dependency 自己没有声明 version 元素那么 maven 就此处来找版本声明。 --!-- 如果有就会继承它如果没有就会报错告诉你没有版本信息 --!-- 优先级如果 dependencies 里的 dependency 已经声明了版本信息就不会生效此处的版本信息了 --dependencyManagementdependencies!-- SpringBoot --dependencygroupIdio.spring.platform/groupIdartifactIdplatform-bom/artifactIdversion${platform-bom.version}/versiontypepom/typescopeimport/scope/dependency!-- SpringCloud --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-dependencies/artifactIdversion${spring-cloud-dependencies.version}/versiontypepom/typescopeimport/scope/dependency/dependencies/dependencyManagement!-- 插件依赖 --buildpluginsplugingroupIdorg.springframework.boot/groupIdartifactIdspring-boot-maven-plugin/artifactId/plugin/plugins/build/project配置一些共用依赖
commons 工程 - 项目结构 service 工程
① 此工程下有五个模块一个注册中心一个聚合监控中心以及服务 A、B、C
② A 提供服务并且调用服务 B、B 提供服务并且调用服务 C 以及 C 提供服务
registry-service注册中心
registry-service - POM 文件
?xml version1.0 encodingUTF-8?
project xmlnshttp://maven.apache.org/POM/4.0.0 xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsdmodelVersion4.0.0/modelVersion!-- 继承父 --parentgroupIdcom.zwc/groupIdartifactIdspringcloud-turbine-service/artifactIdversion1.0/version/parent!-- 三坐标 --groupIdcom.zwc/groupIdartifactIdspringcloud-turbine-registry-service/artifactIdversion1.0/version!-- 工程名称描述 --namespringcloud-turbine-registry-service/namedescription注册中心/description!-- 打包方式 --packagingjar/packaging!-- 在 properties下声明相应的版本信息然后在dependency下引用的时候用 ${} 就可以引入该版本jar包了 --properties/properties!-- 加入依赖 --dependencies!-- commons工程 依赖 --dependencygroupIdcom.zwc/groupIdartifactIdspringcloud-turbine-commons/artifactIdversion1.0/version/dependency!-- 服务注册中心 --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-netflix-eureka-server/artifactId/dependency/dependencies!-- 插件依赖 --buildpluginsplugingroupIdorg.springframework.boot/groupIdartifactIdspring-boot-maven-plugin/artifactId/plugin/plugins/build/project主要是加入spring-cloud-starter-netflix-eureka-server依赖
registry-service - application.yml配置文件
# 端口
server:port: 8761# 应用名称
spring:application:name: eureka-servereureka:instance:# 使用 ip 代替实例名prefer-ip-address: true# 实例的主机名hostname: ${spring.cloud.client.ip-address}# 实例的 ID 规则instance-id: ${spring.cloud.client.ip-address}:${spring.application.name}:${server.port}client:# 是否向注册中心注册自己registerWithEureka: false# 是否向注册中心获取注册信息fetchRegistry: falseserviceUrl:# 注册中心地址defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/这里使用了默认的 8761 端口当然也可以更改不过在发现调用服务端的注册中心地址端口要与它一致
registry-service - 启动类
package com.zwc;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;SpringBootApplication
EnableEurekaServer
public class SpringcloudTurbineRegistryServiceApplication {public static void main(String[] args) {SpringApplication.run(SpringcloudTurbineRegistryServiceApplication.class, args);}}在启动类中添加 EnableEurekaServer 注解表示此工程是注册中心
registry-service - 启动项目
1. 项目启动成功后访问http://localhost:8761/即可看到eureka-server 主页面 master-service聚合监控中心
master-service - POM 文件
?xml version1.0 encodingUTF-8?
project xmlnshttp://maven.apache.org/POM/4.0.0 xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsdmodelVersion4.0.0/modelVersion!-- 继承父 --parentgroupIdcom.zwc/groupIdartifactIdspringcloud-turbine-service/artifactIdversion1.0/version/parent!-- 三坐标 --groupIdcom.zwc/groupIdartifactIdspringcloud-turbine-master-service/artifactIdversion1.0/version!-- 工程名称描述 --namespringcloud-turbine-master-service/namedescription集群监控/description!-- 打包方式 --packagingjar/packaging!-- 在 properties下声明相应的版本信息然后在dependency下引用的时候用 ${} 就可以引入该版本jar包了 --properties/properties!-- 加入依赖 --dependencies!-- commons工程 依赖 --dependencygroupIdcom.zwc/groupIdartifactIdspringcloud-turbine-commons/artifactIdversion1.0/version/dependency!-- 提供者消费者 --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-netflix-eureka-client/artifactId/dependency!-- actuator --dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-actuator/artifactId/dependency!-- hystrix --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-netflix-hystrix/artifactId/dependency!-- dashboard --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-netflix-hystrix-dashboard/artifactId/dependency!-- turbine --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-netflix-turbine/artifactId/dependency/dependencies!-- 插件依赖 --buildpluginsplugingroupIdorg.springframework.boot/groupIdartifactIdspring-boot-maven-plugin/artifactId/plugin/plugins/build/project加入spring-cloud-starter-netflix-eureka-client依赖提供和注册服务加入依赖 spring-boot-starter-actuator开启并配置端点加入依赖 spring-cloud-starter-netflix-hystrix熔断器加入依赖 spring-cloud-starter-netflix-hystrix-dashboard熔断监控加入依赖spring-cloud-netflix-turbine监控数据聚合
master-service - application.yml配置文件
# 端口
server:port: 8762# 应用名称
spring:application:name: hystrix-dashboard-turbineeureka:instance:# 使用 ip 代替实例名prefer-ip-address: true# 实例的主机名hostname: ${spring.cloud.client.ip-address}# 实例的 ID 规则instance-id: ${spring.cloud.client.ip-address}:${spring.application.name}:${server.port}client:serviceUrl:# 注册中心地址defaultZone: http://${eureka.instance.hostname}:8761/eureka/turbine:# 监控的应用名称多个以逗号隔开app-config: turbine-a,turbine-baggregator:# 指定聚合哪些集群默认为 defaultclusterConfig: default# 指定集群名称为 defaultclusterNameExpression: new String(default)注意此处配置注册中心地址的端口为 8761 也就是上面注册中心工程配置的端口此工程需要和应用服务指定同一个注册中心地址配置的app-config 中的应用名称都将会被此工程监控
master-service - 启动类
package com.zwc;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.netflix.hystrix.EnableHystrix;
import org.springframework.cloud.netflix.hystrix.dashboard.EnableHystrixDashboard;
import org.springframework.cloud.netflix.turbine.EnableTurbine;SpringBootApplication
EnableEurekaClient
EnableHystrix
EnableHystrixDashboard
EnableTurbine
public class SpringcloudTurbineMasterServiceApplication {public static void main(String[] args) {SpringApplication.run(SpringcloudTurbineMasterServiceApplication.class, args);}}添加 EnableEurekaClient 注解表示此工程可以向注册中心提供服务添加EnableHystrix 注解表示开启熔断器添加 EnableHystrixDashboard 注解表示开启熔断监控添加EnableTurbine 注解表示开启监控数据聚合
master-server - 启动项目
1. 项目启动成功后访问http://localhost:8762/hystrix可以看到 2. 在中间的输入框中输入http://127.0.0.1:8762/turbine.stream?点击Monitor Stream 按钮可以看到 3. 此时还未调用服务所以一直显示 ‘Loading …’
服务工程 A提供者和消费者
服务工程 A- POM 文件
?xml version1.0 encodingUTF-8?
project xmlnshttp://maven.apache.org/POM/4.0.0 xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsdmodelVersion4.0.0/modelVersion!-- 继承父 --parentgroupIdcom.zwc/groupIdartifactIdspringcloud-turbine-a-service/artifactIdversion1.0/version/parent!-- 三坐标 --groupIdcom.zwc/groupIdartifactIdspringcloud-turbine-a-service-core/artifactIdversion1.0/version!-- 工程名称描述 --namespringcloud-turbine-a-service-core/namedescription服务工程 - A 核心/description!-- 打包方式 --packagingjar/packaging!-- 在 properties下声明相应的版本信息然后在dependency下引用的时候用 ${} 就可以引入该版本jar包了 --properties/properties!-- 加入依赖 --dependencies!-- commons工程 依赖 --dependencygroupIdcom.zwc/groupIdartifactIdspringcloud-turbine-commons/artifactIdversion1.0/version/dependency!-- api工程 依赖 --dependencygroupIdcom.zwc/groupIdartifactIdspringcloud-turbine-a-service-api/artifactIdversion1.0/version/dependency!-- 提供者消费者 --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-netflix-eureka-client/artifactId/dependency!-- feign --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-openfeign/artifactId/dependency!-- actuator --dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-actuator/artifactId/dependency!-- hystrix --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-netflix-hystrix/artifactId/dependency!-- dashboard --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-netflix-hystrix-dashboard/artifactId/dependency/dependencies!-- 插件依赖 --buildpluginsplugingroupIdorg.springframework.boot/groupIdartifactIdspring-boot-maven-plugin/artifactId/plugin/plugins/build/project加入spring-cloud-starter-netflix-eureka-client依赖提供和注册服务加入 Feign 的起步依赖spring-cloud-starter-openfeign消费服务加入依赖 spring-boot-starter-actuator开启并配置端点加入依赖 spring-cloud-starter-netflix-hystrix熔断器加入依赖 spring-cloud-starter-netflix-hystrix-dashboard熔断监控
服务工程 A- application.yml配置文件
# 端口
server:port: 8090# 应用名称
spring:application:name: turbine-aeureka:instance:# 使用 ip 代替实例名prefer-ip-address: true# 实例的主机名hostname: ${spring.cloud.client.ip-address}# 实例的 ID 规则instance-id: ${spring.cloud.client.ip-address}:${spring.application.name}:${server.port}client:serviceUrl:# 注册中心地址defaultZone: http://${eureka.instance.hostname}:8761/eureka/management:endpoints:web:exposure:# 开启监控端点include: hystrix.stream注意此处配置注册中心地址的端口为 8761 也就是上面注册中心工程配置的端口spring.application.name应用名称被消费者调用时需要用到它在消费的同时也可以被消费服务工程 B 和服务工程 C 配置与此类似只是端口和应用名称不一样不再赘述在 2.0 后需要主动开启端点 hystrix.stream否则 404
服务工程 A- application.properties注意
# 开启断路器
feign.hystrix.enabledtrue断路器要主动开启服务调用失败时才会熔断此处有一个坑把此配置写到 yml 中熔断不会生效A 和 B 工程都有此配置此次搭建中 C 工程只提供服务没有消费服务。所以 C 工程不用该配置application.properties 和bootstrap.yml 二选一就行
服务工程 A- bootstrap.yml注意
feign:hystrix:# 开启断路器enabled: true断路器要主动开启服务调用失败时才会熔断此处有一个坑把此配置写到 application.yml中熔断不会生效application.properties 和bootstrap.yml 二选一就行
服务工程 A- controller 前端控制器提供服务
package com.zwc.a.controller;import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;/** ClassName ASayHelloController* Desc TODO Say Hello* Date 2019/5/20 23:24* Version 1.0*/
RestController
public class ASayHelloController {/** ClassName ASayHelloController* Desc TODO 读取配置文件中的端口* Date 2019/5/20 23:24* Version 1.0*/Value(${server.port})private String port;/** ClassName ASayHelloController* Desc TODO Say Hello* Date 2019/5/20 23:24* Version 1.0*/RequestMapping(/a)public String a(){return HelloIm a. port port;}}提供一个服务输出 Hello 和端口
服务工程 A- 服务调用
package com.zwc.a.api.feign;import com.zwc.a.api.impl.FeignApiFallBack;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.RequestMapping;/** ClassName FeignApi* Desc TODO 使用 Feign 调用 b - 接口* Date 2019/5/20 23:21* Version 1.0*/
FeignClient(value turbine-b , fallback FeignApiFallBack.class)
public interface FeignApi {/** ClassName FeignApi* Desc TODO 通过 turbine-b 服务名调用 b() 方法* Date 2019/5/20 23:21* Version 1.0*/RequestMapping(/b)String b();}通过 FeignClient 注解中 value “turbine-b” 来指定调用哪个服务turbine-b 就是提供者的spring.application.name应用名称通过 FeignClient 注解中 fallback FeignApiFallBack.class 来指定熔断时调用的方法FeignApiFallBack 就是此接口FeignApi的实现类对应的实现方法就是熔断时调用的方法b()此方法是 B 工程中提供的服务在这里定义成接口注意要与提供者具有相同返回值相同方法名以及相同参数
服务工程 A- FallbackFeignApiFallBack
package com.zwc.a.api.impl;import com.zwc.a.api.feign.FeignApi;
import org.springframework.stereotype.Component;/** ClassName FeignApi* Desc TODO fallback* Date 2019/5/20 23:21* Version 1.0*/
Component
public class FeignApiFallBack implements FeignApi {/** ClassName FeignApiFallBack* Desc TODO 调用 turbine-b 服务中的 b() 方法失败时执行* Date 2019/5/20 23:31* Version 1.0*/Overridepublic String b() {return HelloaUseB fail;}
}使用Component 注解把此类交给 Spring 管理实现了FeignApi 接口提供熔断时对应的方法
服务工程 A- controller 前端控制器消费服务
package com.zwc.a.controller;import com.zwc.a.api.feign.FeignApi;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;/** ClassName AUseBFeignController* Desc TODO 使用 Feign 调用 b - 前端控制器* Date 2019/5/20 23:23* Version 1.0*/
RestController
public class AUseBFeignController {Autowired(required false)private FeignApi feignApi;/** ClassName FeignController* Desc TODO 通过 turbine-b 服务名调用 b() 方法* Date 2019/5/20 23:13* Version 1.0*/RequestMapping(/aUseB)public String aUseB(){return feignApi.b();}}使用 Autowired 注解装配 Bean通过此 Bean 中的方法调用服务此类对外暴露接口调用的实则是提供者的服务
服务工程 A- 启动类
package com.zwc;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.netflix.hystrix.EnableHystrix;
import org.springframework.cloud.netflix.hystrix.dashboard.EnableHystrixDashboard;
import org.springframework.cloud.openfeign.EnableFeignClients;SpringBootApplication
EnableEurekaClient
EnableFeignClients
EnableHystrix
EnableHystrixDashboard
public class SpringcloudTurbineAServiceCoreApplication {public static void main(String[] args) {SpringApplication.run(SpringcloudTurbineAServiceCoreApplication.class, args);}}添加 EnableEurekaClient 注解表示此工程可以向注册中心提供服务添加EnableFeignClients 注解表示开启 Feign 功能进行远程调用添加EnableHystrix 注解表示开启熔断器添加 EnableHystrixDashboard 注解表示开启熔断监控
服务工程 A- 启动项目
1.项目启动成功后访问http://localhost:8090/a调用自己的服务
2. 输出内容‘HelloI’m a. port8090’
3. 访问地址http://localhost:8090/aUseB调用 B 工程的服务
4. 输出内容‘HelloaUseB fail’ 此时因为 B 工程还未启动所以调用了 fallback中的方法
5. 这时再回到master-server 工程的 ‘Loading …’ 页面发现刚刚服务调用失败已经被监控到了 6. 如果还是显示的 ‘Loading …’ 请再稍等一会
7. 启动服务工程 B项目启动成功后再次访问http://localhost:8090/aUseB调用 B 工程的服务
8.输出内容‘HelloI’m b. port8091’ 如果还未调用成功等待一会再刷新试试
9. 这时再回到 master-server 工程可以看到 10. 另起页面访问http://localhost:8091/bUseC调用 C 工程的服务
11.输出内容‘HellobUseC fail’ 此时因为 C 工程还未启动所以调用了 fallback中的方法
12. 这时再回到 master-server 工程可以看到调用 C 工程也被监控到了 13.红色的百分比表示失败率
14.左边的六个数字对应着页面右上角的六个状态Success、Short-Circuited…
service 工程 -项目结构 把多工程项目使用 IntelliJ IDEA 打开
把项目从 GitHub 中下载到你的本地打开IntelliJ IDEA点击 File - Open打开你下载到本地的项目目录springcloud-turbine -springcloud-turbine-service选择打开此工程打开 service 工程后再次点击 File - Project Structrue选择 Modules点击 ‘’ 符号点击 ImportModule还是打开你下载到本地的项目目录springcloud-turbine -springcloud-turbine-commons - pom.xml点击 OK点击 NextFinish点击 ApplyOK 希望能够帮助到你
over