SOA面向服務的架構理解

来源:http://www.cnblogs.com/jiang-it/archive/2017/02/12/6389374.html
-Advertisement-
Play Games

Ø 單一應用架構 ·當網站流量很小時,只需一個應用,將所有功能都部署在一起,以減少部署節點和成本。 Ø 垂直應用架構 當訪問量逐漸增大,單一應用增加機器帶來的加速度越來越小,將應用拆成互不相干的幾個應用,以提升效率。 當訪問量逐漸增大,單一應用增加機器帶來的加速度越來越小,將應用拆成互不相干的幾個應 ...


 

Ø  單一應用架構

  • ·當網站流量很小時,只需一個應用,將所有功能都部署在一起,以減少部署節點和成本。

Ø  垂直應用架構

    • 當訪問量逐漸增大,單一應用增加機器帶來的加速度越來越小,將應用拆成互不相干的幾個應用,以提升效率。

Ø  分散式服務架構

  • ·當垂直應用越來越多,應用之間交互不可避免,將核心業務抽取出來,作為獨立的服務,逐漸形成穩定的服務中心,使前端應用能更快速的響應多變的市場需求。

Ø  流動計算架構

    • 當服務越來越多,容量的評估,小服務資源的浪費等問題逐漸顯現,此時需增加一個調度中心基於訪問壓力實時管理集群容量,提高集群利用率。
    • 此時,用於提高機器利用率的SOA服務治理方案是關鍵。

 

Dubbo就是SOA服務治理方案的核心框架。

Dubbo理解:Dubbo既可以進行服務調用,又可以進行服務治理。

Dubbo是Alibaba開源的分散式服務框架,它最大的特點是按照分層的方式來架構,使用這種方式可以使各個層之間解耦合(或者最大限度地松耦合),比如表現層和業務層就需要解耦合。

 

從面向服務的角度來看,Dubbo採用的是一種非常簡單的模型,要麼是提供方提供服務,要麼是消費方消費服務,所以基於這一點可以抽象出服務提供方(Provider)和服務消費方(Consumer兩個角色。

 

除了以上兩個角色,它還有註冊中心監控中心。它可以通過註冊中心對服務進行註冊和訂閱;可以通過監控中心對服務進行監控,這樣的話,就可以知道哪些服務使用率高、哪些服務使用率低。對使用率高的服務增加機器,對使用率低的服務減少機器,達到合理分配資源的目的。

 

 

節點角色說明:

  • Provider: 暴露服務的服務提供方。
  • Consumer: 調用遠程服務的服務消費方。
  • Registry: 服務註冊與發現的註冊中心。
  • Monitor: 統計服務的調用次調和調用時間的監控中心。
  • Container: 服務運行容器,實際指的是spring容器,spring容器啟動可以通過java應用程式也可以通過tomcat容器,建議tomcat容器去載入spring容器

調用關係說明:

  • 0. 服務容器負責啟動,載入,運行服務提供者。
  • 1. 服務提供者在啟動時,向註冊中心註冊自己提供的服務。
  • 2. 服務消費者在啟動時,向註冊中心訂閱自己所需的服務。
  • 3. 註冊中心返回服務提供者地址列表給消費者,如果有變更,註冊中心將基於長連接推送變更數據給消費者。
  • 4. 服務消費者,從提供者地址列表中,基於軟負載均衡演算法,選一臺提供者進行調用,如果調用失敗,再選另一臺調用。
  • 5. 服務消費者和提供者,在記憶體中累計調用次數和調用時間,定時每分鐘發送一次統計數據到監控中心。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 理解volatile 平時工作中對於多線程的應用並不太多,但是不能說工作中不應用就可以對此不去瞭解,至少要做的知道有這麼個東西,主要是作什麼的,這樣有助於看其它人寫的代碼。提到這個volatile,一般都會想到併發,同步,鎖之類,但要想搞清楚需要看看下麵一些知識。 處理器,高速緩存,主記憶體之間的關係 ...
  • Java 生成驗證碼的流程是: 收到請求 生成驗證碼所用的隨機數 使用隨機數寫出圖片 將隨機數記錄到Session中 輸出驗證碼 Java 驗證驗證碼的流程是: 收到請求 獲取用戶傳過來的驗證碼數字 驗證是否正確 輸出驗證結果 下麵通過一個例子來展示驗證碼的生成流程,該例子使用基本Java Spri ...
  • 如果計算一個表達式,比如 4+5+6*2,隨著計算器的不同,簡單的四功能計算器是30,許多科學計算器知道乘法的優先順序高於加法,所以科學答案是21。典型計算順序可以是計算4+5,存為臨時變數a,再計算6*2,存為b,最後計算a+b可得出最後結果。這種操作順序如下:45+62*+ 這種記法就是尾碼表達式 ...
  • 用途 在處理多個 socket 套接字的時候,會很自然的遇到一個問題:某個套接字什麼時候可讀?什麼時候可寫?哪些套接字是需要關閉的?我們可以回憶一下,一般我們在最開始編寫socket程式的時候,send,recv都是同步的,send完後就傻等著recv。這種模式的一個很大的問題是,recv會占用一整 ...
  • 折騰了半天左右的時間,成功在win7_64bit下配置成功PHP+apache+miriadb資料庫 +配置工具下載與解壓 01. Apache HTTP Server 2.4.25 : http://www.apachehaus.com/cgi-bin/download.plx -關於版本: Vi ...
  • 以下截圖來自慕課視頻和自己的程式。 1.封裝的實現步驟: 示例: 2.包的使用 3.java的訪問修飾符總結: 4.this關鍵字 示例: ...
  • 把複雜的數據類型壓縮到一個字元串中 serialize() 把變數和它們的值編碼成文本形式 unserialize() 恢複原先變數 eg: $stooges = array('Moe','Larry','Curly');$new = serialize($stooges);print_r($new ...
  • 寒假時自己跟著慕課,複習一些java基礎概念的學習筆記。 1.如何理解類? 類是對一群有共同特征的事物或事件的集合。而類對象就是類的實例化。 如現實世界中手機是一種類: 2.如何使用java對象? 3.成員變數和局部變數 4.示例: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...