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 :
-
RetryMode
spé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_MODE
environnement ou du paramètre retry_mode dans le fichier de configuration partagéAWS.
-
MaxErrorRetry
indique 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_ATTEMPTS
environnement 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 pourMaxErrorRetry
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 pour
RetryMode
. La valeur par défaut pourMaxErrorRetry
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 pour
MaxErrorRetry
. Amazon DynamoDB fait exception à cette règle ; la valeur DynamoDB par défautMaxErrorRetry
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 HttpWebRequestTimeout
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 HttpClientHttpWebRequest
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.
-
Timeout
etReadWriteTimeout
sont définis sur les valeurs maximales si la méthode appelée télécharge un flux, tel que AmazonS3Client. PutObjectAsync(), client Amazon S3. UploadPartAsync(), AmazonGlacierClient. UploadArchiveAsync(), et ainsi de suite. -
Les versions du .NET Framework cible AWS SDK for .NET ont défini
Timeout
etReadWriteTimeout
atteint les valeurs maximales pour tous les clients et objets AmazonS3Client. AmazonGlacierClient -
Les versions AWS SDK for .NET qui ciblent la bibliothèque de classes portable (PCL) et .NET Core sont définies
Timeout
sur la valeur maximale pour tous les clients et objets AmazonS3Client. AmazonGlacierClient
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 });