尝试启动 VM 时 Azure 应用程序令牌凭据中的评估错误 (NoSuchMethodError)



我有一个需要远程控制的Azure VM。我正在以预期的方式使用应用程序令牌凭据进行身份验证;

ApplicationTokenCredentials credentials = new ApplicationTokenCredentials(client, tenant, key, AzureEnvironment.AZURE);

然后找到我的机器:

VirtualMachine vm = Azure .configure() .withLogLevel(LogLevel.NONE) .authenticate(credentials) .withSubscription(subscription) .virtualMachines() .getByResourceGroup(resourceGroup, machineName);

这与此处的官方文档显示的方法基本相同; https://learn.microsoft.com/en-us/azure/developer/java/sdk/java-sdk-manage-virtual-machines?view=azure-java-stable

这可以工作,进行身份验证,并为我设置一个虚拟机对象。我已经确认这就是它,并且它是我要控制的正确机器。

但是,当我尝试使用 start(( 方法启动它时,会发生这种情况:

Evaluation error (NoSuchMethodError) at com.microsoft.azure.credentials.ApplicationTokenCredentials.getToken (ApplicationTokenCredentials.java:138).

我的依赖树看起来不错。我使用的是来自 maven Central 的最新版本 com.microsoft.azure(仅此而已(;

<dependency>
<groupId>com.microsoft.azure</groupId>
<artifactId>azure</artifactId>
<version>1.35.0</version>
</dependency>

当然,这是父依赖项,它拉下了一堆工件。不过,我的依赖树乍一看似乎很好:

+- com.microsoft.azure:azure:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-client-runtime:jar:1.7.0:compile
[INFO] |  |  - com.microsoft.rest:client-runtime:jar:1.7.0:compile
[INFO] |  |     +- com.squareup.retrofit2:retrofit:jar:2.5.0:compile
[INFO] |  |     +- com.squareup.okhttp3:okhttp:jar:3.12.6:compile
[INFO] |  |     |  - com.squareup.okio:okio:jar:1.15.0:compile
[INFO] |  |     +- com.squareup.okhttp3:logging- 
interceptor:jar:3.12.2:compile
[INFO] |  |     +- com.squareup.okhttp3:okhttp- 
urlconnection:jar:3.12.2:compile
[INFO] |  |     +- com.squareup.retrofit2:converter- 
jackson:jar:2.5.0:compile
[INFO] |  |     |  - com.fasterxml.jackson.core:jackson- 
databind:jar:2.9.4:compile
[INFO] |  |     +- com.fasterxml.jackson.datatype:jackson-datatype- 
joda:jar:2.10.0:compile
[INFO] |  |     |  - com.fasterxml.jackson.core:jackson- 
annotations:jar:2.10.0:compile
[INFO] |  |     - com.squareup.retrofit2:adapter-rxjava:jar:2.6.2:compile
[INFO] |  +- com.microsoft.azure:azure-client- 
authentication:jar:1.7.0:compile
[INFO] |  |  - com.microsoft.azure:azure-annotations:jar:1.10.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-resources:jar:1.35.0:compile
[INFO] |  |  - io.reactivex:rxjava:jar:1.3.8:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-storage:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-network:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-graph-rbac:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-keyvault:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-batch:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt- 
trafficmanager:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-dns:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-redis:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-appservice:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-locks:jar:1.35.0:compile
[INFO] |  +- javax.xml.bind:jaxb-api:jar:2.3.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-eventhub:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-cdn:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-sql:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-         
containerinstance:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-         
containerregistry:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt- 
containerservice:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-cosmosdb:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-search:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-msi:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-monitor:jar:1.35.0:compile
[INFO] |  +- com.microsoft.azure:azure-mgmt-servicebus:jar:1.35.0:compile
[INFO] |  - com.microsoft.azure:azure-mgmt-batchai:jar:1.35.0:compile
[INFO] +- com.microsoft.azure:azure-mgmt-compute:jar:1.35.0:compile
[INFO] |  - com.google.code.gson:gson:jar:2.2.4:compile

至少我在这里没有看到任何突出的依赖冲突。我真的不知道如何在这里进行。

我最终设置了一个仅使用 VM 管理的测试项目,并发现使用相同的依赖项。

在煞费苦心地比较了两者之间的依赖关系后,我发现了一个差异;在我的测试项目中,com.microsoft.azure.adal4j包的版本是1.6.4,在我的生产应用程序中是1.0.0。

我不知道我的生产应用程序是如何最终使用旧版本的,因为所有根 azure 依赖项都是相同的,但我将此依赖项添加到我的生产应用程序中,从而解决了这个问题:

<dependency>
<groupId>com.microsoft.azure</groupId>
<artifactId>adal4j</artifactId>
<version>1.6.4</version>
</dependency>

最新更新