1. ホーム
  2. java

[解決済み] IntelliJ IDEAでエンドポイントタブが何も表示されない。"アプリケーションのJMXサービスURLの取得に失敗しました"

2022-03-11 02:06:51

質問

Spring BootのWebサービスを持っていて、そのエンドポイントを見たいと思っています。 しかし、IntelliJでそれを実行すると、エンドポイントが表示されません。 エンドポイントウィンドウでは、エラーが表示されます。

Failed to check application ready state: AttachProvider for the vm is not found.
Press Refresh button to reinit ready state checking

SoapUIで問題なくアプリケーションを実行し、Webサービスをヒットさせることができるのですが、IntelliJでその機能を使いたいのです。エンドポイントタブやエンドポイントタブの更新ボタンをクリックすると、イベントログに、アプリケーション起動時に次のようなログエントリが表示されます。

PersonMicroserviceApplication: Failed to retrieve application JMX service URL

実行設定で "Enable JMX agent" にチェックを入れています。 これは私の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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.2.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

    <groupId>com.example.microservice</groupId>
    <artifactId>person-service</artifactId>
    <version>0.0.1-SNAPSHOT</version>

    <properties>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>com.google.code.gson</groupId>
            <artifactId>gson</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>com.fasterxml.jackson.core</groupId>
                    <artifactId>*</artifactId>
                </exclusion>
                <exclusion>
                    <groupId>com.fasterxml.jackson.datatype</groupId>
                    <artifactId>*</artifactId>
                </exclusion>
                <exclusion>
                    <groupId>com.fasterxml.jackson.module</groupId>
                    <artifactId>*</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-security</artifactId>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.6</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-mongodb</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.security</groupId>
            <artifactId>spring-security-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <sourceDirectory>src/main/java</sourceDirectory>
        <testSourceDirectory>src/test/java</testSourceDirectory>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

注:Jacksonは、私の会社のMavenリポジトリでは、セキュリティ上の懸念から隔離された依存関係としてマークされています(セキュリティ上の懸念が何であるかは分かりません)ので、私はjsonマッパーとしてgsonを使っています。

spring.http.converters.preferred-json-mapper=gson

application.propertiesにあるのは、mongodbへの接続文字列だけです。 他に何もないので、何か見落としているかもしれませんが、私が見たspringのドキュメントでは、include spring-boot-starter-actuator と check enable JMX agent と書いてあるだけでした。

これを有効にするために、何か設定的に足りないものがあるのでしょうか?私はWindows 10の64ビットで、Oracle JDK 8を使用しています。

解決方法を教えてください。

私もこの問題に遭遇し、ようやく答えを見つけました。

2018.3.4以降のIntelliJ IDEAでは、Spring Bootアクチュエータのエンドポイントのデータを取得するために、ローカルJMXコネクタを使用します。 ローカルJMXモニタリングにはいくつかの制限があり、特にSpring BootアプリケーションとIntelliJ IDEAのJVMのビット数が異なる場合、ローカルJMXコネクタのアドレスを取得することはできません。 もし、同じビット数のJVMでアプリケーションを実行できない場合は、Spring Bootの実行設定のVMオプションに以下を追加することで問題を解決することができます。

-Dcom.sun.management.jmxremote.port={some_port} -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false

設定後。

jetbrains issue link: https://youtrack.jetbrains.com/issue/IDEA-204797