

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

# 連線至 Amazon Neptune 端點
<a name="feature-overview-endpoints"></a>

Amazon Neptune 會使用資料庫執行個體的叢集，而非單一執行個體。每個 Neptune 連線都由特定的資料庫執行個體處理。當您連線至 Neptune 叢集時，您指定的主機名稱和連接埠會指向稱為「端點」**的中繼處理常式。端點為包含主機地址和連接埠的 URL。Neptune 端點使用加密的 Transport Layer Security/Secure Sockets Layer (TLS/SSL) 連線。

Neptune 會使用端點機制來抽象化這些連線，以便您不必對主機名稱進行硬式編碼，或撰寫您自己的邏輯，在某些資料庫執行個體無法使用時重新路由連線。

使用端點，您可以將每個連線映射至適當的執行個體或執行個體群組，取決於您的使用案例。自訂端點可讓您連線至資料庫執行個體的子集。下列端點可在 Neptune 資料庫叢集中使用。

## Neptune 叢集端點
<a name="feature-overview-cluster-endpoints"></a>

叢集端點為 Neptune 資料庫叢集的端點，其會連線至該資料庫叢集目前的主要資料庫執行個體。每個 Neptune 資料庫叢集具有一個叢集端點和一個主要資料庫執行個體。

叢集端點可為資料庫叢集的讀寫連線提供容錯移轉支援。對資料庫叢集上的所有寫入操作，包括插入、更新、刪除和資料定義語言 (DDL) 變更使用叢集端點。您也可以對讀取操作 (例如查詢) 使用叢集端點。

如果資料庫叢集目前的主要資料庫執行個體失敗，Neptune 會自動容錯移轉至新的主要資料庫執行個體。容錯移轉期間，資料庫叢集會繼續從新的主要資料庫執行個體對叢集端點提供連線請求，將對服務的中斷降到最低。

以下範例說明 Neptune 資料庫叢集的叢集端點。

`mydbcluster.cluster-123456789012.us-east-1.neptune.amazonaws.com:8182`

## Neptune 讀取器端點
<a name="feature-overview-reader-endpoints"></a>

讀取器端點為 Neptune 資料庫叢集的端點，其會連線至該資料庫叢集其中一個可用的 Neptune 複本。每個 Neptune 資料庫叢集都有一個讀取器端點。如果有多個 Neptune 複本，讀取器端點會將每個連線請求導向其中一個 Neptune 複本。

讀取器端點可為資料庫叢集的唯讀連線提供循環配置資源路由。對讀取操作 (例如 查詢) 使用讀取器端點。

除非您有單一執行個體叢集 (沒有僅供讀取複本的叢集)，否則無法使用讀取器端點進行寫入作業。在這種情況下 (以及只有在這種情況下)，讀取器可以用於寫入操作以及讀取操作。

讀取器端點循環配置資源路由的運作方式是改變 DNS 項目指向的主機。每當您解析 DNS，就會取得不同的 IP，且對這些 IP 開放連線。建立連線後，所有對該連線的請求都會傳送到同一主機。用戶端必須再次建立新的連線和解析 DNS 記錄，以取得可能不同的僅供讀取複本的連線。

**注意**  
WebSockets 連線通常會維持很長一段時間。若要獲得不同的僅供讀取複本，請執行下列動作：  
確保您的用戶端於每次連線時解析 DNS 項目。
關閉連線並重新連線。

不同的用戶端軟體可能會以不同的方式解析 DNS。例如，如果您的用戶端解析 DNS，然後將 IP 用於每一個連線，則軟體會將所有請求導向單一主機。

用戶端或代理伺服器的 DNS 快取，會從快取將 DNS 名稱解析至同一個端點。這對循環配置資源路由和容錯移轉情況都構成問題。

**注意**  
停用所有 DNS 快取設定，以強制每次執行 DNS 解析。

資料庫叢集會在可用的 Neptune 複本間對讀取器端點分配連線請求。如果資料庫叢集僅包含一個主要資料庫執行個體，讀取器端點會從主要資料庫執行個體提供連接請求。如果已為該資料庫叢集建立 Neptune 複本，讀取器端點會繼續從新的 Neptune 複本對讀取器端點提供連線請求，將對服務的中斷降到最低。

下列範例說明 Neptune 資料庫叢集的讀取器端點。

`mydbcluster.cluster-ro-123456789012.us-east-1.neptune.amazonaws.com:8182`

## Neptune 執行個體端點
<a name="feature-overview-instance-endpoints"></a>

執行個體端點為 Neptune 資料庫叢集中資料庫執行個體的端點，其會連線至該特定資料庫執行個體。資料庫叢集中的每個資料庫執行個體，不論執行個體類型為何，都有自己的唯一執行個體端點。因此，資料庫叢集目前的主要資料庫執行個體有一個執行個體端點。資料庫叢集的每一個 Neptune 複本也有一個執行個體端點。

執行個體端點對資料庫叢集的連線提供直接控制，使用叢集端點或讀取器端點的案例可能不適用。例如，根據工作負載類型而定，您的用戶端應用程式可能需要精細負載平衡。在此情況下，您可以設定多個用戶端連線至資料庫叢集中的不同 Neptune 複本，以分配讀取工作負載。

下列範例說明 Neptune 資料庫叢集中資料庫執行個體的執行個體端點。

`mydbinstance.123456789012.us-east-1.neptune.amazonaws.com:8182`

## Neptune 自訂端點
<a name="feature-overview-custom-endpoints"></a>

Neptune 叢集的自訂端點代表您選擇的一組資料庫執行個體。連線至端點時，Neptune 會選擇群組的其中一個執行個體來處理連線。您可以定義此端點要參考的執行個體，並且決定端點的運作目的。

Neptune 資料庫叢集沒有自訂端點，直到您建立一個自訂端點，而且您可以為每個佈建的 Neptune 叢集建立最多五個自訂端點。

自訂端點可根據資料庫執行個體的唯讀或讀寫功能以外的準則來提供負載平衡的資料庫連線。由於連線可能前往與端點相關聯的任何資料庫執行個體，因此確定該群組內的所有執行個體分享相同的效能和記憶體容量特性。使用自訂端點時，您一般不會對該叢集使用讀取器端點。

此功能預期供具有專精類型工作負載的進階使用者使用，在其工作負載中，讓叢集中的所有 Neptune 複本保持相同並不切實際。利用自訂端點，您可以調整與每個連線搭配使用的資料庫執行個體容量。

例如，如果您定義數個自訂端點，而這些端點連線到具有不同執行個體類別的執行個體群組，則可以將效能需求不同的使用者導向至最適合其使用案例的端點。

下列範例說明 Neptune 資料庫叢集中資料庫執行個體的自訂端點：

`myendpoint.cluster-custom-123456789012.us-east-1.neptune.amazonaws.com:8182`

如需詳細資訊，請參閱[使用自訂端點](feature-custom-endpoint-membership.md)。

## Neptune 端點考量
<a name="feature-overview-endpoint-considerations"></a>

使用 Neptune 端點時，請考慮下列情況：
+ 使用執行個體端點來連接至資料庫叢集中的特定資料庫執行個體之前，請考慮改為針對資料庫叢集使用叢集端點或讀取器端點。

  叢集端點和讀取器端點提供高可用性案例的支援。如果資料庫叢集的主要資料庫執行個體失敗，Neptune 會自動容錯移轉至新的主要資料庫執行個體。它會透過將現有的 Neptune 複本提升為新的主要資料庫執行個體，或建立新的主要資料庫執行個體來完成。如果發生容錯移轉，您可以使用叢集端點重新連線至新提升或建立的主要資料庫執行個體，或使用讀取器端點重新連線至資料庫叢集中其中一個其他的 Neptune 複本。

  如果您不採取此方法，您仍可以針對預期的操作確定已連接至資料庫叢集中的正確資料庫執行個體。若要這麼做，您可以手動或以程式設計方式探索資料庫叢集中可用資料庫執行個體的結果集，並在容錯移轉之後，於使用特定資料庫執行個體的執行個體端點之前確認其執行個體類型。

  如需容錯移轉的詳細資訊，請參閱 [Neptune 資料庫叢集的容錯能力](backup-restore-overview-fault-tolerance.md)。

   
+ 讀取器端點只會將連線導向 Neptune 資料庫叢集中可用的 Neptune 複本。它不會將特定查詢導向。
**重要**  
Neptune 不會進行負載平衡。

  如果您想要平衡查詢負載以分配資料庫叢集的讀取工作負載，您必須管理您應用程式的負載。您必須使用執行個體端點直接連線到 Neptune 複本，以平衡負載。

   
+ 讀取器端點循環配置資源路由的運作方式是改變 DNS 項目指向的主機。用戶端必須建立新的連線並再次解析 DNS 紀錄，以取得可能是新的僅供讀取複本的連線。

   
+ 在容錯移轉期間，當 Neptune 複本提升為新的主要資料庫執行個體時，讀取器端點可能會短暫直接連線至資料庫叢集的新主要資料庫執行個體。