Cette page explique comment utiliser la console Google Cloud et Google Cloud CLI pour configurer des règles de durée de vie (TTL). Avant de lire cette page, vous devez comprendre le modèle de données du mode Datastore.
Présentation du délai avant expiration
Utilisez des règles de valeur TTL pour supprimer automatiquement les données obsolètes de vos bases de données. Une règle TTL désigne une propriété donnée comme délai d'expiration pour les entités d'un type donné. Avec la valeur TTL, vous pouvez réduire les coûts de stockage en supprimant les données obsolètes. Les données sont généralement supprimées dans les 24 heures suivant leur date d'expiration.
Tarifs
Les opérations de suppression TTL sont comptabilisées dans les coûts de suppression d'entités. Pour connaître le prix des opérations de suppression, consultez Tarifs de Firestore en mode Datastore.
Limites et contraintes
- Vous ne pouvez marquer qu'une seule propriété par type comme propriété TTL.
- Vous pouvez définir jusqu'à 500 règles TTL.
Suppression de la valeur TTL
Voici les principaux comportements de la suppression basée sur le TTL :
La suppression via le TTL n'est pas un processus instantané. Les entités expirées continuent d'apparaître dans les requêtes et les demandes de recherche jusqu'à ce que le processus TTL les supprime réellement. Le TTL privilégie la réduction du coût total de possession pour les suppressions au détriment de la rapidité de suppression. Les données sont généralement supprimées dans les 24 heures suivant leur date d'expiration.
La suppression d'une entité via le TTL n'entraîne pas la suppression de ses entités descendantes.
Si vous appliquez une règle TTL à un type existant, toutes les données expirées selon la nouvelle règle TTL seront supprimées de manière groupée. Notez que cette suppression groupée n'est pas non plus instantanée et dépend de la quantité de données existantes pour ce type.
Si une entité a une heure d'expiration passée et que vous ajoutez une nouvelle règle TTL au type, l'entité sera supprimée dans les 24 heures suivant la fin de la configuration et l'activation de la règle TTL.
La valeur TTL ne supprime pas nécessairement les entités dans l'ordre de leur date d'expiration.
Les suppressions ne sont pas effectuées de manière transactionnelle. Les entités ayant la même date d'expiration ne sont pas nécessairement supprimées en même temps. Si vous avez besoin de ce comportement, effectuez les suppressions à l'aide d'une bibliothèque cliente.
Le mode Datastore respecte toujours le dernier champ TTL pour déterminer l'expiration. Par exemple, si le champ TTL d'une entité expirée, mais pas encore supprimée, est mis à jour à une date ultérieure, l'entité ne sera pas expirée et la nouvelle date sera utilisée.
Le mode Datastore n'expire un document que lorsque le champ TTL est défini sur un type
Timestamp
. Si vous ne définissez pas le champ ou si vous lui attribuez une valeur telle quenull
, vous pouvez désactiver les expirations pour chaque document.La valeur TTL est conçue pour minimiser l'impact sur les autres activités de base de données. Les suppressions déclenchées par le TTL sont traitées avec une priorité plus faible. D'autres stratégies sont également en place pour lisser les pics de trafic liés aux suppressions déclenchées par la valeur TTL.
Propriétés et index TTL
Une propriété TTL peut être indexée ou non. Toutefois, comme une propriété TTL est un code temporel, l'indexation de la propriété peut affecter les performances à des taux de trafic plus élevés. L'indexation d'une propriété d'horodatage ne respecte pas les bonnes pratiques et peut créer des points chauds. Les hotspots sont des taux de lecture, d'écriture et de suppression élevés pour une plage de clés restreinte.
Par défaut, Datastore crée un index intégré pour toutes les propriétés. Vous pouvez exclure une propriété des index pour désactiver les index sur une propriété TTL.
Autorisations
Le compte principal qui configure une stratégie TTL doit disposer de l'autorisation suivante dans le projet :
- Pour afficher les règles TTL, vous devez disposer des autorisations
datastore.indexes.list
etdatastore.indexes.get
. - Pour modifier les règles TTL, vous devez disposer de l'autorisation
datastore.indexes.update
. - Pour vérifier l'état des opérations TTL, vous devez disposer des autorisations
datastore.operations.list
etdatastore.operations.get
.
Pour connaître les rôles qui attribuent ces autorisations, consultez Rôles Identity and Access Management pour Datastore.
Avant de commencer
Avant d'utiliser la gcloud CLI pour gérer les règles TTL, exécutez la commande gcloud components update
pour mettre à jour les composants vers la dernière version disponible :
gcloud components update
Créer une règle TTL
Lorsque vous créez une règle TTL, vous désignez une propriété d'entité comme heure d'expiration pour les entités d'un type. La règle TTL s'applique au type spécifié dans tous les espaces de noms.
La valeur TTL utilise une propriété spécifiée pour identifier les entités pouvant être supprimées. Cette propriété TTL doit être de type Date and time
. Vous pouvez sélectionner une propriété existante ou en désigner une que vous prévoyez d'ajouter ultérieurement.
Avant de définir la valeur de la propriété TTL, tenez compte des points suivants :
La valeur de la propriété TTL peut être une heure future, actuelle ou passée. Si la valeur est une heure passée, l'entité peut être supprimée immédiatement. Par exemple, vous pouvez créer une règle TTL avec la propriété
expireAt
, que vous ajoutez ensuite aux entités existantes.Si vous utilisez un autre type de données ou si vous ne définissez pas la valeur de la propriété TTL, le TTL sera désactivé pour l'entité individuelle.
Pour créer une règle TTL :
Console Google Cloud
Dans la console Google Cloud , accédez à la page Bases de données.
Sélectionnez la base de données requise dans la liste des bases de données.
Dans le menu de navigation, cliquez sur Durée de vie.
Cliquez sur Créer une règle.
Saisissez un nom de type et un nom de propriété d'horodatage.
Cliquez sur Créer.
La console revient à la page Délai avant expiration. Si l'opération démarre correctement, la page ajoute une entrée au tableau des règles TTL. En cas d'échec, la page affiche un message d'erreur.
gcloud
-
In the Google Cloud console, activate Cloud Shell.
At the bottom of the Google Cloud console, a Cloud Shell session starts and displays a command-line prompt. Cloud Shell is a shell environment with the Google Cloud CLI already installed and with values already set for your current project. It can take a few seconds for the session to initialize.
Utilisez la commande
firestore fields ttls update
pour configurer une règle de TTL. Ajoutez l'indicateur--async
pour empêcher gcloud CLI d'attendre la fin de l'opération.gcloud firestore fields ttls update ttl_field --collection-group=collection_group_name --enable-ttl
Même sur une base de données vide, l'activation d'une règle TTL peut prendre 10 minutes ou plus. Lorsque vous lancez une opération, la fermeture du terminal n'annule pas l'opération.
Afficher les règles TTL
Pour afficher les règles TTL et leur état, procédez comme suit.
Console Google Cloud
Dans la console Google Cloud , accédez à la page Bases de données.
Sélectionnez la base de données requise dans la liste des bases de données.
Dans le menu de navigation, cliquez sur Durée de vie.
La console liste les règles TTL de votre base de données et inclut l'état de chacune d'elles.
gcloud
-
In the Google Cloud console, activate Cloud Shell.
At the bottom of the Google Cloud console, a Cloud Shell session starts and displays a command-line prompt. Cloud Shell is a shell environment with the Google Cloud CLI already installed and with values already set for your current project. It can take a few seconds for the session to initialize.
Utilisez la commande
firestore fields ttls list
pour configurer une règle de TTL. La commande suivante liste toutes les règles TTL.gcloud firestore fields ttls list
Pour lister les règles TTL d'un type spécifique, utilisez la commande suivante :
gcloud firestore fields ttls list --collection-group=collection_group_name
Afficher les détails de l'opération
Vous pouvez utiliser la gcloud CLI pour afficher plus de détails sur une règle TTL à l'état CREATING
.
Utilisez la commande operations list
pour afficher toutes les opérations en cours et terminées récemment :
gcloud firestore operations list
La réponse inclut une estimation de la progression de l'opération.
Désactiver une règle TTL
Suivez les étapes ci-dessous pour désactiver une règle TTL.
Console Google Cloud
Dans la console Google Cloud , accédez à la page Bases de données.
Sélectionnez la base de données requise dans la liste des bases de données.
Dans le menu de navigation, cliquez sur Durée de vie.
Dans le tableau des règles TTL, recherchez la ligne correspondant à la règle TTL. Dans cette ligne du tableau, cliquez sur le bouton Supprimer (icône en forme de corbeille).
Confirmez l'opération en cliquant sur Supprimer.
La console revient à la page Délai avant expiration. En cas de succès, Datastore supprime la règle TTL de la table.
gcloud
-
In the Google Cloud console, activate Cloud Shell.
At the bottom of the Google Cloud console, a Cloud Shell session starts and displays a command-line prompt. Cloud Shell is a shell environment with the Google Cloud CLI already installed and with values already set for your current project. It can take a few seconds for the session to initialize.
Utilisez la commande
firestore fields ttls update
pour configurer une règle de TTL. Ajoutez l'indicateur--async
pour empêcher gcloud CLI d'attendre la fin de l'opération.gcloud firestore fields ttls update ttl_field --collection-group=collection_group_name --disable-ttl
Surveiller les suppressions de valeurs TTL
Vous pouvez utiliser Cloud Monitoring pour afficher les métriques sur les suppressions basées sur le TTL. Datastore fournit les métriques suivantes pour le TTL :
datastore.googleapis.com/entity/ttl_deletion_count | Nombre de suppressions TTL |
Nombre total d'entités supprimées par les règles TTL. |
datastore.googleapis.com/entity/ttl_expiration_to_deletion_delays | Délai entre l'expiration de la valeur TTL et la suppression |
Temps écoulé entre l'expiration d'une entité en vertu d'une règle TTL et sa suppression effective. |
Pour configurer un tableau de bord avec des métriques Datastore, consultez Gérer les tableaux de bord personnalisés et Ajouter des widgets de tableau de bord.