繁体   English   中英

Spring 引导 - Spring 引导启动器执行器问题

[英]Spring Boot - Issue with Spring Boot Starter Actuator

所以我正在创建一个新的 spring 引导项目,并想玩一下 spring-boot-starter-actuator。 但是,我在启动应用程序时遇到了问题。

Pom片段:

      <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-logging</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>
        <!--<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-validation</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

<spring-boot.version>2.2.0.RELEASE</spring-boot.version>

我的类路径上的spring-boot 在此处输入图像描述

启动应用程序时出错:

***************************
APPLICATION FAILED TO START
***************************

Description:

An attempt was made to call a method that does not exist. The attempt was made from the following location:

    org.springframework.boot.actuate.autoconfigure.metrics.orm.jpa.HibernateMetricsAutoConfiguration.bindEntityManagerFactoryToRegistry(HibernateMetricsAutoConfiguration.java:68)

The following method did not exist:

    io.micrometer.core.instrument.binder.jpa.HibernateMetrics.<init>(Lorg/hibernate/SessionFactory;Ljava/lang/String;Ljava/lang/Iterable;)V

The method's class, io.micrometer.core.instrument.binder.jpa.HibernateMetrics, is available from the following locations:

    jar:file:/C:/Users/rahul/.m2/repository/io/micrometer/micrometer-core/1.0.2/micrometer-core-1.0.2.jar!/io/micrometer/core/instrument/binder/jpa/HibernateMetrics.class

It was loaded from the following location:

    file:/C:/Users/rahul/.m2/repository/io/micrometer/micrometer-core/1.0.2/micrometer-core-1.0.2.jar


Action:

Correct the classpath of your application so that it contains a single, compatible version of io.micrometer.core.instrument.binder.jpa.HibernateMetrics

此时发生异常: 在此处输入图像描述

然而, HibernateMetrics只有一个构造函数,如下所示:

public HibernateMetrics(EntityManagerFactory entityManagerFactory, String entityManagerFactoryName, Iterable<Tag> tags) {
        this.tags = Tags.concat(tags, "entityManagerFactory", entityManagerFactoryName);
        this.stats = hasStatisticsEnabled(entityManagerFactory) ? getStatistics(entityManagerFactory) : null;
    }

从依赖项分析器中,可以看到micrometer-core没有多个版本: 在此处输入图像描述

我也尝试使用spring-boot-starter-actuator version of 2.2.0.RELEASE但也有同样的问题。

我不确定我在这里缺少什么,任何帮助将不胜感激。

假设您要将 spring-boot-actuator 应用程序连接到 JMX 控制台。 (“因为它不是 web 应用程序”)

我根据您的 pom 依赖项和 CommandLineRunner 示例使用了 Spring Initializr。 Github 示例: https://github.com/thiagochagas/actuator-example

调整:我已经删除了“spring-boot-starter”依赖:

<dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter</artifactId>
     <exclusions>
         <exclusion>
             <groupId>org.springframework.boot</groupId>
             <artifactId>spring-boot-starter-logging</artifactId>
         </exclusion>
     </exclusions>
</dependency>

我在 DemoApplication class 中使用了 Thread.sleep(30000L) 来简化示例。

安装并运行应用程序:

./mvnw clean install
java -jar target/demo-0.0.1-SNAPSHOT.jar

打开 jconsole:

$JAVA_HOME/bin/jconsole

当您的应用程序正在运行时,它应该在 jconsole 上。

Select 你的“demo-0.0.1-SNAPSHOT.jar”来分析: 在此处输入图像描述

如果显示此消息,select 选项“不安全连接”: 在此处输入图像描述

运行应用程序分析: 在此处输入图像描述

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM