Cette page explique comment configurer le délai maximal de commit (écriture) pour optimiser le débit en écriture dans Spanner.
Présentation
Pour assurer la cohérence des données, Spanner envoie des requêtes d'écriture à toutes les instances répliquées participant au vote dans la base de données. Ce processus de réplication peut entraîner une surcharge de calcul. Pour en savoir plus, consultez la page Réplication.
Les écritures optimisées pour le débit permettent d'amortir ces coûts de calcul en exécutant un groupe d'écritures ensemble. Pour ce faire, Spanner introduit un court délai et collecte un groupe d'écritures à envoyer aux mêmes participants votants. L'exécution des écritures de cette manière peut améliorer considérablement le débit, au prix d'une latence légèrement plus importante.
Comportement par défaut
Si vous ne définissez pas de délai de commit, Spanner peut définir un court délai à votre place s'il pense que cela amortir le coût de vos écritures.
Cas d'utilisation courants
Vous pouvez définir manuellement le délai de vos requêtes d'écriture en fonction des besoins de votre application. Vous pouvez également désactiver les délais de commit pour les applications très sensibles à la latence en définissant le délai de commit maximal sur 0 ms.
Si votre application tolère la latence et que vous souhaitez optimiser le débit, la définition d'un délai de commit plus long améliore considérablement le débit tout en entraînant une latence plus élevée pour chaque écriture. Par exemple, si vous effectuez le chargement groupé d'une grande quantité de données et que l'application ne se soucie pas de la vitesse à laquelle Spanner écrit des données individuelles, vous pouvez définir le délai de commit sur une valeur plus longue, telle que 100 ms. Nous vous recommandons de commencer par une valeur de 100 ms, puis d'ajuster la vitesse à la hausse ou à la baisse jusqu'à ce que les compromis en termes de latence et de débit répondent à vos besoins. Pour la plupart des applications, une valeur comprise entre 20 ms et 100 ms convient mieux.
Si vous avez une application sensible à la latence, Spanner l'est également par défaut. En cas de charge de travail en pics, il est possible que Spanner définisse un faible délai. Vous pouvez essayer de définir une valeur de 0 ms pour déterminer si la latence réduite au prix d'une augmentation du débit est raisonnable pour votre application.
Définir des délais de commit mixtes
Vous pouvez configurer différents délais de commit max. sur des sous-ensembles de vos écritures. Dans ce cas, Spanner utilise le délai le plus court configuré pour l'ensemble d'écritures. Toutefois, nous vous recommandons de choisir une valeur unique pour la plupart des cas d'utilisation, car cela entraîne un comportement plus prévisible.
Limites
Vous pouvez définir un délai de commit compris entre 0 et 500 ms. Si vous définissez des délais de commit supérieurs à 500 ms, une erreur est générée.
Définir le délai de commit maximal pour les requêtes de commit
Le paramètre de délai de commit maximal fait partie de la méthode CommitRequest
. Vous pouvez accéder à cette méthode à l'aide de l'API RPC, de l'API REST ou de la bibliothèque cliente Cloud Spanner.
Go
Node.js
Python
Ruby
Surveiller la latence des requêtes d'écriture
Vous pouvez surveiller l'utilisation du processeur et la latence du processeur Spanner à l'aide de la console Google Cloud. Lorsque vous définissez un délai plus long pour vos requêtes d'écriture, attendez-vous à une réduction de l'utilisation du processeur, tandis que la latence augmente. Pour en savoir plus sur la latence des requêtes Spanner, consultez la page Capturer et visualiser la latence des requêtes de l'API Spanner.