Diagnostic
Diagnostic details. Uses Azure REST API version 2022-09-01-preview. In version 2.x of the Azure Native provider, it used API version 2022-08-01. Other available API versions: 2021-04-01-preview, 2021-08-01, 2021-12-01-preview, 2022-04-01-preview, 2022-08-01, 2023-03-01-preview, 2023-05-01-preview, 2023-09-01-preview, 2024-05-01, 2024-06-01-preview. These can be accessed by generating a local SDK package using the CLI command pulumi package add azure-native apimanagement [ApiVersion]
. See the ../../../version-guide/#accessing-any-api-version-via-local-packages for details.
Example Usage
ApiManagementCreateDiagnostic
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using AzureNative = Pulumi.AzureNative;
return await Deployment.RunAsync(() =>
{
var diagnostic = new AzureNative.ApiManagement.Diagnostic("diagnostic", new()
{
AlwaysLog = AzureNative.ApiManagement.AlwaysLog.AllErrors,
Backend = new AzureNative.ApiManagement.Inputs.PipelineDiagnosticSettingsArgs
{
Request = new AzureNative.ApiManagement.Inputs.HttpMessageDiagnosticArgs
{
Body = new AzureNative.ApiManagement.Inputs.BodyDiagnosticSettingsArgs
{
Bytes = 512,
},
Headers = new[]
{
"Content-type",
},
},
Response = new AzureNative.ApiManagement.Inputs.HttpMessageDiagnosticArgs
{
Body = new AzureNative.ApiManagement.Inputs.BodyDiagnosticSettingsArgs
{
Bytes = 512,
},
Headers = new[]
{
"Content-type",
},
},
},
DiagnosticId = "applicationinsights",
Frontend = new AzureNative.ApiManagement.Inputs.PipelineDiagnosticSettingsArgs
{
Request = new AzureNative.ApiManagement.Inputs.HttpMessageDiagnosticArgs
{
Body = new AzureNative.ApiManagement.Inputs.BodyDiagnosticSettingsArgs
{
Bytes = 512,
},
Headers = new[]
{
"Content-type",
},
},
Response = new AzureNative.ApiManagement.Inputs.HttpMessageDiagnosticArgs
{
Body = new AzureNative.ApiManagement.Inputs.BodyDiagnosticSettingsArgs
{
Bytes = 512,
},
Headers = new[]
{
"Content-type",
},
},
},
LoggerId = "/loggers/azuremonitor",
ResourceGroupName = "rg1",
Sampling = new AzureNative.ApiManagement.Inputs.SamplingSettingsArgs
{
Percentage = 50,
SamplingType = AzureNative.ApiManagement.SamplingType.@Fixed,
},
ServiceName = "apimService1",
});
});
package main
import (
apimanagement "github.com/pulumi/pulumi-azure-native-sdk/apimanagement/v2"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
_, err := apimanagement.NewDiagnostic(ctx, "diagnostic", &apimanagement.DiagnosticArgs{
AlwaysLog: pulumi.String(apimanagement.AlwaysLogAllErrors),
Backend: &apimanagement.PipelineDiagnosticSettingsArgs{
Request: &apimanagement.HttpMessageDiagnosticArgs{
Body: &apimanagement.BodyDiagnosticSettingsArgs{
Bytes: pulumi.Int(512),
},
Headers: pulumi.StringArray{
pulumi.String("Content-type"),
},
},
Response: &apimanagement.HttpMessageDiagnosticArgs{
Body: &apimanagement.BodyDiagnosticSettingsArgs{
Bytes: pulumi.Int(512),
},
Headers: pulumi.StringArray{
pulumi.String("Content-type"),
},
},
},
DiagnosticId: pulumi.String("applicationinsights"),
Frontend: &apimanagement.PipelineDiagnosticSettingsArgs{
Request: &apimanagement.HttpMessageDiagnosticArgs{
Body: &apimanagement.BodyDiagnosticSettingsArgs{
Bytes: pulumi.Int(512),
},
Headers: pulumi.StringArray{
pulumi.String("Content-type"),
},
},
Response: &apimanagement.HttpMessageDiagnosticArgs{
Body: &apimanagement.BodyDiagnosticSettingsArgs{
Bytes: pulumi.Int(512),
},
Headers: pulumi.StringArray{
pulumi.String("Content-type"),
},
},
},
LoggerId: pulumi.String("/loggers/azuremonitor"),
ResourceGroupName: pulumi.String("rg1"),
Sampling: &apimanagement.SamplingSettingsArgs{
Percentage: pulumi.Float64(50),
SamplingType: pulumi.String(apimanagement.SamplingTypeFixed),
},
ServiceName: pulumi.String("apimService1"),
})
if err != nil {
return err
}
return nil
})
}
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.azurenative.apimanagement.Diagnostic;
import com.pulumi.azurenative.apimanagement.DiagnosticArgs;
import com.pulumi.azurenative.apimanagement.inputs.PipelineDiagnosticSettingsArgs;
import com.pulumi.azurenative.apimanagement.inputs.HttpMessageDiagnosticArgs;
import com.pulumi.azurenative.apimanagement.inputs.BodyDiagnosticSettingsArgs;
import com.pulumi.azurenative.apimanagement.inputs.SamplingSettingsArgs;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
public static void main(String[] args) {
Pulumi.run(App::stack);
}
public static void stack(Context ctx) {
var diagnostic = new Diagnostic("diagnostic", DiagnosticArgs.builder()
.alwaysLog("allErrors")
.backend(PipelineDiagnosticSettingsArgs.builder()
.request(HttpMessageDiagnosticArgs.builder()
.body(BodyDiagnosticSettingsArgs.builder()
.bytes(512)
.build())
.headers("Content-type")
.build())
.response(HttpMessageDiagnosticArgs.builder()
.body(BodyDiagnosticSettingsArgs.builder()
.bytes(512)
.build())
.headers("Content-type")
.build())
.build())
.diagnosticId("applicationinsights")
.frontend(PipelineDiagnosticSettingsArgs.builder()
.request(HttpMessageDiagnosticArgs.builder()
.body(BodyDiagnosticSettingsArgs.builder()
.bytes(512)
.build())
.headers("Content-type")
.build())
.response(HttpMessageDiagnosticArgs.builder()
.body(BodyDiagnosticSettingsArgs.builder()
.bytes(512)
.build())
.headers("Content-type")
.build())
.build())
.loggerId("/loggers/azuremonitor")
.resourceGroupName("rg1")
.sampling(SamplingSettingsArgs.builder()
.percentage(50)
.samplingType("fixed")
.build())
.serviceName("apimService1")
.build());
}
}
Import
An existing resource can be imported using its type token, name, and identifier, e.g.
$ pulumi import azure-native:apimanagement:Diagnostic applicationinsights /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ApiManagement/service/{serviceName}/diagnostics/{diagnosticId}
Properties
The Azure API version of the resource.
Diagnostic settings for incoming/outgoing HTTP messages to the Backend
Diagnostic settings for incoming/outgoing HTTP messages to the Gateway.
Sets correlation protocol to use for Application Insights diagnostics.
Log the ClientIP. Default is false.
The format of the Operation Name for Application Insights telemetries. Default is Name.
Sampling settings for Diagnostic.