Catch up on highlights from Firebase at Google I/O 2023. Learn more

Ajouter une surveillance personnalisée pour des demandes réseau spécifiques (applications Apple et Android)

La surveillance des performances collecte des traces pour vous aider à surveiller les performances de votre application. Une trace est un rapport de données de performances capturées entre deux points dans le temps dans votre application.

Les traces de demande réseau collectées automatiquement par Performance Monitoring incluent la plupart des demandes réseau pour votre application. Cependant, certaines requêtes peuvent ne pas être signalées ou vous pouvez utiliser une bibliothèque différente pour effectuer des requêtes réseau. Dans ces cas, vous pouvez utiliser l'API de surveillance des performances pour instrumenter manuellement les traces de demande réseau personnalisées . Les suivis de demande réseau personnalisés ne sont pris en charge que pour les applications Apple et Android.

Les métriques par défaut pour une trace de demande réseau personnalisée sont les mêmes que celles des traces de demande réseau automatiquement collectées par la surveillance des performances, en particulier le temps de réponse, la taille de la charge utile de la réponse et de la demande et le taux de réussite. Les suivis de demande réseau personnalisés ne prennent pas en charge l'ajout de métriques personnalisées.

Dans votre code, vous définissez le début et la fin d'une trace de demande réseau personnalisée à l'aide des API fournies par le SDK de surveillance des performances.

Les traces de requête réseau personnalisées apparaissent dans la console Firebase à côté des requêtes réseau que Performance Monitoring capture automatiquement (dans le sous-onglet Requêtes réseau du tableau des traces).

Ajouter des suivis de demande réseau personnalisés

Utilisez l'API HTTPMetric de surveillance des performances ( Swift | Obj-C ) pour ajouter des suivis de demande réseau personnalisés afin de surveiller des demandes réseau spécifiques.

Pour instrumenter manuellement les requêtes réseau personnalisées dans Performance Monitoring, ajoutez un code similaire au suivant :

Rapide

Remarque : Ce produit Firebase n'est pas disponible sur les cibles macOS, Mac Catalyst et watchOS.
guard let metric = HTTPMetric(url: "https://www.google.com", httpMethod: .get) else { return }

metric.start()
guard let url = URL(string: "https://www.google.com") else { return }
let request: URLRequest = URLRequest(url:url)
let session = URLSession(configuration: .default)
let dataTask = session.dataTask(with: request) { (urlData, response, error) in
        if let httpResponse = response as? HTTPURLResponse {
         metric.responseCode = httpResponse.statusCode
        }
        metric.stop()
}
dataTask.resume()

Objectif c

Remarque : Ce produit Firebase n'est pas disponible sur les cibles macOS, Mac Catalyst et watchOS.
@property (nonatomic) FIRHTTPMetric *metric;

- (void)beginManualNetworkInstrumentation {
  self.metric =
      [[FIRHttpMetric alloc] initWithURL:[NSURL URLWithString:@"https://www.google.com"]
                              HTTPMethod:FIRHTTPMethodGET];

  [self.metric start];

  NSURLRequest *request =
      [NSURLRequest requestWithURL:[NSURL URLWithString:@"https://www.google.com"]];
  NSURLConnection *connection = [[NSURLConnection alloc] initWithRequest:request
                                                                delegate:self];
  [connection resume];
}

- (void)connection:(NSURLConnection *)connection
    didReceiveResponse:(NSURLResponse *) response {
  NSHTTPURLResponse* httpResponse = (NSHTTPURLResponse*)response
  self.metric.responseCode = httpResponse.statusCode;
  [self.metric stop];
}

Les suivis de demande réseau personnalisés prennent également en charge l'ajout d'attributs personnalisés ( Swift | Obj-C ), mais pas de métriques personnalisées.

Prochaines étapes

  • Configurez des alertes pour les demandes réseau qui dégradent les performances de votre application. Par exemple, vous pouvez configurer une alerte par e-mail pour votre équipe si le temps de réponse pour un modèle d'URL spécifique dépasse un seuil que vous avez défini.