《大型網站系統與Java中間件》讀書筆記 (中)

来源:https://www.cnblogs.com/Java3y/archive/2019/07/01/11117205.html
-Advertisement-
Play Games

前言 只有光頭才能變強。 文本已收錄至我的GitHub倉庫,歡迎Star: "https://github.com/ZhongFuCheng3y/3y" 回顧上一篇: "《大型網站系統與Java中間件》讀書筆記(一)" 這周周末讀了第四章,現在過來做做筆記,希望能幫助到大家。 註:在看這篇文章之前, ...


前言

只有光頭才能變強。

文本已收錄至我的GitHub倉庫,歡迎Star:https://github.com/ZhongFuCheng3y/3y

回顧上一篇:

這周周末讀了第四章,現在過來做做筆記,希望能幫助到大家。

註:在看這篇文章之前,強烈建議先看看我之前寫過的一篇SpringCloud入門文章:外行人都能看懂的SpringCloud,錯過了血虧!。看完再回頭看這篇文章,你會發現:這本書講的設計與實現在SpringCloud中幾乎都有對應的組件支持。

一、服務框架的設計

從上一篇我們講到,應用拆開了以後,不同功能/模塊之間的調用不再單純通過本機調用,引入了遠程的服務調用

服務拆分

而遠程的服務調用這個東東會很難嗎?說白了,不就是兩台伺服器之間通信嗎?

遠程的服務調用

這時候,你能想到什麼?必定是Socket吧。沒錯,我們通過Socket肯定是可以完成兩個系統之間的通信的問題的。(Socket相信大家在學習基礎的時候已經寫過Demo了,這我就不多BB了)

Socket完成系統之間的通信

一兩個系統的Socket寫起來沒啥,但我們應用拆分之後,系統可是會變得很多很多。

系統會變得非常多

系統很多的情況下,我們在寫遠程調用代碼的時候就可能要考慮到以下的問題:

  1. 我們肯定是不希望每次遠程調用的時候都貼上重覆的Socket代碼,要是調用遠程方法像調用本地方法一樣簡單就好了。
  2. 某個服務應用為了實現高可用,集群了(多台機器部署同一套應用)。那我遠程調用的時候選擇哪一臺機器進行調用?
  3. 網路之間的傳輸協議用現成的HTTP呢?還是自定義一套通信協議呢?
  4. 因為我們想調用遠程方法像調用本地方法一樣,那麼在網路上就需要傳輸Java對象,要傳輸Java對象,就必須得對其進行序列化和反序列化的處理。能實現序列化的操作也有很多,選擇哪一種方式呢?
  5. 網路之間的通訊也有bio、nio、以及aio這幾種模式,一般來說我們會選擇哪種比較多?如果不瞭解nio的同學,可以閱讀我以前寫過的筆記(nio你瞭解多少?
  6. ….等等等

由於系統之間的調用會非常多,我們自然是不希望寫重覆的代碼的,所以服務框架(也可以說是RPC框架)就應運而生了【說白了就是專門處理遠程服務調用的框架】。有了服務框架,我們就可以實現多個系統之間以統一的方式來進行遠程調用了。

一個服務框架需要考慮的問題其實遠不止上面所列出的那些,比如說:

  • 服務框架與Web應用和Web容器的關係是什麼?服務框架和應用是綁定在一起嗎?(服務框架作為Web應用的一個依賴包),還是說服務框架只是Web應用的一個擴展(沒有和Web應用打包綁定在一起)
  • 服務框架的jar包和Web應用的jar包衝突了怎麼辦?
  • 為了保證系統的穩定性,流量控制也應該要考慮到
  • 在遠程調用的時候,需不需要以更細粒度的方式來進行選擇(之前說的是選擇哪台機器,但可以細粒度到機器下的介面或者方法)
  • ....等等

二、服務框架的技術實現思路

在書中給出了設計服務框架時需要考慮的問題的同時也給出了一些實現思路,我摘錄一些我覺得比較有參考意義的說說。

2.1 像本地一樣調用遠程服務

比如服務消費方在執行orderService.buy("HHKB鍵盤")時,實質上調用的是遠端的服務

這用到啥技術?明顯就是動態代理(給女朋友講解什麼是代理模式

在實現的時候有三個基礎屬性可以參考一下:

  • interfaceName— 確定調用的是哪一個介面
  • version— 如果介面進行升級了,可以使用version來進行區分和隔離
  • group— 對遠程服務的機器進行分組,那麼調用的時候就可以選擇不同的分組來調用(調用者對統一服務的調用進行隔離)

2.2 其他

  1. 當遠程調用服務的時候,不需要每次都要去註冊中心查找可用的地址,而是把地址緩存在調用方。當服務有變化的時候,主動告訴調用者就行了。
  2. 流量控制一般會基於兩個維度去考慮:一、自身的介面和方法。二、請求的來源
  3. 並不是所有的請求都要經過服務提供者。像走緩存這樣頻繁的操作(而且大多數都是會成功的),直接在調用方調用就ok了

直接在調用方走緩存

最後

總的來說,書的第四章主要是在講解在設計服務框架的時候應該要考慮到哪些方面,可以以什麼方案來解決,看得還是非常過癮的(這隻是我的個人筆記,書上還有很多的內容)。強烈建議配合我之前寫過的一篇SpringCloud入門文章:外行人都能看懂的SpringCloud,錯過了血虧!食用。

樂於輸出乾貨的Java技術公眾號:Java3y。公眾號內有200多篇原創技術文章、海量視頻資源、精美腦圖,關註即可獲取!

轉發到朋友圈是對我最大的支持!

覺得我的文章寫得不錯,點


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

-Advertisement-
Play Games
更多相關文章
  • 日誌框架 開發一個大型系統的簡易步驟: 寫一個統一的介面層: 日誌門面,(日誌的一個抽象層) 給項目導入具體的日誌實現,之前的框架都是實現的抽象層 主流的日誌框架 JUL、JCL、Jboss-logging、logback、log4j、log4j2、slf4j.... 日誌門面(日誌的抽象層): J ...
  • 自定義資料庫欄位 擴展預設的models.CharField和models.TextField使之成為支持多語言的欄位。 可以輕鬆實現復用,無需配置多餘選項 這裡定義了 MultilingualCharField 和 MultilingualTextField欄位 使用方法 中配置多語言 預設語言設 ...
  • 8-1 消息: 編寫一個名為display_message()的函數,它列印一個句子指出你在本章學的是什麼。調用這個函數,確認顯示的消息正確無誤。 8-2 喜歡的圖書:編寫一個名為favorite_book()的函數,其中包含一個名為title的形參。這個函數列印一條消息,如One of my fa ...
  • 一、NoSQL簡介 1、NoSQL 概念 NoSQL( Not Only SQL ),意即"不僅僅是SQL"。對不同於傳統的關係型資料庫的資料庫管理系統的統稱。NoSQL用於超大規模數據的存儲。這些類型的數據存儲不需要固定的模式,無需多餘操作就可以橫向擴展。 2、NoSQL的優點/缺點 二、Mong ...
  • Spring容器是一個大工廠,負責創建、管理所有的Bean。 Spring容器支持2種格式的配置文件:xml文件、properties文件,最常用的是xml文件。 Bean在xml文件中的配置 <beans> 根元素,可包含多個<bean>元素,一個<bean>即一個Bean的配置。 <bean> ...
  • 今天我開始重新一點一滴的學習python,雖然之前也學習過python,但是當時的學習比較雜亂,知識點較為凌亂,所以感覺學習效果不是很好,寫一些程式或者是演算法都不能夠得心應手,因此決定重新學習學習python,因為之前有學習過C語言和JAVA的原因,學習過程比較快,但是還是要告誡一些初學者或者是其他 ...
  • Day1 1.電腦基礎 1. 什麼是電腦 輸入輸出設備 CPU(中央處理器):處理各種數據,相當於人的大腦 記憶體:存儲數據,相當於人的臨時記憶 硬碟:存儲數據,相當於人的永久記憶 2. 什麼是操作系統 控制電腦硬體工作的流程 軟體 3. 什麼是應用程式 安裝在操作系統之上的軟體 2.Pytho ...
  • [TOC] 一、源碼下載 Qt庫封裝了很多很控制項,種類也比較多,其中容器控制項包括:表格、樹和列表。 使用過QtDesigner的同學應該都知道,這個工具中有一個屬性編輯器,是一個表格樹控制項,就像vs中控制項屬性面板一樣。 今天我們就來介紹一款使用QTreeWidget封裝的表格樹控制項QtTreePro ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...