Affichez, recherchez et filtrez les journaux de requêtes Web de votre site avec Cloud Logging.

Vous pouvez associer votre projet Firebase à Cloud Logging pour afficher, rechercher et filtrer vos journaux de requêtes Web pour chacun de vos sites d'hébergement. Ces journaux proviennent du CDN automatiquement fourni par Firebase, de sorte que chaque demande adressée à votre site et les données de demande associées sont enregistrées.

Voici certaines choses que vous faites avec les journaux Cloud Logging. Visitez chaque section de cette page pour en savoir plus.

Si vous avez plusieurs sites d'hébergement dans votre projet, vous pouvez sélectionner lequel de vos sites d'hébergement exportera les journaux. Vous pouvez ensuite filtrer et visualiser vos données de journaux par site d'hébergement et même par domaine. En sélectionnant des sites d'hébergement spécifiques pour exporter les journaux, vous pouvez également contrôler la quantité de données traitées pour votre projet.

  1. Cliquez sur Lien dans la carte d'intégration Cloud Logging dans la console Firebase.

    Pour associer ou dissocier Cloud Logging, vous avez besoin des autorisations regroupées dans l'un des rôles suivants : propriétaire ou éditeur du projet ou administrateur de développement Firebase .

  2. Suivez les instructions à l'écran pour sélectionner lequel de vos sites d'hébergement doit exporter les journaux vers Cloud Logging.

    Si vous disposez déjà d'un ou plusieurs sites d'hébergement actifs, le workflow de liaison affiche un niveau d'utilisation des données estimé pour les journaux de chacun de vos sites d'hébergement. Cette valeur est estimée sur les 30 derniers jours.

Après la connexion à Cloud Logging, les journaux de toute nouvelle demande adressée à vos sites d'hébergement s'afficheront généralement dans les 30 minutes suivant la demande.

Vous pouvez également dissocier Firebase Hosting de Cloud Logging, ce qui arrête les exportations des journaux de requêtes Web vers Cloud Logging.

Surveillez votre utilisation des données pour les journaux

Après vous être connecté à Cloud Logging, vous pouvez afficher le niveau d'utilisation des données pour les journaux de vos sites d'hébergement :

Mieux comprendre votre site

L' interface Logs Viewer de la console Google Cloud propose des outils pour afficher vos journaux et données spécifiques à l'aide de requêtes et de filtres et panneaux de données intégrés. Apprenez-en davantage sur le filtrage de vos journaux avec des requêtes dans la section suivante ci-dessous.

  • D'où vient le trafic de votre site à un niveau granulaire ?
    Vous pouvez afficher des informations sur chaque demande, notamment l'adresse IP source, le référent, la ville et le statut.

  • Quand les utilisateurs visitent-ils votre site ?
    Vous pouvez utiliser le panneau Histogramme pour voir la distribution par plages de temps spécifiques. Cela peut vous donner un aperçu des pics et des baisses normaux de l'utilisation de votre application, ainsi que révéler tout pic de trafic inattendu.

  • Quelle est la répartition du statut des demandes des utilisateurs finaux ?
    Vous pouvez afficher l'état de chaque demande et même diagnostiquer les demandes qui reçoivent des erreurs. Vous pouvez filtrer vos journaux par Critical , Error ou Warning .

  • Combien de temps faut-il à votre site pour répondre à une demande ?
    Vous pouvez afficher la latence de votre site pour chaque demande en utilisant la valeur latency capturée dans chaque journal.

  • Votre site profite-t-il de la mise en cache du contenu ?
    Chaque journal contient un champ cacheHit pour vous indiquer si la ressource de votre site a été servie rapidement à partir du cache CDN de l'hébergement, ou si elle a dû effectuer le voyage complet vers le backend de l'hébergement. Cela peut vous aider à améliorer les performances de votre site Web en tirant le meilleur parti du CDN mondial de Firebase. Par exemple, vous pouvez utiliser les données pour affiner les habitudes de mise en cache de vos actifs statiques et de votre contenu dynamique .

  • Quelle est la répartition du trafic vers vos différents domaines ?
    Si vous disposez de plusieurs domaines ou sites d'hébergement, vous pouvez filtrer vos journaux par domaine ou par site. Cela vous permet de voir comment votre trafic est réparti. Lorsque vous filtrez par domaine, vous pouvez savoir quel domaine est le plus fréquemment visité.

Filtrez vos journaux avec des requêtes

Pour savoir comment filtrer vos journaux avec des requêtes, consultez Exemples de requêtes à l'aide de la visionneuse de journaux et Création de requêtes de journaux . Le tableau ci-dessous décrit les champs disponibles pour ces requêtes.

Pour l'hébergement, voici quelques filtres initiaux pour une requête :

  • Ressource ( resource.type ) — firebase_domain (domaine du site d'hébergement Firebase)
  • Nom du journal ( logName ) — webrequests (hébergement Firebase)

Chaque entrée de journal a une structure prédéfinie et des champs interrogeables (voir LogEntry ). Pour l'hébergement, certains champs sont standard pour une requête HTTP, mais il existe d'autres valeurs de champ qui proviennent du traitement que l'hébergement exécute sur chaque requête.

Champ Description
Firebase Hosting stocke les champs suivants dans l'objet httpRequest de l'entrée de journal.
Ces champs sont définis dans la spécification HTTP.
cacheHit Si le CDN d'hébergement disposait ou non de la ressource de la réponse en cache
latency La durée de la requête, en secondes avec le suffixe s (par exemple, 1.256s )
protocol Le protocole utilisé pour la requête (par exemple, HTTP/1.1 , HTTP/2 , websocket )
referer L'adresse de la page Web précédente à partir de laquelle un lien vers la page actuellement demandée a été suivi (si présent)
remoteIp L'adresse IP du client d'origine pour la demande
requestMethod La méthode de requête ( GET , POST , PUT , etc.)
requestSize La taille de la requête en octets
requestUrl L'URL complète de la demande (par exemple,
https://foo.web.app/bar ou https://custom.domain.com?query=param )
responseSize La taille de la réponse HTTP en octets
serverIp pas peuplée
status L'état de la réponse HTTP (par exemple, 200 ou 404 )
userAgent L'en-tête user-agent de la requête
Firebase Hosting stocke des champs supplémentaires dans l'objet jsonPayload de l'entrée de journal.
acceptEncoding (à partir de la requête HTTP) Quel codage de contenu, généralement un algorithme de compression, pris en charge par le client (par exemple, gzip ou compress )
billable Si votre projet a été facturé ou non pour la demande
customDomain Si la demande a été faite ou non sur un domaine personnalisé
hostname Le nom d'hôte sur lequel la demande a été faite
remoteIpCountry Le pays d'origine de la demande
remoteIpCity La ville d'origine de la demande

Utiliser des métriques basées sur les journaux

Vous pouvez afficher et créer des métriques basées sur les journaux , puis utiliser ces métriques dans Cloud Monitoring pour créer des graphiques et des stratégies d'alerte.

  • Tirez parti des métriques système prédéfinies qui sont automatiquement enregistrées, telles que le nombre d’événements de journalisation survenus au cours d’une période spécifique.

  • Créez des métriques définies par l'utilisateur pour votre projet. Vous pouvez compter le nombre d'entrées de journal qui correspondent à une requête donnée ou suivre des valeurs particulières avec les entrées de journal correspondantes. Vous pouvez filtrer à l'aide d'expressions régulières.

  • Utilisez Cloud Monitoring pour enregistrer le nombre d'entrées de journal contenant des messages particuliers ou extraire les informations de latence signalées dans les entrées de journal. Vous pouvez ensuite utiliser ces métriques dans des graphiques et des stratégies d'alerte.

Firebase Hosting génère également les métriques de journalisation spécifiques à l'hébergement suivantes. Ces métriques ne sont pas spécifiques à une entrée de journal mais plutôt au site d'hébergement spécifique dans son ensemble.

  • log_bytes : nombre total d'octets d'utilisation de données pour chaque site

  • response_count : nombre total de réponses écrites pour le site

    Cette métrique inclut le champ de statut HTTP, vous pouvez donc tracer les réponses HTTP par statut (à titre d'exemple).

Exporter les journaux vers d'autres outils Google Cloud

Vous pouvez également exporter les journaux de votre site vers d'autres outils Google Cloud, comme Cloud Monitoring ou BigQuery, par exemple :

  • À l'aide de Cloud Monitoring , vous pouvez créer des métriques basées sur les journaux que vous pouvez utiliser dans des graphiques et des stratégies d'alerte.

  • Avec BigQuery , vous pouvez effectuer l'une des opérations suivantes :

    • Utilisez Data Studio pour générer des tableaux de bord de vos données d'hébergement.
    • Exécutez des requêtes pour obtenir plus d’informations sur vos demandes (taille moyenne des réponses, réussites ou échecs du cache, etc.).
    • Découvrez quelles URL vos utilisateurs demandent réellement.
    • Combinez vos données d'hébergement avec d'autres données Firebase que vous avez exportées vers BigQuery et interrogez-les de nouvelles manières.