简体   繁体   English

创建Azure网络安全组-改装错误

[英]Create Azure Network Security Group - Retrofit Error

I'm using the Azure Java SDK version 1.15.1. 我正在使用Azure Java SDK版本1.15.1。 Since I need to connect to Azure using a non-default Java TrustStore, I created my own, custom trust store file which I'm loading into a TrustManager and then create an OkHttpClient.Builder like this: 由于我需要使用非默认的Java TrustStore连接到Azure,因此我创建了自己的自定义信任存储文件,将其加载到TrustManager中,然后创建如下的OkHttpClient.Builder:

OkHttpClient.Builder httpClientBuilder = new OkHttpClient.Builder().sslSocketFactory(sslSocketFactory, trustManager);

Then I'm creating a Retrofit Builder and use all of that to create my Azure connection object: 然后,我创建一个Retrofit Builder,并使用所有这些来创建我的Azure连接对象:

retrofit2.Retrofit.Builder retrofitBuilder = new retrofit2.Retrofit.Builder(); 
retrofitBuilder.baseUrl("https://management.azure.com"); 

com.microsoft.rest.RestClient restClient = new RestClient.Builder(httpClientBuilder, retrofitBuilder) 
    .withCredentials(credentials) 
    .withBaseUrl("https://management.azure.com") 
    .withResponseBuilderFactory(new ServiceResponseBuilder.Factory()) 
    .withSerializerAdapter(new JacksonAdapter())
    .build(); 

Azure azureConnection = Azure.authenticate(restClient, tenantId).withSubscription(subscription);

This works fine for retrieving all kinds of data from Azure (networks, security groups, etc.). 这对于从Azure检索各种数据(网络,安全组等)非常有效。

But if I want to use this connection to create a new security group: 但是,如果我想使用此连接来创建新的安全组:

newSecGroup = azureConnection.getAzureConnection().networkSecurityGroups() 
    .define(groupName) 
    .withRegion(regionName) 
    .withExistingResourceGroup(resourceGroupName) 
    .withTag("MyCustomTag", groupName) 
    .create();

it throws the following exception which doesn't really help me to track down the root cause - maybe someone can point me into the right direction? 它会引发以下异常,但这并不能真正帮助我找到根本原因-也许有人可以指出我正确的方向? Thanks Kurt 谢谢库尔特

Error when trying to create a new Security Group within resource groupksembatest, region eastus with name Cloud__Web Server for policy Web Server: com.microsoft.azure.CloudException
at com.microsoft.azure.AzureClient.createExceptionFromResponse(AzureClient.java:740)
at com.microsoft.azure.AzureClient.access$100(AzureClient.java:33)
at com.microsoft.azure.AzureClient$3.call(AzureClient.java:160)
at com.microsoft.azure.AzureClient$3.call(AzureClient.java:157)
at rx.internal.operators.OnSubscribeMap$MapSubscriber.onNext(OnSubscribeMap.java:69)
at retrofit2.adapter.rxjava.CallArbiter.deliverResponse(CallArbiter.java:120)
at retrofit2.adapter.rxjava.CallArbiter.emitResponse(CallArbiter.java:102)
at retrofit2.adapter.rxjava.CallExecuteOnSubscribe.call(CallExecuteOnSubscribe.java:46)
at retrofit2.adapter.rxjava.CallExecuteOnSubscribe.call(CallExecuteOnSubscribe.java:24)
at rx.Observable.unsafeSubscribe(Observable.java:10327)
at rx.internal.operators.OnSubscribeMap.call(OnSubscribeMap.java:48)
at rx.internal.operators.OnSubscribeMap.call(OnSubscribeMap.java:33)
at rx.Observable.unsafeSubscribe(Observable.java:10327)
at rx.internal.operators.OnSubscribeSingle.call(OnSubscribeSingle.java:81)
at rx.internal.operators.OnSubscribeSingle.call(OnSubscribeSingle.java:27)
at rx.internal.operators.SingleToObservable.call(SingleToObservable.java:39)
at rx.internal.operators.SingleToObservable.call(SingleToObservable.java:27)
at rx.Observable.unsafeSubscribe(Observable.java:10327)
at rx.internal.operators.OnSubscribeMap.call(OnSubscribeMap.java:48)
at rx.internal.operators.OnSubscribeMap.call(OnSubscribeMap.java:33)
at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:48)
at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:30)
at rx.Observable.unsafeSubscribe(Observable.java:10327)
at rx.internal.operators.DeferredScalarSubscriber.subscribeTo(DeferredScalarSubscriber.java:153)
at rx.internal.operators.OnSubscribeTakeLastOne.call(OnSubscribeTakeLastOne.java:32)
at rx.internal.operators.OnSubscribeTakeLastOne.call(OnSubscribeTakeLastOne.java:22)
at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:48)
at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:30)
at rx.Observable.unsafeSubscribe(Observable.java:10327)
at rx.internal.operators.OnSubscribeMap.call(OnSubscribeMap.java:48)
at rx.internal.operators.OnSubscribeMap.call(OnSubscribeMap.java:33)
at rx.Observable.unsafeSubscribe(Observable.java:10327)
at rx.internal.operators.OnSubscribeMap.call(OnSubscribeMap.java:48)
at rx.internal.operators.OnSubscribeMap.call(OnSubscribeMap.java:33)
at rx.Observable.unsafeSubscribe(Observable.java:10327)
at rx.internal.operators.OnSubscribeMap.call(OnSubscribeMap.java:48)
at rx.internal.operators.OnSubscribeMap.call(OnSubscribeMap.java:33)
at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:48)
at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:30)
at rx.Observable.unsafeSubscribe(Observable.java:10327)
at rx.internal.operators.OperatorSubscribeOn$SubscribeOnSubscriber.call(OperatorSubscribeOn.java:100)
at rx.internal.schedulers.CachedThreadScheduler$EventLoopWorker$1.call(CachedThreadScheduler.java:230)
at rx.internal.schedulers.ScheduledAction.run(ScheduledAction.java:55)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
at java.util.concurrent.FutureTask.run(FutureTask.java:266)
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:180)
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:293)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at java.lang.Thread.run(Thread.java:748)
Caused by: rx.exceptions.OnErrorThrowable$OnNextValue: OnError while emitting onNext value: retrofit2.Response.class
at rx.exceptions.OnErrorThrowable.addValueAsLastCause(OnErrorThrowable.java:118)
at rx.internal.operators.OnSubscribeMap$MapSubscriber.onNext(OnSubscribeMap.java:73)
... 45 more

After figuring out that it was possible to enable debug logging on the RestClient 在确定可以在RestClient上启用调试日志记录之后

com.microsoft.rest.RestClient restClient = new RestClient.Builder(httpClientBuilder, retrofitBuilder)
            .withCredentials(credentials)
            .withBaseUrl("https://management.azure.com")
            .withResponseBuilderFactory(new ServiceResponseBuilder.Factory())
            .withSerializerAdapter(new JacksonAdapter())
            .withLogLevel(com.microsoft.rest.LogLevel.BODY_AND_HEADERS)
            .build();

it was easy to find and solve my problem. 很容易找到并解决我的问题。 It was simply the fact that I had an empty space in the name of the Network Security Group that I wanted to create and that was not allowed by Azure. 只是事实是,我要创建的Network Security Group的名称中有一个空白,而Azure不允许这样做。 The HTTP response was MUCH clearer than the "CloudException" I got from the java API error trace. HTTP响应比我从Java API错误跟踪获得的“ CloudException”更清晰。

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

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