Rétentatives et délais - AWS SDK for .NET

Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.

Rétentatives et délais

Vous AWS SDK for .NET permet de configurer le nombre de tentatives et les valeurs de délai d'expiration pour les requêtes HTTP adressées aux AWS services. Si les valeurs par défaut concernant les nouvelles tentatives et les délais d'expiration ne conviennent pas à votre application, vous pouvez les ajuster selon vos besoins spécifiques, mais il est important de comprendre en quoi le comportement de votre application en sera affecté.

Pour déterminer quelles valeurs utiliser pour les nouvelles tentatives et les délais d'expiration, prenez en compte les éléments suivants :

  • Comment l'application AWS SDK for .NET et votre application doivent-elles réagir lorsque la connectivité réseau se dégrade ou qu'un AWS service est inaccessible ? Souhaitez-vous que l'appel échoue rapidement ou est-il indiqué que l'appel continue de faire l'objet de nouvelles tentatives en votre nom ?

  • Votre application est-elle une application ou un site web orienté vers l'utilisateur qui doit être réactive ou s'agit-il d'une tâche de traitement en arrière plan qui tolère davantage les latences accrues ?

  • L'application est-elle déployée sur un réseau fiable à faible latence ou est-elle déployée sur un site distant avec une connectivité peu fiable ?

Nouvelle tentative

Présentation

Ils AWS SDK for .NET peuvent réessayer les demandes qui échouent en raison d'un ralentissement côté serveur ou d'une interruption de connexion. Il existe deux propriétés des classes de configuration de service que vous pouvez utiliser pour spécifier le comportement d'un client de service en cas de nouvelle tentative. Les classes de configuration de service héritent de ces propriétés de l'abstrait Amazon.Runtime. ClientConfigclasse de l'AWS SDK for .NETAPI Reference :

  • RetryModespécifie l'un des trois modes de nouvelle tentative définis dans Amazon.Runtime. RequestRetryModeénumération.

    La valeur par défaut de votre application peut être contrôlée à l'aide de la variable d'AWS_RETRY_MODEenvironnement ou du paramètre retry_mode dans le fichier de configuration partagéAWS.

  • MaxErrorRetryindique le nombre de tentatives autorisées au niveau du client de service ; le SDK réessaie l'opération le nombre de fois spécifié avant d'échouer et de lancer une exception.

    La valeur par défaut de votre application peut être contrôlée à l'aide de la variable d'AWS_MAX_ATTEMPTSenvironnement ou du paramètre max_attempts du fichier de AWS configuration partagé.

Les descriptions détaillées de ces propriétés se trouvent dans le résumé Amazon.Runtime. ClientConfigclasse de l'AWS SDK for .NETAPI Reference. Chaque valeur de RetryMode correspond par défaut à une valeur particulière deMaxErrorRetry, comme indiqué dans le tableau suivant.

RetryMode Corresponding MaxErrorRetry (Amazon DynamoDB) Corresponding MaxErrorRetry (all others)
Legacy 10 4
Standard 10 2
Adaptive (experimental) 10 2

Attitude

Quand votre candidature démarre

Lorsque votre application démarre, les valeurs par défaut pour RetryMode et MaxErrorRetry sont configurées par le SDK. Ces valeurs par défaut sont utilisées lorsque vous créez un client de service, sauf si vous spécifiez d'autres valeurs.

  • Si les propriétés ne sont pas définies dans votre environnement, la valeur par défaut RetryMode est configurée comme Legacy et la valeur par défaut pour MaxErrorRetry est configurée avec la valeur correspondante du tableau précédent.

  • Si le mode de nouvelle tentative a été défini dans votre environnement, cette valeur est utilisée par défaut pourRetryMode. La valeur par défaut pour MaxErrorRetry est configurée avec la valeur correspondante du tableau précédent, sauf si la valeur pour les erreurs maximales a également été définie dans votre environnement (décrit ci-dessous).

  • Si la valeur du nombre maximal d'erreurs a été définie dans votre environnement, cette valeur est utilisée par défaut pourMaxErrorRetry. Amazon DynamoDB fait exception à cette règle ; la valeur DynamoDB par défaut MaxErrorRetry pour est toujours la valeur du tableau précédent.

Pendant l'exécution de votre application

Lorsque vous créez un client de service, vous pouvez utiliser les valeurs par défaut pour RetryMode etMaxErrorRetry, comme décrit précédemment, ou vous pouvez spécifier d'autres valeurs. Pour spécifier d'autres valeurs, créez et incluez un objet de configuration de service tel que AmazonDynamoDBConfig ou AmazonSQSConfig lorsque vous créez le client de service.

Ces valeurs ne peuvent pas être modifiées pour un client de service une fois celui-ci créé.

Considérations

Lorsqu'une nouvelle tentative a lieu, la latence de votre demande augmente. Vous devez configurer les nouvelles tentatives en fonction des limites de votre application en termes de latence totale des demandes et de taux d'erreur.

Délais

Vous AWS SDK for .NET permet de configurer le délai d'expiration de la demande et les valeurs du délai de lecture/écriture du socket au niveau du client de service. Ces valeurs sont spécifiées dans Timeout et dans les ReadWriteTimeout propriétés du résumé Amazon.Runtime. ClientConfigclasse. Ces valeurs sont transmises sous forme de ReadWriteTimeout propriétés Timeout et des HttpWebRequestobjets créés par l'objet client du AWS service. La valeur par défaut de Timeout est de 100 secondes et celle de ReadWriteTimeout est de 300 secondes.

Lorsque votre réseau présente une latence élevée ou qu'une opération fait l'objet d'une nouvelle tentative du fait de certaines conditions, un long délai d'expiration et un nombre élevé de nouvelles tentatives peuvent donner l'impression que certaines opérations du kit SDK ne répondent pas.

Note

La version AWS SDK for .NET qui cible la bibliothèque de classes portable (PCL) utilise la HttpClientclasse au lieu de la HttpWebRequest classe et ne prend en charge que la propriété Timeout.

Vous trouverez ci-dessous les exceptions aux valeurs de délai d'expiration par défaut. Ces valeurs sont remplacées lorsque vous définissez explicitement les valeurs de délai d'expiration.

Exemple

L'exemple suivant vous montre comment spécifier le mode de nouvelle tentative standard, un maximum de 3 tentatives, un délai d'expiration de 10 secondes et un délai de lecture/écriture de 10 secondes (le cas échéant). Le constructeur AmazonS3Client reçoit un objet AmazonS3Config.

var s3Client = new AmazonS3Client( new AmazonS3Config { Timeout = TimeSpan.FromSeconds(10), // NOTE: The following property is obsolete for // versions of the AWS SDK for .NET that target .NET Core. ReadWriteTimeout = TimeSpan.FromSeconds(10), RetryMode = RequestRetryMode.Standard, MaxErrorRetry = 3 });