Biblioteka klienta .NET rejestruje żądania, odpowiedzi i wiadomości podsumowania wysyłane do interfejsu Google Ads API. Logi można zapisywać w niestandardowej TraceListener
lub w niestandardowej ILogger
.
TraceListener
Aby włączyć rejestrowanie w TraceListener
, przed wykonaniem wywołań interfejsu API dodaj ten wiersz do metody Main
.
using Google.Ads.GoogleAds.Util;
...
// Detailed logs.
TraceUtilities.Configure(TraceUtilities.DETAILED_REQUEST_LOGS_SOURCE,
"C:\\logs\\details.log", System.Diagnostics.SourceLevels.All);
// Summary logs.
TraceUtilities.Configure(TraceUtilities.SUMMARY_REQUEST_LOGS_SOURCE,
"C:\\logs\\details.log", System.Diagnostics.SourceLevels.All);
ILogger
Jeśli używasz już ILogger
do logów aplikacji, to rozwiązanie umożliwia zintegrowanie logów Google Ads API z dotychczasowymi logami.
Najpierw utwórz LoggerFactory
lub, jeśli już go masz, dodaj filtry dla logów interfejsu Google Ads API:
var loggerFactory = LoggerFactory.Create(delegate (ILoggingBuilder builder)
{
// Log to stdout.
builder.AddConsole();
builder.AddFilter(TraceUtilities.SUMMARY_REQUEST_LOGS_SOURCE, LogLevel.Trace);
builder.AddFilter(TraceUtilities.DETAILED_REQUEST_LOGS_SOURCE, LogLevel.Trace);
});
Następnie użyj funkcji LoggerFactory
, aby utworzyć loga dla podsumowań i szczegółów żądań oraz odpowiedzi:
ILogger summaryLogger = loggerFactory.CreateLogger(TraceUtilities.SUMMARY_REQUEST_LOGS_SOURCE);
ILogger detailLogger = loggerFactory.CreateLogger(TraceUtilities.DETAILED_REQUEST_LOGS_SOURCE);
Na koniec skonfiguruj bibliotekę klienta, aby przekierowywać ścieżki do swoich instancji ILogger
:
TraceUtilities.ConfigureSummaryLogger(summaryLogger);
TraceUtilities.ConfigureDetailLogger(detailLogger);
To rozwiązanie umożliwia zintegrowanie logów żądań i odpowiedzi interfejsu Google Ads API z dotychczasowymi ramami logowania, takimi jak Log4Net, NLog i Serilog.
Poziomy rejestrowania
Biblioteka rejestruje różne typy zdarzeń na różnych poziomach logowania. W przypadku prawidłowej odpowiedzi interfejsu API podsumowanie jest rejestrowane w INFO
, a pełne żądanie i odpowiedzi – w DEBUG
.
W przypadku żądania, które powoduje błąd interfejsu API, komunikat z podsumowaniem jest rejestrowany w pliku WARN
, a pełne żądanie i odpowiedź – w pliku INFO
.
Częściowe niepowodzenia są rejestrowane w miejscu DEBUG
.
Identyfikator żądania
W większości przypadków dzienniki wygenerowane przez bibliotekę klienta zawierają wystarczające informacje do rozwiązania problemów. Kontaktując się z zespołem pomocy na forum lub za pomocą aliasów, możesz przesłać dzienniki (w których domyślnie są usunięte informacje poufne) lub udostępnić identyfikator żądania (który jest zapisywany w dzienniku odpowiedzi).
Jeśli wolisz samodzielnie rejestrować identyfikator żądania, możesz użyć jednego z tych rozwiązań:
Wyodrębnianie za pomocą zwykłych wywołań interfejsu API
Aby rejestrować identyfikatory żądań z zwykłych wywołań jednoelementowych, możesz użyć niestandardowego parametru CallSetting
z parametrem TrailingMetadataHandler
.
CallSettings callSettings = CallSettings.FromTrailingMetadataHandler(
delegate (Metadata metadata) {
// Extract the request ID from the trailing metadata.
string requestId = metadata.Get("request-id").Value;
});
// Add the campaigns.
MutateCampaignsResponse retVal = campaignService.MutateCampaigns(
customerId.ToString(), operations.ToArray(), callSettings);
Wyodrębnianie za pomocą wywołań interfejsu API przesyłającego strumieniowo
Identyfikator żądania jest zwracany jako część obiektu odpowiedzi w przypadku wywołań interfejsu API przesyłanych strumieniowo. Identyfikator żądania wywołania SearchStream
możesz na przykład uzyskać w ten sposób:
// Get the GoogleAdsService.
GoogleAdsServiceClient googleAdsService = client.GetService(
Services.V19.GoogleAdsService);
// Retrieve all campaigns.
string query = @"SELECT
campaign.id,
campaign.name,
campaign.network_settings.target_content_network
FROM campaign
ORDER BY campaign.id";
// Issue a search request.
googleAdsService.SearchStream(customerId.ToString(), query,
delegate (SearchGoogleAdsStreamResponse resp)
{
// Extract the request ID from the response.
string requestId = resp.RequestId;
foreach (GoogleAdsRow googleAdsRow in resp.Results)
{
Console.WriteLine("Campaign with ID {0} and name '{1}' was found.",
googleAdsRow.Campaign.Id, googleAdsRow.Campaign.Name);
}
}
);
Wyjątki
Identyfikator żądania jest zwracany w ramach wyjątku GoogleAdsException
za każdym razem, gdy wywołanie interfejsu API się nie powiedzie.
try
{
// Make an API call.
...
}
catch (GoogleAdsException e)
{
string requestId = e.RequestId;
}
Zaawansowane rejestrowanie
Jeśli dziennik interfejsu API nie zawiera wystarczającej ilości informacji, włącz rejestrowanie na niższym poziomie, np. na poziomie gRPC. Pamiętaj, że dane wyjściowe mogą być obszerne. Logi gRPC są zapisywane w pliku stderr, ale możesz dołączyć własny rejestrator, jak pokazano poniżej. Obsługiwane zmienne środowiska.
Environment.SetEnvironmentVariable("GRPC_VERBOSITY", "DEBUG");
Environment.SetEnvironmentVariable("GRPC_TRACE", "http");
GrpcEnvironment.SetLogger(new ConsoleLogger());
Konfiguracja TraceListener za pomocą pliku App.config (starsza wersja)
Jeśli aplikacja jest kompilowana na potrzeby docelowego zestawu .NET Framework, możesz załadować konfigurację rejestrowania z pliku App.config
lub Web.config
aplikacji. Jest to starsza funkcja .NET, która nie jest obsługiwana w przypadku aplikacji skompilowanych na potrzeby .NET Core.
Aby korzystać z tej funkcji, musisz wprowadzić w pliku konfiguracji te zmiany:
Dodaj ten fragment kodu w sekcji
<configuration>
.<system.diagnostics> <sources> <source name="GoogleAds.DeprecationMessages" switchName="GoogleAds.DeprecationMessages" switchType="System.Diagnostics.SourceSwitch"> <listeners> <add name="myListener" type="System.Diagnostics.EventLogTraceListener" initializeData="Application"/> </listeners> </source> <source name="GoogleAds.DetailedRequestLogs" switchName="GoogleAds.DetailedRequestLogs" switchType="System.Diagnostics.SourceSwitch"> <listeners> <add name="detailedRequestLogListener" type="System.Diagnostics.ConsoleTraceListener" initializeData="true"/> <!-- Use the following to log to file. Modify the initializeData attribute to control the path to the detailed request log file. --> <!-- <add name="detailedRequestLogListener" type="System.Diagnostics.TextWriterTraceListener" initializeData="C:\Logs\detailed_logs.log"/> <remove name="Default"/> --> </listeners> </source> <source name="GoogleAds.SummaryRequestLogs" switchName="GoogleAds.SummaryRequestLogs" switchType="System.Diagnostics.SourceSwitch"> <listeners> <add name="summaryRequestLogListener" type="System.Diagnostics.ConsoleTraceListener" initializeData="true"/> <!-- Use the following to log to file. Modify the initializeData attribute to control the path to the summary request log file. --> <!-- <add name="summaryRequestLogListener" type="System.Diagnostics.TextWriterTraceListener" initializeData="C:\Logs\summary_logs.log"/> --> <remove name="Default"/> </listeners> </source> </sources> <switches> <!-- Use this trace switch to control the deprecation trace messages written by Ads* .NET libraries. The default is level is set to Warning. To disable all messages, set this value to Off. See msdn.microsoft.com/en-us/library/system.diagnostics.sourcelevels.aspx for all possible values this key can take. --> <add name="GoogleAds.DeprecationMessages" value="Warning"/> <!-- Use this trace switch to control the detailed request logs written by Ads* .NET libraries. The default level is set to Off. Logs are generated at both the Error and Information levels. --> <add name="GoogleAds.DetailedRequestLogs" value="Off"/> <!-- Use this trace switch to control the summary request logs written by Ads* .NET libraries. The default level is set to Off. Logs are generated at both the Error and Information levels. --> <add name="GoogleAds.SummaryRequestLogs" value="Off"/> </switches> <trace autoflush="true"/> </system.diagnostics>
Dodaj ten fragment kodu w sekcji
<configSections>
.<section name="system.diagnostics" type="System.Diagnostics.SystemDiagnosticsSection"/>
Twoje
App.config
będzie wyglądać tak:<?xml version="1.0" encoding="utf-8"?> <configuration> <configSections> <section name="GoogleAdsApi" type="System.Configuration.DictionarySectionHandler"/> <section name="system.diagnostics" type="System.Diagnostics.SystemDiagnosticsSection"/> </configSections> <GoogleAdsApi> <!-- Google Ads API settings. --> </GoogleAdsApi> <system.diagnostics> <!-- Logging settings. --> </system.diagnostics> </configuration>