Nella dashboard Crashlytics, puoi fare clic su un problema e ottenere un report dettagliato sugli eventi. Puoi personalizzare questi report per comprendere meglio cosa succede nella tua app e le circostanze che circondano gli eventi segnalati a Crashlytics.
Strumenta la tua app per registrare chiavi personalizzate, messaggi di log personalizzati e identificatori utente.
Segnala le eccezioni a Crashlytics.
Ricevi automaticamente i log di breadcrumb se la tua app utilizza l'SDK Firebase per Google Analytics. Questi log ti offrono visibilità sulle azioni degli utenti che hanno portato a un evento raccolto da Crashlytics nella tua app.
Disattiva la segnalazione automatica degli arresti anomali e attiva la segnalazione con consenso per i tuoi utenti. Tieni presente che, per impostazione predefinita, Crashlytics raccoglie automaticamente i report sugli arresti anomali per tutti gli utenti della tua app.
Aggiungere chiavi personalizzate
Le chiavi personalizzate ti consentono di conoscere lo stato specifico della tua app che ha causato un arresto anomalo. Puoi associare coppie chiave/valore arbitrarie ai report sugli arresti anomali, quindi utilizzare le chiavi personalizzate per cercare e filtrare i report sugli arresti anomali nella console Firebase.
- Nella dashboard Crashlytics, puoi cercare i problemi che corrispondono a una chiave personalizzata.
- Quando esamini un problema specifico nella console, puoi visualizzare le chiavi personalizzate associate a ogni evento (scheda secondaria Chiavi) e persino filtrare gli eventi in base alle chiavi personalizzate (menu Filtro nella parte superiore della pagina).
Utilizza il metodo setCustomValue
per impostare le coppie chiave/valore. Ad esempio:
Swift
// Set int_key to 100. Crashlytics.crashlytics().setCustomValue(100, forKey: "int_key") // Set str_key to "hello". Crashlytics.crashlytics().setCustomValue("hello", forKey: "str_key")
Objective-C
Quando imposti numeri interi, valori booleani o numeri in virgola mobile, racchiudi il valore tra parentesi quadre @(value)
.
// Set int_key to 100. [[FIRCrashlytics crashlytics] setCustomValue:@(100) forKey:@"int_key"]; // Set str_key to "hello". [[FIRCrashlytics crashlytics] setCustomValue:@"hello" forKey:@"str_key"];
Puoi anche modificare il valore di una chiave esistente chiamandola e impostandola su un valore diverso. Ad esempio:
Swift
Crashlytics.crashlytics().setCustomValue(100, forKey: "int_key") // Set int_key to 50 from 100. Crashlytics.crashlytics().setCustomValue(50, forKey: "int_key")
Objective-C
[[FIRCrashlytics crashlytics] setCustomValue:@(100) forKey:@"int_key"]; // Set int_key to 50 from 100. [[FIRCrashlytics crashlytics] setCustomValue:@(50) forKey:@"int_key"];
Aggiungi coppie chiave/valore collettivamente utilizzando il metodo setCustomKeysAndValues
con un
NSDictionary come unico parametro:
Swift
let keysAndValues = [ "string key" : "string value", "string key 2" : "string value 2", "boolean key" : true, "boolean key 2" : false, "float key" : 1.01, "float key 2" : 2.02 ] as [String : Any] Crashlytics.crashlytics().setCustomKeysAndValues(keysAndValues)
Objective-C
NSDictionary *keysAndValues = @{@"string key" : @"string value", @"string key 2" : @"string value 2", @"boolean key" : @(YES), @"boolean key 2" : @(NO), @"float key" : @(1.01), @"float key 2" : @(2.02)}; [[FIRCrashlytics crashlytics] setCustomKeysAndValues: keysAndValues];
Aggiungere messaggi di log personalizzati
Per avere più contesto sugli eventi che hanno portato a un arresto anomalo, puoi aggiungere log Crashlytics personalizzati alla tua app. Crashlytics associa i log ai dati sugli arresti anomali e li visualizza nella pagina Crashlytics della console Firebase, nella scheda Log.
Swift
Utilizza log()
o log(format:, arguments:)
per identificare i problemi. Se vuoi
ottenere un output di log utile con i messaggi, l'oggetto che passi a
log()
deve essere conforme alla
proprietà CustomStringConvertible
. log()
restituisce la proprietà di descrizione che definisci per
l'oggetto. Ad esempio:
Crashlytics.crashlytics().log("Higgs-Boson detected! Bailing out…, \(attributesDict)")
.log(format:, arguments:)
formatta i valori restituiti dalla chiamata
getVaList()
. Ad esempio:
Crashlytics.crashlytics().log(format: "%@, %@", arguments: getVaList(["Higgs-Boson detected! Bailing out…", attributesDict]))
Per saperne di più su come utilizzare log()
o log(format:, arguments:)
,
consulta la Crashlytics
documentazione di riferimento.
Objective-C
Utilizza log
o logWithFormat
per identificare i problemi. Tieni presente che, se vuoi ottenere un output di log utile con i messaggi, l'oggetto che passi a uno dei due metodi deve sostituire la proprietà dell'istanza description
.
Ad esempio:
[[FIRCrashlytics crashlytics] log:@"Simple string message"]; [[FIRCrashlytics crashlytics] logWithFormat:@"Higgs-Boson detected! Bailing out... %@", attributesDict]; [[FIRCrashlytics crashlytics] logWithFormat:@"Logging a variable argument list %@" arguments:va_list_arg];
Per maggiori dettagli su come utilizzare log
e logWithFormat
, consulta la
Crashlytics documentazione di riferimento.
Impostare gli identificatori utente
Per diagnosticare un problema, spesso è utile sapere quali utenti hanno riscontrato un determinato arresto anomalo. Crashlytics include un modo per identificare in modo anonimo gli utenti nei report sugli arresti anomali.
Per aggiungere gli ID utente ai report, assegna a ogni utente un identificatore univoco sotto forma di numero ID, token o valore sottoposto ad hashing:
Swift
Crashlytics.crashlytics().setUserID("123456789")
Objective-C
[[FIRCrashlytics crashlytics] setUserID:@"123456789"];
Se devi cancellare un identificatore utente dopo averlo impostato, reimposta il valore su una stringa vuota. L'eliminazione di un identificatore utente non comporta la rimozione dei record Crashlyticsesistenti. Se devi eliminare i record associati a un ID utente, contatta l'assistenza Firebase.
Segnalare eccezioni non irreversibili
Oltre a segnalare automaticamente gli arresti anomali della tua app, Crashlytics ti consente di registrare eccezioni non irreversibili e inviartele al successivo avvio dell'app.
Puoi registrare eccezioni non irreversibili registrando oggetti NSError
con il metodo recordError
. recordError
acquisisce lo stack di chiamate del thread chiamando
[NSThread callStackReturnAddresses]
.
Swift
Crashlytics.crashlytics().record(error: error)
Objective-C
[[FIRCrashlytics crashlytics] recordError:error];
Quando utilizzi il metodo recordError
, è importante comprendere la struttura di NSError
e il modo in cui Crashlytics utilizza i dati per raggruppare gli arresti anomali. L'utilizzo
errato del metodo recordError
può causare un comportamento imprevedibile e
potrebbe indurre Crashlytics a limitare la generazione di report sugli errori registrati per la tua app.
Un oggetto NSError
ha tre argomenti:
domain: String
code: Int
userInfo: [AnyHashable : Any]? = nil
A differenza degli arresti anomali irreversibili, che vengono raggruppati tramite l'analisi dello stack, gli errori registrati
vengono raggruppati per domain
e code
. Questa è una distinzione importante
tra arresti anomali irreversibili ed errori registrati. Ad esempio:
Swift
let userInfo = [ NSLocalizedDescriptionKey: NSLocalizedString("The request failed.", comment: ""), NSLocalizedFailureReasonErrorKey: NSLocalizedString("The response returned a 404.", comment: ""), NSLocalizedRecoverySuggestionErrorKey: NSLocalizedString("Does this page exist?", comment: ""), "ProductID": "123456", "View": "MainView" ] let error = NSError.init(domain: NSCocoaErrorDomain, code: -1001, userInfo: userInfo)
Objective-C
NSDictionary *userInfo = @{ NSLocalizedDescriptionKey: NSLocalizedString(@"The request failed.", nil), NSLocalizedFailureReasonErrorKey: NSLocalizedString(@"The response returned a 404.", nil), NSLocalizedRecoverySuggestionErrorKey: NSLocalizedString(@"Does this page exist?", nil), @"ProductID": @"123456", @"View": @"MainView", }; NSError *error = [NSError errorWithDomain:NSCocoaErrorDomain code:-1001 userInfo:userInfo];
Quando registri l'errore riportato sopra, viene creato un nuovo problema raggruppato per
NSSomeErrorDomain
e -1001
. Gli errori registrati aggiuntivi che utilizzano gli stessi
valori di dominio e codice vengono raggruppati nello stesso problema. I dati contenuti nell'oggetto userInfo
vengono convertiti in coppie chiave-valore e visualizzati nella sezione chiavi/log all'interno di un singolo problema.
Log e chiavi personalizzate
Come per i report sugli arresti anomali, puoi incorporare log e chiavi personalizzate per aggiungere contesto
al NSError
. Tuttavia, esiste una differenza tra i log allegati
ai blocchi anomali e agli errori registrati. Quando si verifica un arresto anomalo e l'app viene riavviata, i
log Crashlytics recuperati dal disco sono quelli scritti fino al
momento dell'arresto anomalo. Quando registri un NSError
, l'app non viene chiusa
immediatamente. Poiché Crashlytics invia il report degli errori registrati solo al successivo avvio dell'app e deve limitare la quantità di spazio allocato per i log sul disco, è possibile registrare un numero sufficiente di errori dopo la registrazione di un NSError
in modo che tutti i log pertinenti vengano ruotati prima che Crashlytics invii il report dal dispositivo. Tieni presente questo equilibrio quando registri NSErrors
e utilizzi i log e le chiavi personalizzate nella tua app.
Considerazioni sulle prestazioni
Tieni presente che la registrazione di un NSError
può essere piuttosto costosa. Al momento della chiamata, Crashlytics acquisisce lo stack di chiamate del thread corrente utilizzando un
processo chiamato stack unwinding. Questo processo può richiedere un uso intensivo di CPU e I/O,
in particolare su architetture che supportano l'unwinding DWARF (arm64 e x86).
Al termine dell'annullamento, le informazioni vengono scritte sul disco in modo sincrono.
In questo modo si evita la perdita di dati in caso di arresto anomalo della riga successiva.
Sebbene sia sicuro chiamare questa API su un thread in background, ricorda che l'invio di questa chiamata a un'altra coda perde il contesto dello stack trace corrente.
Che cosa sono le NSException?
Crashlytics non offre una funzionalità per registrare e registrare direttamente le istanze di NSException
. In generale, le API Cocoa e Cocoa Touch non sono
sicure per le eccezioni. Ciò significa che l'utilizzo di @catch
può avere effetti collaterali indesiderati molto gravi nel tuo processo, anche se utilizzato con estrema attenzione. Non devi mai
utilizzare le istruzioni @catch
nel tuo codice. Consulta la documentazione di Apple sull'argomento.
Personalizzare le analisi dello stack
Se la tua app viene eseguita in un ambiente non nativo (ad esempio C++ o Unity), puoi utilizzare l'API Exception Model per segnalare i metadati degli arresti anomali nel formato di eccezione nativa della tua app. Le eccezioni segnalate sono contrassegnate come non irreversibili.
Swift
var ex = ExceptionModel(name:"FooException", reason:"There was a foo.") ex.stackTrace = [ StackFrame(symbol:"makeError", file:"handler.js", line:495), StackFrame(symbol:"then", file:"routes.js", line:102), StackFrame(symbol:"main", file:"app.js", line:12), ] crashlytics.record(exceptionModel:ex)
Objective-C
FIRExceptionModel *model = [FIRExceptionModel exceptionModelWithName:@"FooException" reason:@"There was a foo."]; model.stackTrace = @[ [FIRStackFrame stackFrameWithSymbol:@"makeError" file:@"handler.js" line:495], [FIRStackFrame stackFrameWithSymbol:@"then" file:@"routes.js" line:102], [FIRStackFrame stackFrameWithSymbol:@"main" file:@"app.js" line:12], ]; [[FIRCrashlytics crashlytics] recordExceptionModel:model];
I frame dello stack personalizzati possono essere inizializzati anche solo con gli indirizzi:
Swift
var ex = ExceptionModel.init(name:"FooException", reason:"There was a foo.") ex.stackTrace = [ StackFrame(address:0xfa12123), StackFrame(address:12412412), StackFrame(address:194129124), ] crashlytics.record(exceptionModel:ex)
Objective-C
FIRExceptionModel *model = [FIRExceptionModel exceptionModelWithName:@"FooException" reason:@"There was a foo."]; model.stackTrace = @[ [FIRStackFrame stackFrameWithAddress:0xfa12123], [FIRStackFrame stackFrameWithAddress:12412412], [FIRStackFrame stackFrameWithAddress:194129124], ]; [[FIRCrashlytics crashlytics] recordExceptionModel:model];
Recuperare i log dei breadcrumb
I log dei breadcrumb ti consentono di comprendere meglio le interazioni che un utente ha avuto con la tua app prima di un evento di arresto anomalo, non irreversibile o ANR. Questi log possono essere utili quando si tenta di riprodurre ed eseguire il debug di un problema.
I log breadcrumb sono basati su Google Analytics, quindi per ottenerli devi attivare Google Analytics per il tuo progetto Firebase e aggiungere l'SDK Firebase per Google Analytics alla tua app. Una volta soddisfatti questi requisiti, i log breadcrumb vengono inclusi automaticamente nei dati di un evento nella scheda Log quando visualizzi i dettagli di un problema.
L'SDK Analytics
registra automaticamente l'screen_view
evento
che consente ai log dei breadcrumb di mostrare un elenco di schermate visualizzate prima dell'evento di arresto anomalo, non irreversibile o ANR. Un log breadcrumb screen_view
contiene un
parametro firebase_screen_class
.
I log breadcrumb vengono compilati anche con eventuali eventi personalizzati registrati manualmente all'interno della sessione dell'utente, inclusi i dati dei parametri dell'evento. Questi dati possono contribuire a mostrare una serie di azioni dell'utente che hanno portato a un evento di arresto anomalo, non irreversibile o ANR.
Tieni presente che puoi controllare la raccolta e l'utilizzo dei dati Google Analytics, che includono i dati che compilano i log della breadcrumb.
Attivare i report di attivazione
Per impostazione predefinita, Crashlytics raccoglie automaticamente i report sugli arresti anomali per tutti gli utenti della tua app. Per dare agli utenti un maggiore controllo sui dati che inviano, puoi attivare i report con consenso esplicito disattivando i report automatici e inviando i dati solo a Crashlytics quando scegli di farlo nel codice.
Disattiva la raccolta automatica aggiungendo una nuova chiave al file
Info.plist
:- Chiave:
FirebaseCrashlyticsCollectionEnabled
- Valore:
false
- Chiave:
Attiva la raccolta per gli utenti selezionati chiamando l'override della raccolta dei dati Crashlytics in fase di runtime. Il valore di override viene mantenuto in tutti i lanci successivi dell'app, in modo che Crashlytics possa raccogliere automaticamente i report per l'utente.
Swift
Crashlytics.crashlytics().setCrashlyticsCollectionEnabled(true)
Objective-C
[[FIRCrashlytics crashlytics] setCrashlyticsCollectionEnabled:YES];
Se l'utente in un secondo momento disattiva la raccolta dei dati, puoi trasmettere
false
come valore di override, che verrà applicato al successivo avvio dell'app da parte dell'utente e verrà mantenuto per tutti gli avvii successivi.
Gestire i dati di Crash Insights
Gli insight sugli arresti anomali ti aiutano a risolvere i problemi confrontando le analisi dello stack anonimizzate con quelle di altre app Firebase e comunicandoti se il tuo problema fa parte di una tendenza più ampia. Per molti problemi, Crash Insights fornisce anche risorse per aiutarti a eseguire il debug dell'arresto anomalo.
Crash Insights utilizza i dati sugli arresti anomali aggregati per identificare le tendenze comuni di stabilità. Se preferisci non condividere i dati della tua app, puoi disattivare Crash Insights dal menu Crash Insights nella parte superiore dell'elenco dei problemi di Crashlytics nella console Firebase.