Bevor Sie beginnen
Falls noch nicht geschehen, fügen Sie Firebase zu Ihrem Apple-Projekt hinzu .
Schritt 1 : Fügen Sie Ihrer App Leistungsüberwachung hinzu
Nachdem Sie das Performance Monitoring SDK hinzugefügt haben, beginnt Firebase automatisch mit der Erfassung von Daten für die Bildschirmwiedergabe Ihrer App, Daten im Zusammenhang mit dem Lebenszyklus Ihrer App (z. B. App-Startzeit ) und Daten für HTTP/S-Netzwerkanfragen .
Verwenden Sie Swift Package Manager, um Firebase-Abhängigkeiten zu installieren und zu verwalten.
- Navigieren Sie in Xcode bei geöffnetem App-Projekt zu File > Add Packages .
- Wenn Sie dazu aufgefordert werden, fügen Sie das Firebase Apple Platforms SDK-Repository hinzu:
- Wählen Sie die Leistungsüberwachungsbibliothek.
- Fügen Sie das Flag
-ObjC
zum Abschnitt „Andere Linker-Flags“ der Build-Einstellungen Ihres Ziels hinzu. - Wenn Sie fertig sind, beginnt Xcode automatisch mit der Auflösung und dem Herunterladen Ihrer Abhängigkeiten im Hintergrund.
https://github.com/firebase/firebase-ios-sdk.git
Als nächstes konfigurieren Sie das Firebase-Modul:
- Importieren Sie das
FirebaseCore
Modul in IhrUIApplicationDelegate
sowie alle anderen Firebase-Module, die Ihr App-Delegierter verwendet. Um beispielsweise Cloud Firestore und Authentifizierung zu verwenden:SwiftUI
import SwiftUI import FirebaseCore import FirebaseFirestore import FirebaseAuth // ...
Schnell
import FirebaseCore import FirebaseFirestore import FirebaseAuth // ...
Ziel c
@import FirebaseCore; @import FirebaseFirestore; @import FirebaseAuth; // ...
- Konfigurieren Sie eine gemeinsam genutzte
FirebaseApp
Instanz in derapplication(_:didFinishLaunchingWithOptions:)
Methode Ihres App-Delegierten:SwiftUI
// Use Firebase library to configure APIs FirebaseApp.configure()
Schnell
// Use Firebase library to configure APIs FirebaseApp.configure()
Ziel c
// Use Firebase library to configure APIs [FIRApp configure];
- Wenn Sie SwiftUI verwenden, müssen Sie einen Anwendungsdelegaten erstellen und ihn über
UIApplicationDelegateAdaptor
oderNSApplicationDelegateAdaptor
an IhreApp
Struktur anhängen. Sie müssen auch das Swizzling von App-Delegierten deaktivieren. Weitere Informationen finden Sie in den SwiftUI-Anweisungen .SwiftUI
@main struct YourApp: App { // register app delegate for Firebase setup @UIApplicationDelegateAdaptor(AppDelegate.self) var delegate var body: some Scene { WindowGroup { NavigationView { ContentView() } } } }
Kompilieren Sie Ihre App neu.
Schritt 2 : Leistungsereignisse für die erste Datenanzeige generieren
Firebase beginnt mit der Verarbeitung der Ereignisse, wenn Sie das SDK erfolgreich zu Ihrer App hinzugefügt haben. Wenn Sie noch lokal entwickeln, interagieren Sie mit Ihrer App, um Ereignisse für die erste Datenerfassung und -verarbeitung zu generieren.
Entwickeln Sie Ihre App mithilfe eines Simulators oder Testgeräts weiter.
Generieren Sie Ereignisse, indem Sie Ihre App mehrmals zwischen Hintergrund und Vordergrund wechseln, mit Ihrer App interagieren, indem Sie über Bildschirme navigieren, und/oder Netzwerkanfragen auslösen.
Gehen Sie zum Performance- Dashboard der Firebase-Konsole. Innerhalb weniger Minuten sollten Sie Ihre erste Datenanzeige sehen.
Wenn Ihre ursprünglichen Daten nicht angezeigt werden, lesen Sie die Tipps zur Fehlerbehebung .
Schritt 3 : (Optional) Protokollmeldungen für Leistungsereignisse anzeigen
Aktivieren Sie die Debug-Protokollierung wie folgt:
- Wählen Sie in Xcode (mindestens Version 14.1) Produkt > Schema > Schema bearbeiten aus.
- Wählen Sie im linken Menü „Ausführen“ und dann die Registerkarte „Argumente“ .
- Fügen Sie im Abschnitt „Beim Start übergebene Argumente
-FIRDebugEnabled
hinzu.
Überprüfen Sie Ihre Protokollnachrichten auf etwaige Fehlermeldungen.
Performance Monitoring markiert seine Protokollnachrichten mit
Firebase/Performance
, sodass Sie Ihre Protokollnachrichten filtern können.Suchen Sie nach den folgenden Protokolltypen, die darauf hinweisen, dass Performance Monitoring Leistungsereignisse protokolliert:
-
Logging trace metric: TRACE_NAME , FIREBASE_PERFORMANCE_CONSOLE_URL
-
Logging network request trace: URL
-
Klicken Sie auf die URL, um Ihre Daten in der Firebase-Konsole anzuzeigen. Es kann einen Moment dauern, bis die Daten im Dashboard aktualisiert werden.
Wenn Ihre App keine Leistungsereignisse protokolliert, lesen Sie die Tipps zur Fehlerbehebung .
Schritt 4 : (Optional) Fügen Sie eine benutzerdefinierte Überwachung für bestimmten Code hinzu
Um Leistungsdaten zu überwachen, die einem bestimmten Code in Ihrer App zugeordnet sind, können Sie benutzerdefinierte Code-Traces instrumentieren.
Mit einem benutzerdefinierten Code-Trace können Sie messen, wie lange Ihre App benötigt, um eine bestimmte Aufgabe oder eine Reihe von Aufgaben abzuschließen, z. B. das Laden einer Reihe von Bildern oder das Abfragen Ihrer Datenbank. Die Standardmetrik für einen benutzerdefinierten Code-Trace ist seine Dauer. Sie können jedoch auch benutzerdefinierte Metriken hinzufügen, z. B. Cache-Treffer und Speicherwarnungen.
In Ihrem Code definieren Sie den Anfang und das Ende eines benutzerdefinierten Code-Trace (und fügen alle gewünschten benutzerdefinierten Metriken hinzu), indem Sie die vom Performance Monitoring SDK bereitgestellte API verwenden.
Besuchen Sie „Überwachung für bestimmten Code hinzufügen“, um mehr über diese Funktionen zu erfahren und wie Sie sie Ihrer App hinzufügen können.
Schritt 5 : Stellen Sie Ihre App bereit und überprüfen Sie dann die Ergebnisse
Nachdem Sie die Leistungsüberwachung mit dem Xcode-Simulator und einem oder mehreren Testgeräten validiert haben, können Sie die aktualisierte Version Ihrer App für Ihre Benutzer bereitstellen.
Sie können Leistungsdaten im Leistungs- Dashboard der Firebase-Konsole überwachen.
Bekannte Probleme
- Bei der Leistungsüberwachung sind Kompatibilitätsprobleme mit GTMSQLite bekannt. Wir empfehlen, die Leistungsüberwachung nicht mit Apps zu verwenden, die GTMSQLite verwenden.
- Das Swizzling der Methode nach dem Aufruf
FirebaseApp.configure()
kann das Performance Monitoring SDK beeinträchtigen. - Bekannte Probleme mit dem iOS 8.0-8.2-Simulator verhindern, dass die Leistungsüberwachung Leistungsereignisse erfasst. Diese Probleme wurden im iOS 8.3 Simulator und späteren Versionen behoben.
- Verbindungen, die mithilfe
backgroundSessionConfiguration
von NSURLSession hergestellt werden, weisen längere Verbindungszeiten als erwartet auf. Diese Verbindungen werden außerhalb des Prozesses ausgeführt und die Zeitvorgaben spiegeln prozessinterne Rückrufereignisse wider.
Nächste Schritte
Überprüfen Sie das iOS-Codebeispiel zur Leistungsüberwachung auf GitHub und führen Sie es aus.
Erfahren Sie mehr über die automatisch von Performance Monitoring erfassten Daten:
- Daten zum Lebenszyklus Ihrer App, z. B. die Startzeit der App
- Daten für die Bildschirmdarstellung in Ihrer App
- Daten für HTTP/S-Netzwerkanfragen, die von Ihrer App ausgegeben werden
Sehen, verfolgen und filtern Sie Ihre Leistungsdaten in der Firebase-Konsole.
Fügen Sie Überwachung für bestimmte Aufgaben oder Arbeitsabläufe in Ihrer App hinzu, indem Sie benutzerdefinierte Code-Traces instrumentieren .