處理 中的錯誤 AWS SDK for Java 2.x - AWS SDK for Java 2.x

本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。

處理 中的錯誤 AWS SDK for Java 2.x

了解 AWS SDK for Java 2.x 拋出例外狀況的方式和時間,對於使用 SDK 建置高品質應用程式至關重要。以下章節說明開發套件會擲回的不同例外狀況案例,以及如何正確處理這些狀況。

為什麼要取消勾選例外狀況?

由於這些原因, AWS SDK for Java 使用執行時間 (或未核取) 例外狀況,而非核取的例外狀況:

  • 為了讓開發人員能夠更精確的控制他們想處理的錯誤,而非強制他們處理不在乎的例外情況 (因而使得程式碼過於冗長)

  • 為了避免大型應用程式中已檢查例外狀況的固有擴展性問題

一般而言,已檢查例外狀況在小規模上可運作良好,但會隨著應用程式增長且更複雜而變得棘手。

AwsServiceException (和子類別)

AwsServiceException 是您在使用 時會遇到的最常見例外狀況 AWS SDK for Java。 AwsServiceException 是較一般 SdkServiceException 的子類別。 AwsServiceException代表來自 的錯誤回應 AWS 服務。例如,如果您嘗試終止不存在的 Amazon EC2 執行個體, Amazon EC2 會傳回錯誤回應,而該錯誤回應的所有詳細資訊都會包含在AwsServiceException擲出的 中。

當您遇到 時AwsServiceException,您知道您的請求已成功傳送到 , AWS 服務 但無法成功處理。這可能是因為請求參數中的錯誤,或因為服務端的問題。

AwsServiceException 為您提供資訊,例如:

  • 傳回 HTTP 狀態碼

  • 傳回的 AWS 錯誤碼

  • AwsErrorDetails 類別中服務的詳細錯誤訊息

  • AWS 失敗請求的請求 ID

在大多數情況下,AwsServiceException會擲回服務特定的 子類別,以允許開發人員精細控制透過擷取區塊處理錯誤案例。適用於 AwsServiceException 的 Java SDK API 參考會顯示大量AwsServiceException子類別。使用子類別連結向下切入,以查看服務擲回的精細例外狀況。

例如,下列 SDK API 參考的連結會顯示幾個常見的例外狀況階層 AWS 服務。每個頁面上顯示的子類別清單會顯示您的程式碼可以捕捉的特定例外狀況。

若要進一步了解例外狀況,請檢查 AwsErrorDetails 物件errorCode上的 。您可以使用 errorCode值來查詢服務指南 API 中的資訊。例如,如果 S3Exception 被抓到且AwsErrorDetails#errorCode()值為 InvalidRequest,請使用 Amazon S3 API 參考中的錯誤代碼清單來查看更多詳細資訊。

SdkClientException

SdkClientException 指出在嘗試傳送請求至 或嘗試剖析回應 AWS 時,Java 用戶端程式碼內發生問題 AWS。SdkClientException 通常比 更嚴重SdkServiceException,並指出導致用戶端無法對 AWS 服務進行服務呼叫的主要問題。例如,當您嘗試呼叫其中一個用戶端上的 操作時,SdkClientException如果沒有可用的網路連線, 會 AWS SDK for Java 擲回 。

例外狀況和重試行為

適用於 Java 的 SDK 會針對數個用戶端例外狀況及其從 AWS 服務 回應接收的 HTTP 狀態碼,重試請求。這些錯誤會做為RetryMode服務用戶端預設使用的舊版的一部分來處理。的 Java API 參考RetryMode說明您可以設定 模式的各種方式。

若要自訂觸發自動重試的例外狀況和 HTTP 狀態碼,請使用新增 RetryOnExceptionsConditionRetryOnStatusCodeCondition執行個體RetryPolicy的 來設定您的服務用戶端。