Sun Java System Application Server Enterprise Edition 8.2 高可用性管理指南

應用程式伺服器如何提供高可用性

Application Server 經由以下子元件和功能提供高可用性:

負載平衡外掛程式

負載平衡外掛程式接受 HTTP / HTTPS 請求,然後將這些請求轉寄至叢集中的應用程式伺服器實例。如果實例出現故障,變得不可用 (因為網路故障) 或無回應,負載平衡器即會將請求重新導向至現有的可用機器。負載平衡器還可以識別出現故障的實例是否回復,並相應地重新分配負載。Application Server Enterprise Edition 和 Standard Edition 提供適用於 Sun Java System Web Server、Apache Web Server 以及 Microsoft Internet Information Server 的負載平衡外掛程式。

透過在多台實體機器間分配工作負荷量,負載平衡器會提昇整體系統流量。負載平衡器還透過 HTTP 請求的容錯移轉提供更高的可用性。若要使 HTTP 階段作業資訊具有持續性,必須配置HTTP 階段作業持續性。

對於簡單且無狀態的應用程式,負載平衡的叢集可能已足夠。但是,對於具有階段作業狀態的任務關鍵性應用程式,請將負載平衡叢集與 HADB 配合使用。

參與負載平衡的伺服器實例和叢集具有同質環境。這通常表示伺服器實例參照相同的伺服器配置,可以存取相同的實體資源,並部署相同的應用程式。同質環境確保故障前後,負載平衡器均始終在叢集使用中的實例間平均分配負載。

如需有關配置負載平衡和容錯移轉的資訊,請參閱第 5 章, 配置 HTTP 負載平衡

高可用性資料庫

Application Server Enterprise Edition 提供高可用性資料庫 (HADB),用於 HTTP 階段作業和有狀態階段作業 Bean 資料的高可用性儲存。HADB 旨在透過負載平衡、容錯移轉和狀態回復支援高達 99.999% 的服務和資料可用性。通常必須獨立於 Application Server 來配置和管理 HADB。

Application Server 不承擔狀態管理職責,這具有顯著優勢。Application Server 實例的所有時間都在充當可延伸的高效能應用程式容器,將狀態複製工作委託給外部高可用性狀態服務。由於採用此鬆耦合架構,因此可以非常輕鬆地將 Application Server 實例增加至叢集或從叢集中刪除。HADB 狀態複製服務可以獨立延伸,以取得最佳可用性和效能。如果 Application Server 實例還執行複製,J2EE 應用程式的效能可能會降低,並且資源回收暫停時間也可能會變長。

如需有關規劃和設定應用程式伺服器安裝,以透過 HADB 實現高可用性 (包括決定硬體配置、調整大小和拓樸) 的資訊,請參閱「Sun Java System Application Server Enterprise Edition 8.2 Deployment Planning Guide」中的「Planning for Availability」「Sun Java System Application Server Enterprise Edition 8.2 Deployment Planning Guide」中的第 3 章「Selecting a Topology」

高可用性叢集

叢集是 Application Server 實例集合,這些實例共同做為一個邏輯實體工作。叢集為一個或多個 J2EE 應用程式提供了執行階段環境。高可用性叢集將狀態複製服務與叢集和負載平衡器整合。

使用叢集可提供以下優勢:

叢集中的所有實例:

網域中的每一個叢集都具有唯一的名稱;此外,該名稱在所有節點代理程式名稱、伺服器實例名稱、叢集名稱和配置名稱中也必須是唯一的。此名稱不能為 domain。您在叢集上執行的作業 (例如,部署應用程式和建立資源) 與在非叢集伺服器實例上執行之作業相同。

叢集和配置

叢集的設定取自已命名的配置 (可能能夠與其他叢集共用)。不與其他伺服器實例或叢集共用配置的叢集稱之為具有獨立配置。依預設,此配置的名稱為 cluster_name -config,其中,cluster_name 為叢集的名稱。

與其他叢集或實例共用配置的叢集稱之為具有共用配置

叢集、實例、階段作業和負載平衡

叢集、伺服器實例、負載平衡器和階段作業相互關係如下:

因此,對於叢集中的伺服器實例,叢集充當的是階段作業容錯移轉的安全邊界。在 Application Server 中,可以使用負載平衡器和升級元件,而不使服務受到任何損失。