首页 > 解决方案 > 使用 FileBasedInstanceDiscovery 的 hystrix-dashboard 涡轮机的问题

问题描述

我正在尝试使用涡轮机设置 hystrix-dashboard。我没有使用 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>

标签: hystrixturbine

解决方案


涡轮机的一些文档不清楚和冲突,我认为这是因为有 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 类中。我最初只是在我的 SpringBootApplication 类中拥有我的,但这不允许您覆盖默认实现。


推荐阅读