SOA認知和方法論

来源:https://www.cnblogs.com/jingdongkeji/archive/2023/10/18/17771637.html
-Advertisement-
Play Games

架構的範疇太大太廣,本文嘗試從一個點切入闡述一下個人的認知。有太多相關性的問題想去闡述,比如SOA與BPM的結合、實踐過程中遇到的細節問題等等,為了比較乾凈的剖析SOA還是刪除掉了。希望各位看官有所收穫。 ...


1 前言

1.1 架構分類

在軟體設計領域,企業架構通常被劃分為如下五種分類:

如何理解架構分類依據及其彼此之間的關係?業務是企業賴以生存之本,因此業務架構是基礎、是靈魂,其他一切均是對業務架構的支撐;根據業務架構形成與之相應的產品架構和數據架構;最後通過技術架構落地實施。

應用架構用於對產品架構進行細分,通過應用集成形成產品。但是應用架構區別於產品架構的本質不應該只在粒度,更重要的是產品直接承接業務,按照業務問題域進行劃分;而應用需要考慮通用能力沉澱和復用,為多個產品提供統一支撐。

  • 業務架構:業務需求初期,將模糊的需求描述為清晰的問題域,主要包括業務規劃、業務模塊、業務流程。
  • 產品架構:脫胎於業務架構(主要是業務流程和業務模塊),關註的是功能的枚舉和分類。
  • 數據架構:從問題定義的視角,邏輯(流程)+ 數據是兩個核心。業務架構分析流程的同時,另一個核心就是定義數據架構,結合流程和數據形成產品。在實踐過程中數據架構的工作往往被置於產品架構或者應用架構內部,從全局視角看這是一種誤區,數據作為企業寶貴資產,其架構的好壞直接影響企業競爭力,必須全局考量和設計。數據架構要解決兩個關鍵問題 - 1.需要什麼數據 2.如何存儲數據。
  • 應用架構:應用架構用於對產品架構進行細分,在產品架構的基礎上進行更細粒度的問題拆解和職責劃分,並抽取可復用模塊沉澱形成基礎能力。應用架構的最貼近落地實現。
  • 技術架構:上述四個架構從問題定義視角出發,技術架構從問題解決的視角出發,關註的是技術選型、開發框架、開發語言等。

1.2 SOA

自19年底開始,我的工作內容就集中於供應鏈領域中台產品的建設,在建設過程中不可避免的一個關鍵詞就是服務化,對此不同人會有不同的看法,個人對服務化的理解更傾向於SOA,因此通過本文談一下對SOA的認知。

SOA作為一種架構風格,從架構分類的視角看更偏向於業務架構的一個思想體系,可以作為方法論指導我們從業務模型定義開始一直到整體的業務架構落地。SOA強調我們對業務本質的思考和設計,通過共創的方式(方式而非形式)對業務本質不斷的追溯、抽象、總結、歸納、演繹,用於提升業務靈活性、加快業務創新、提升業務效率;不應該跳過業務架構將其當作一個應用架構或者技術架構的術語。往往在談到服務化的時候,很多實踐就會用技術框架(平臺)來等價代換服務化的概念,追求將熱點的技術框架(如serverless、codeless)在現有系統中的落地作為整個服務化建設的主旋律,這樣的建設最終往往收效欠佳。原因就是技術框架的使用僅僅是術、是器,而服務化(SOA)的本質是道、是法。

軟體架構在SOA提出之後尚未發生變革性的突破,很多架構思想如 EA分層架構、微服務架構、DDD架構 等,大多都是在SOA架構風格的基礎上進行不同角度的演化迭代,因此本文在闡述SOA的過程多少會存在其他架構思想中的“影子”。

2 What、Why、How三個視角看SOA

2.1 What

2.1.1 術語

任何概念的定義,都有與之對應的術語。

  • 業務行為:具備一定業務語義的原子行為抽象。
  • 業務流程:實現特定業務價值(滿足客戶需求)的一些列業務行為的有機組合。
  • 業務服務:提供增值價值的業務行為或業務流程(需要特別說明的是業務服務既可以是業務流程也可以是業務行為、甚至兩者的組合)。具有明確業務功能定義和價值衡量標準(SLA)。
  • 應用組件:按照一定的相關性結構化封裝的應用功能(為方便理解,在不考慮分層的前提下,簡化等價於業務服務)的一個集合。用以提升應用的一致性、靈活性,並實現重用。
  • 應用:應用組件的有機集合,用來提供業務功能(單個或多個),為整個系統或者平臺提供增量價值支撐。京慧中的需求計劃、經營計劃、庫存計劃、分銷補貨計劃、供給計劃(應用之間也存在一定的層級概念,貼近業務本質的理解)。
  • 系統:一系列應用及服務的有機組合(某些服務可以獨立為系統提供增量價值支撐,微服務架構思想中有諸多體現),具備端到端的完整業務功能,體系化的提供用戶增量價值。我所建設的 京慧產品(供應鏈計劃產品) 本身是系統的層面。
  • 平臺:一個或多個系統的有機組合,具備整個業務線或者業務生態的端到端業務功能全集。以提供業務線或者業務生態整體業務價值為目標。
  • 架構:代表的是一個系統的基礎元素構成。體現在系統構成的元素集合、元素之間的關係、與外部環境的交互,以及指導系統迭代演進的原則。
  • 架構風格:一系列符合共同特征和核心原則的架構定義。

2.1.2 定義

SOA就是一種架構風格,致力於將業務功能保持一致的服務作為設計、構建和編排組合業務流程(或者解決方案)的基本單元。

2.1.3 服務

服務是設計、構建和編排組合一個完整業務實體中業務解決方案的基礎單元。

服務可以從表裡兩個方向結合定義 - 服務是提供業務功能的原子單元(里),通過服務契約的方式管理(表)。

服務契約是服務消費方與服務提供方交互的所有約定的集合,通常由如下元素構成:
服務介面:介面定義,描述服務做什麼、出入參定義等,通常通過介面文檔的形式呈現。圍繞著一個核心的業務功能操作以及相關聯的操作。

  • 服務策略: 服務雙方的隱性的共識,描述適應場景、約束等。
  • 服務水平:通過服務質量、可用性、性能等各個方面衡量服務本身,基本等價於SLA,包含了服務的兩個重要方面的指標 - 業務指標和技術指標(技術指標- RT、吞吐量、可用性、可靠性等;業務指標-完成的業務功能的質量或者完成度,e.g.補貨建議是否滿足業務預期的周轉缺貨KPI)。

服務契約中體現出來的管理屬性是服務區別於其他常見定義(模塊、組件等)的根本區別,我們通過服務契約來管理服務的全生命周期(設計、實現、部署、升級)。

服務實現 - 對業務功能的實現,是對SOA核心本質的映射。

  • 服務實現:具有多種實現方式【編碼實現 |編排其他服務 | 適配封裝現有應用 | 混合實現】。服務如何實現對於服務消費方來說是透明的,即服務消費方僅關心服務的what而非how。服務可以在保持介面不變的情況下在橫縱兩個方向改變(橫 根據不同行業不同場景提供不同的實現;縱 根據行業發展演進服務)。

2.2 Why

為什麼要選擇SOA?針對這個問題會有很多觀點

  1. 職責清晰(介面定義)
  2. 可靈活擴展(介面與實現分離)
  3. 高度可復用
  4. 介面分類
  5. 高度可管理

上述觀點都無法否定,因為它們可以通過服務定義推演得到。其中前三個都是針對單個服務構建來看,只要掌握足夠的技術手段就可以很容易的創建一個服務(單個服務),這並不是SOA的核心競爭力。SOA的目的遠超介面技術細節的設計與定義,核心關註點在於服務的業務內容以及內涵(而非如何設計和實現)。在使用SOA總結提煉出的術與器的同時,不要忘記道和法。how to do很重要,指導的是做好一件事;但是what更重要,指導的是做對的事。

更深層次的剖析SOA的價值,我們需要回歸SOA的本質 - 致力於在企業內的不同業務環境內建設業務功能驅動的服務,併在此基礎上將服務組裝成更高價值/更高級別的業務流程(解決方案)。故而可以將SOA的價值總結為兩個關鍵點:

  1. 賦能企業構建具有業務價值的、具備完整業務語義的服務集合;
  2. 基於服務集合,組織和編排服務,構建敏捷&靈活的業務流程/解決方案。【敏捷 服務可以快速調整、獨立演化;靈活 服務的業務功能定義明確(邊界清晰、內聚性強),可靈活組合】

2.2.1 SOA價值的表現形式

  • 一致性:一致性是SOA核心的價值體現,包括數據一致性和行為一致性【數據 提供業務一致&共識的公共數據訪問服務;行為 對外(業務流程、外部任務等)提供統一的入口】
  • 解耦:通過分離減少功能與數據的依賴和耦合。服務作為獨立的業務功能單元,在應用系統中可以協同工作,同時各自又具備各自清晰且獨立的業務目標和生命周期。
  • 模塊化&敏捷性:為業務的模塊化提供基礎;同時在模塊化實現的基礎上,模塊可以在多個業務流程和場景中被覆用和靈活組合,從而支持業務快速創新。
  • 高度可管理性:服務水平的定義保證了服務在支撐業務目標的同時,可以跳出業務功能認知進行管理(可監控、可優化、可調整)。

2.3 How

相比於What和Why,SOA的實踐是一個很龐大的問題,本文選擇從服務設計的角度進行剖析。

2.3.1 梳理上下文

對業務系統,理解我們所支持的業務及其核心驅動力,是我們做好服務化的前提;如果是平臺類系統,需要理解公司的戰略所賦予平臺的使命和平臺的終局目標、中長期目標 。換言之,第一步是理清服務化架構的完整上下文背景。這些內容需要映射到模型中(各層級模型,詳見下文分層設計)。如何梳理上下文,一種好的實踐方式是定義問題集。有一種觀點是提出好的問題 == 問題解決了一半,問題集定義:

通過上述8個問題描述了整個服務化架構的上下文:

  • 問題1-6:描述業務/平臺整體架構需求梳理;
  • 問題7:描述架構需求梳理的結論;
  • 問題8:引入了服務集合定義。服務集合是SOA建設的核心成果,需要從持續迭代演進的視角去理解。

我們通過服務集合來反映完整的業務語義和平臺語義。怎樣確定服務集合是否具備完整的上下文語義,必須能識別出下述內容:

  • 完整的上下文背景
  • 服務集合職責範圍
  • 服務分組(體現服務關聯性)
  • 服務的類型和角色

服務集合設計的兩個主要目標

  1. 提供一種機制來識別一個特定服務的責任邊界,指引服務實現。(重要 明確服務職責及邊界,避免重覆建設,保障行為和數據一致性)
  2. 提供一種機制來幫助理解服務整體的上下文背景,用於更高效的服務選擇、服務重用。(服務分類,服務間關聯性)

服務集合中的服務可以按照服務類型以及服務角色來進行組織。服務類型參照服務化分層架構描述,服務角色包含任務服務角色、實體服務角色、決策服務角色。

2.3.2 服務設計原則

SOA成功的關鍵之一是創建一個具備完整上下文語義(業務/平臺語義)的服務集合,以便於通過組合編排服務來支撐不同的業務流程和業務場景。面向服務的架構中服務設計的問題要跨越多個甚至全部的流程來一起考慮。

首先,最容易想到的是松耦合,無論是SOA思想還是其他思想(e.g.OOP)松耦合都是基礎原則之一;通過減少服務間的依賴提升不同應用場景下的復用性,隔離變更影響。耦合 - 服務間存在依賴關係。首先我們來看下對於服務最重要的兩個點:

  • 服務提供的業務功能
  • 服務對業務數據產生的影響

從上述兩個點我們比較容易得出兩種類型的耦合(依賴) - 數據和功能。這裡會存在一個很基礎的問題為什麼要產生依賴,從技術實現的角度看可以摒棄依賴實現一個大而全的服務。開發人員特別是習慣面向對象思想的開發人員對松耦合/高內聚已經形成一種本能,很少會反思為什麼要這麼做 - 兩個方面(內在 一致性保障;外在 能力復用)。好的服務設計不僅是關註重用性,更重要的是提供一致性(行為與數據)。

再有,如何決定有哪些服務以及服務是什麼?還是從數據和功能出發,通過功能分解和數據隔離組合在一起來決定服務有哪些以服務分別是什麼。由此擴展所得的基本原則如下:

  • 避免缺失
  • 避免重覆
  • 保持一致性

如何實踐落地上述原則?可以藉助問題集的定義和轉換:

2.3.3 服務集合設計

我們從分層、分類、顆粒度切分三個緊密聯繫的方面來看服務集合設計。

服務分層

信息架構是服務化分層架構設計中會被忽視的一個重要側面,體現的是企業中不同角色的關註點。

  • 戰略與決策 定義企業的戰略方向和商業目標,指引企業內部系統/平臺發展的方向和終局。
  • 商業模式 用運營主體的術語描述對企業業務有價值的事物。
  • 業務抽象 用信息化的方式對單個業務線或者多個業務線的業務進行抽象。從業務抽象開始進入問題域定義。
  • 公共語義模型 在業務抽象的基礎上增加服務化的語義。公共語義模型描述的是在平臺各業務服務間共用的具有一致語義的業務實體和信息,需要在平臺層達成共識。
  • 子域領域模型 是各子域的核心業務功能的抽象,包括服務定義及服務實現中的關鍵實體的定義。從整體視角來看是平臺各子域的私有模型,除了服務語義之外整體不對外可視。
  • 開發實現模型 等價於OOP中的對象模型,是開發和落地的基石。

商業模式與業務抽象的關係

1-商業模式描述業務運營人員感知的業務流程;業務抽象不僅描述業務流程,更重要的是抽象描述業務流程所應該包含的底層業務功能。
2-商業模式描述對企業業務來講所有重要的事物;業務抽象描述企業業務想要事物背後的最根本的內容。

雖然從層級結構上看商業模式是業務抽象的上層,但是商業模式描述的東西是業務抽象定義所對應的樣本或實例(從概念上來講業務抽象的範圍更寬泛)。業務抽象是商業模式的抽象與綜合,必須要仔細分析和歸納、甚至通過演繹的方式來定義出隱藏在企業業務運營主體背後的根本內容和結構。

公共語義模型與子域領域模型的關係

公共語義模型用於描述平臺層服務介面交互的共用信息,基於平臺完整業務語義下所有服務公用數據的標準化視圖模型。簡言之,平臺公共語義模型定義了業務平臺層次的基本業務服務語義,是平臺各業務服務之間、平臺業務流程和平臺業務服務交互的統一語言,強調統一和共用。而子域領域模型是平臺各域的私有模型,用於驅動子域內服務功能的設計與實現。除非域內業務發生本質變化,子域領域模型需要保持動態穩定,通過防腐層隔離外部依賴的侵蝕 (領域模型也是DDD思想的核心)。

服務分層是服務化分層架構設計的主體。理解服務分層架構的一個好的方式是學習一下 TOGAF Meta-Model。

  • 業務流程(端到端):按照一定業務規則決定的順序執行的業務操作。高層級的業務功能通常跨多個應用子域/業務條線。
  • 業務服務(平臺/系統):高度模塊化的業務功能單元。由不同類型的子域服務組合編排而來,可作為業務流程的編排單元。
  • 子域服務:功能子域提供的服務,對平臺可見,用於平臺業務服務的組合編排,也可以作為更高層的業務流程編排的基礎單元。
  • 子域基礎服務:用於支撐各功能子域服務的基礎服務,對子域可見,對平臺不可見,用於子域服務的編排。
  • 基礎子域服務:或稱之為基礎業務域服務,提供平臺基礎業務服務,為各個功能子域或平臺業務服務提供基礎業務功能及數據服務(e.g.商家服務、貨品服務、庫存服務)
  • 基礎架構服務:提供不同層次所共用的基礎架構服務(e.g.用戶管理、許可權管理)

模型分層是對服務分層的重要補充。服務分層從結構上看是清晰和完整的,但是從服務化建設的整體視角看卻並不完整,我們需要添加與之對應的模型抽象。

  • 核心模型:端到端的業務流程承載業務核心價值的信息模型。在供應鏈領域中是單據模型,e.g.銷售訂單、採購訂單、補貨計劃單。
  • 公共語義模型:定義了平臺層面業務流程、業務服務交互數據。在平臺層面或者企業層面,端到端的業務流程中交互信息的公共語義模型定義了業務流程中所需要的完整的業務語義的實體定義(各業務語義實體邊界明確、責任清晰)。核心模型通常是公共語義模型的子集。平臺公共語義模型包含下層子域的對外服務實體子集,按照端到端的完整平臺業務語義,可以由平臺各功能子域模型所共用給平臺的核心實體子集有機整合而成,也可以由平臺業務模型全新定義(從top-down與bottom-up兩個方向共同融合而成)。此模型需要不斷迭代演進,平臺的諸多架構決策和完善都是基於此模型來進行。
  • 子域領域模型:平臺各功能子域的領域模型用於驅動各功能子域的應用系統設計和開發。(同服務分層描述 需要保持動態穩定,通過防腐層對外部服務進行隔離,防止外部服務污染子域內的核心業務語義,同時保持域內業務功能靈活可控。子域領域模型僅通過其對外服務實體對外可見,其他均對外不可見。)
  • 跨域映射模型:用於各子域領域模型實現對外部模型的防腐依賴。
  • 基礎架構服務模型:提供跳出層級之外的公用的基礎架構信息模型,如用戶模型、許可權模型。

服務分類

服務分類(或稱服務角色)是獨立於職責範圍、服務粒度之外的另一個重要因素;用於標識服務在組合/流程編排中所扮演的角色是什麼。
如果說服務分層是縱向切分,服務分類就是橫切麵。借鑒OOP與AOP的理念,對服務分類的定義我們使用關註點分離的架構原則。

通常我們通過較粗粒度來定義三大類服務:

  • 任務服務:任務服務通常實現一個完整的業務功能,既可以是基本業務功能,也可以是複雜的業務功能。此服務類型顆粒度粗,包含從獨立的子域基礎服務到平臺業務服務都可以具有任務服務角色。業務服務通常承擔任務服務的角色,本身是由小顆粒度服務較大的組合(流程),可以被設計成支持一個或者更多待定的流程。任務服務的針對性強,復用能力弱。通常,具有任務服務是主動服務,通過主動行為來進行價值輸出。
  • 實體服務:管理訪問業務實體的服務。舉例來看,e.g.用戶、類目、商品、購物車。實體服務通常獨立於任何特定的業務流程,可作為多個不同業務流程的組成部分。實體服務通常通過是配合提供需要的信息來實現任務的方式來支撐任務服務。實體服務通常具備很強的復用潛力。
  • 規則/決策服務:通過執行業務規則來提供業務決策的服務。舉例來看,e.g.補貨計劃自動審核服務。通常作用於複雜問題的判斷或者支持變化頻繁的業務規則。從顆粒度上來看,規則/決策服務通常為小到中等,用來組裝成更大的服務。規則/決策服務可以是不同層次的服務(包括業務服務、子域服務、子域基礎服務等),但是更常見的是作為基礎服務來支撐這些服務。

我們通過組合不同類型的服務角色來提供靈活的業務能力,支持業務流程內的活動。因此需要一些基本原則來幫助我們合理的組合服務(減少依賴、限制耦合、獲取最大的靈活性) - 服務分層以及組合的基本原則:

  • 業務流程的任務通過任務服務實現,業務流程路由的核心規則由規則/決策服務來提供
  • 服務更高層次的業務服務由其他更小的服務組成
  • 任務服務可以組合規則/決策服務、實體服務以及其他任務服務
  • 實體服務不允許存在相互調用
  • 服務單向依賴,上層服務可以依賴下層服務以及同一層次的服務,下層服務不可以依賴上層服務

通過豐富的流程、實體和決策服務的集合,創建新的不同的服務(流程);結合規則/決策的靈活可變與服務分層的模塊化、可重用性,打造系統/平臺實踐落地的架構方法論。

顆粒度切分

我們在設計服務是一個很大的疑惑是我們的服務到底要設計成什麼樣的顆粒度?這個問題沒有統一標準,可以通過設置問題集結合併結合服務分層的方式來求解

  • 誰是服務消費方(包含潛在消費方),e.g.其他服務、業務流程、外部合作方
  • 服務在哪裡別消費,通過什麼路徑消費(即服務拓撲)
  • 服務的性能要求
  • 服務預期的業務範圍和邊界

在複雜的環境或者系統(平臺)中,服務具有不同的類型和顆粒度。一種通用的方式是參照服務化分層進行合理映射:

  • 業務流程(端到端):跨越整個企業或者平臺多個業務域,通常由底層服務構建而成
  • 平臺業務服務:最粗粒度的服務,提供高度抽象的組合業務功能給到平臺或者企業。業務服務的功能和數據同業務流程所需要的業務語義緊密結合。數據整合服務在這個層次提供端到端的業務流程所需要的整合後的數據
  • 子域服務:中等粒度服務,提供針對每個業務子域的業務相關服務,被本於內的不同業務服務所使用,但是未必暴露在子域外
  • 子域基礎服務:最小粒度的服務,提供低層次的服務,用來提供子域內業務功能的基本功能支撐
  • 基礎子域服務:較細粒度的服務,支撐上層業務功能服務的業務功能實現
  • 基礎架構服務:較細粒度的服務,獨立於任何業務域。(明確區分於業務,e.g.安全認證、許可權管理等)

3 總結

架構的範疇太大太廣,本文嘗試從一個點切入闡述一下個人的認知。有太多相關性的問題想去闡述,比如SOA與BPM的結合、實踐過程中遇到的細節問題等等,為了比較乾凈的剖析SOA還是刪除掉了。希望各位看官有所收穫。

作者:京東物流 崔立群

來源:京東雲開發者社區 自猿其說Tech 轉載請註明來源


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

-Advertisement-
Play Games
更多相關文章
  • 在上篇文章中,我們向大家解釋了為什麼實時湖倉是當前企業數字化轉型過程中的解決之道,介紹了實時計算和數據湖結合的應用場景。(“數據驅動”時代,企業為什麼需要實時湖倉?) 在這篇文章中,我們將詳細介紹在數棧實時開發平臺內,實時湖倉的功能架構設計和具體實操案例。 功能架構介紹 實時湖倉並不是一個獨立的產品 ...
  • 使用Base克隆集群節點 先把Base關機,然後右鍵 - 管理 - 克隆 選擇完整克隆 克隆名字這裡叫node1 重覆步驟,克隆node2/node3 為了分類,創建了一個大數據集群文件夾 以下命令全是root許可權執行 配置固定IP # 修改主機名 hostnamectl set-hostname ...
  • mtools是一個基於Python實現的MongoDB工具集,旨在提供一系列功能,包括MongoDB日誌分析、報表生成以及簡易的資料庫安裝等。它由MongoDB原生的工程師單獨發起併進行開源維護。mtools包含了一些常用的組件,如mlaunch、mlogfilter、mplotqueries和ml... ...
  • 一、環境介紹 本文環境,以及本文所採用資料庫為GreatSQL 8.0.32-24 $ cat /etc/system-release Red Hat Enterprise Linux Server release 7.9 (Maipo) $ uname -a Linux gip 3.10.0-11 ...
  • 下載VM與Centos鏡像 用的 VM 17 版本: 該版本解決了老版本的一些藍屏問題和相容性問題 https://download3.vmware.com/software/WKST-1700-WIN/VMware-workstation-full-17.0.0-20800274.exe # 密鑰 ...
  • 接上一節:從零用VitePress搭建博客教程(2) –VitePress預設首頁和頭部導航、左側導航配置 五、預設主題相關細節配置 關於預設主題的標題,logo、頁腳,最後更新時間等相關細節配置,我們也是通過文件config.js中的themeConfig選項配置的,以下所有配置都是在themeC ...
  • 我的小冊 《CSS 技術揭秘與實戰通關》上線了,想瞭解更多有趣、進階、系統化的 CSS 內容,可以猛擊 - LINK。 最近大家刷抖音,是否有刷到拉斯維加斯的新地標 「Sphere」: 場館內部的視覺效果非常驚人,其中一個效果讓我虎軀一震: 我的第一想法就是,這個看起來用 CSS 也可以實現嘛?還有 ...
  • 本文總結了軟體開發過程中經常用到的基礎常識,分為基礎篇和實踐篇兩個篇章,其中基礎篇中著重講述了類,方法,變數的命名規範以及代碼註釋好壞的評判標準。實踐篇中從類,方法以及對象三個層面分析了常見的技術概念和落地實踐,希望這些常識能夠為讀者帶來一些思考和幫助。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...