使用 FileBasedInstanceDiscovery 的 hystrix-dashboard 涡轮机问题
Problems with hystrix-dashboard turbine using FileBasedInstanceDiscovery
我正在尝试设置带有涡轮机的 hystrix 仪表板。我没有使用 Eureka,而是想使用 FileBasedInstanceDiscovery。我正在尝试配置它,但遵循在线文档似乎不起作用。它始终尝试使用 Eureka 发现客户端。我尝试从我的 pom 中排除尤里卡,但随后它退回到另一个发现客户端 CommonsInstanceDiscovery
这是我的 application.properties:
turbine.aggregator.clusterConf=mycluster
turbine.instanceUrlSuffix.mycluster=8080/hystrix.stream
turbine.FileBasedInstanceDiscovery.filePath=turbine.hostnames.txt
turbine.InstanceMonitor.eventStream.skipLineLogic.enabled=false
InstanceDiscovery.impl=com.netflix.turbine.discovery.FileBasedInstanceDiscovery
还有其他方法吗?此外,对于我的涡轮机主机名的文件路径,它从哪里开始寻找?我可以将该文件放在我的 jar 资源目录下吗?
这是我的 pom 文件依赖项:
<properties>
<java.version>1.8</java.version>
<spring-cloud.version>Greenwich.SR1</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web-services</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-hystrix-dashboard</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-turbine</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
涡轮机的一些文档不清楚和冲突,我认为这是因为有 spring-cloud-netflix 项目和一个独立的涡轮机项目。无论如何,如果您正在构建一个 spring-boot 应用程序,那么这个 属性 是没有用的:
InstanceDiscovery.impl=com.netflix.turbine.discovery.FileBasedInstanceDiscovery
如果您想更改 InstanceDiscovery 的实现,这非常简单,只需像这样创建一个实现 InstanceDiscovery 的 bean:
@Bean
public InstanceDiscovery instanceDiscovery() {
//choose either one of the provided implementations from spring or
//create your own
return new ConfigPropertyBasedDiscovery();
//return new FileBasedInstanceDiscovery();
}
确保将它放在@Configuration class 中。我最初在我的 SpringBootApplication class 中有我的,但这不允许你覆盖默认实现。
我正在尝试设置带有涡轮机的 hystrix 仪表板。我没有使用 Eureka,而是想使用 FileBasedInstanceDiscovery。我正在尝试配置它,但遵循在线文档似乎不起作用。它始终尝试使用 Eureka 发现客户端。我尝试从我的 pom 中排除尤里卡,但随后它退回到另一个发现客户端 CommonsInstanceDiscovery
这是我的 application.properties:
turbine.aggregator.clusterConf=mycluster
turbine.instanceUrlSuffix.mycluster=8080/hystrix.stream
turbine.FileBasedInstanceDiscovery.filePath=turbine.hostnames.txt
turbine.InstanceMonitor.eventStream.skipLineLogic.enabled=false
InstanceDiscovery.impl=com.netflix.turbine.discovery.FileBasedInstanceDiscovery
还有其他方法吗?此外,对于我的涡轮机主机名的文件路径,它从哪里开始寻找?我可以将该文件放在我的 jar 资源目录下吗?
这是我的 pom 文件依赖项:
<properties>
<java.version>1.8</java.version>
<spring-cloud.version>Greenwich.SR1</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web-services</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-hystrix-dashboard</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-turbine</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
涡轮机的一些文档不清楚和冲突,我认为这是因为有 spring-cloud-netflix 项目和一个独立的涡轮机项目。无论如何,如果您正在构建一个 spring-boot 应用程序,那么这个 属性 是没有用的:
InstanceDiscovery.impl=com.netflix.turbine.discovery.FileBasedInstanceDiscovery
如果您想更改 InstanceDiscovery 的实现,这非常简单,只需像这样创建一个实现 InstanceDiscovery 的 bean:
@Bean
public InstanceDiscovery instanceDiscovery() {
//choose either one of the provided implementations from spring or
//create your own
return new ConfigPropertyBasedDiscovery();
//return new FileBasedInstanceDiscovery();
}
确保将它放在@Configuration class 中。我最初在我的 SpringBootApplication class 中有我的,但这不允许你覆盖默认实现。