国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

程序員必知的7種軟件架構(gòu)模式

開發(fā) 架構(gòu)
架構(gòu)模式是對給定上下文的軟件架構(gòu)中常見問題的一種通用的可復(fù)用的解決方案。

[[374334]]

架構(gòu)模式是對給定上下文的軟件架構(gòu)中常見問題的一種通用的可復(fù)用的解決方案。

一種模式就是特定上下文的問題的一種解決方案。

然而,很多開發(fā)者至今還對各種軟件架構(gòu)模式之間的差別搞不清,甚至對其所知甚少。

大體上,主要有下面這7種架構(gòu)模式:

  1.  分層架構(gòu)
  2.  多層架構(gòu)
  3.  管道 - 過濾器架構(gòu)
  4.  客戶端 - 服務(wù)器架構(gòu)
  5.  模型 - 視圖 - 控制器架構(gòu)
  6.  事件驅(qū)動架構(gòu)
  7.  微服務(wù)架構(gòu)

一、分層架構(gòu)模式

最常見的架構(gòu)模式就是分層架構(gòu)或者稱為 n 層架構(gòu)。

大部分軟件架構(gòu)師、設(shè)計師和開發(fā)者都對這個架構(gòu)模式非常熟悉。盡管對于層的數(shù)量和類型沒有具體限制,但大部分分層架構(gòu)主要由四層組成:展現(xiàn)層、業(yè)務(wù)層、持久層和數(shù)據(jù)庫層,如下圖所示。

圖片一個很流行的 n 層架構(gòu)示例

 1 上下文 

所有復(fù)雜的系統(tǒng)都會經(jīng)歷獨立地發(fā)展和衍化系統(tǒng)各個部分的需要。出于這個原因,系統(tǒng)開發(fā)者需要對關(guān)注點進(jìn)行清晰且條理分明的分離,以便系統(tǒng)的各個模塊可以獨立地開發(fā)和維護(hù)。

 2 問題 

軟件需要以這樣一種方式分割:各個模塊可以獨自開發(fā)和衍化,各自部分之間的交互非常少,支持可移植性、可修改性和復(fù)用性。

 3 方案 

為了實現(xiàn)關(guān)注點分離,分層模式將軟件分割成各個單元(稱為“層”)。每一層都是一組模塊,提供了一組高內(nèi)聚的服務(wù)。其使用必須是單向的。層將一組軟件作為一個完整的分區(qū),每個分區(qū)暴露一個公開接口。

  •  第一個概念是,每一層都有特定的角色和職責(zé)。例如,展現(xiàn)層負(fù)責(zé)處理所有的用戶界面。分層架構(gòu)的這種關(guān)注點分離,讓構(gòu)建高效的角色和職責(zé)非常簡單。
  •  第二個概念是,分層架構(gòu)模式是一個技術(shù)性的分區(qū)架構(gòu),而非一個領(lǐng)域性的分區(qū)架構(gòu)。它們是由組件組成的,而不是領(lǐng)域。
  •  最后一個概念是,分層架構(gòu)中的每一層都被標(biāo)記為封閉或者開放。封閉層意味著請求從一層移到另一層,它必須通過它正下面的這一層才能達(dá)到下面這一層的再下一層。請求不能跳過任何層。

圖片封閉層和請求訪問

 4 弱點 

分層會導(dǎo)致性能下降。這種模式不適合高性能應(yīng)用程序,因為經(jīng)過架構(gòu)中的多層來實現(xiàn)一個業(yè)務(wù)請求的效率是不高的。

分層還會增加系統(tǒng)的前期成本和復(fù)雜性。

 5 用途 

我們應(yīng)該將這種方式應(yīng)用于小型簡單的應(yīng)用程序或網(wǎng)站。對于預(yù)算和時間非常緊張的場景,這是一個不錯的選擇。

二、多層模式

 1 方案 

圖片一個多層模式示例:消費者網(wǎng)站 J2EE

許多系統(tǒng)的執(zhí)行結(jié)構(gòu)被組織成一系列邏輯組件分組。每個分組被稱為一個層。

 1 上下文 

在一個分布式部署中,通常需要將系統(tǒng)的基礎(chǔ)設(shè)施分到不同的子集中。

 2 問題 

我們?nèi)绾螌⑾到y(tǒng)分割到多個計算上獨立的執(zhí)行結(jié)構(gòu):由一些通信媒介連接的軟件和硬件組?

 3 弱點 

大量前期成本和復(fù)雜性。

 4 用途 

用在分布式系統(tǒng)中。

三、管道-過濾器架構(gòu)

軟件架構(gòu)中反復(fù)出現(xiàn)的一種模式是管道 - 過濾器(pipe-filter)模式。

圖片管道過濾器模式

 1 上下文 

許多系統(tǒng)需要轉(zhuǎn)換從輸入到輸出的離散數(shù)據(jù)流。許多類型轉(zhuǎn)換在實踐中重復(fù)出現(xiàn),因此將其創(chuàng)建成獨立的可復(fù)用的部分,這是比較理想的。

 2 問題 

這些系統(tǒng)需要被分割成可復(fù)用的松耦合的組件,組件之間擁有簡單通用的交互機(jī)制。這樣它們就可以靈活地相互結(jié)合。這些通用松耦合的組件就很容易復(fù)用。那些獨立的組件可以并行執(zhí)行。

 3 方案 

這種架構(gòu)中的管道構(gòu)成了過濾器之間的通信通道。第一個概念是,由于性能原因,每個管道都是非定向的和點對點的,接受來自一個源的輸入并經(jīng)常直接輸出到另外一個源。

在這種模式中,有如下四種過濾器。

  •  producer(source):一個過程的起點。
  •  transformer (map):對一些或所有數(shù)據(jù)進(jìn)行轉(zhuǎn)換。
  •  tester (reduce):測試一個或多個條件。
  •  consumer (sink):終點。

 4 弱點 

不太適合交互性的系統(tǒng),因為它們的轉(zhuǎn)換特性。

過多的解析和反解析會導(dǎo)致性能損失,也會增加編寫過濾器本身的復(fù)雜性。

 5 用途 

管道 - 過濾器架構(gòu)用于各種應(yīng)用程序,特別是簡化單項處理的任務(wù),例如 EDI、ETL 工具。

編譯器:連續(xù)的過濾器執(zhí)行詞法分析、語法分析、語義分析和代碼生成。

四、客戶端-過濾器架構(gòu)

 1 上下文 

有許多共享資源和服務(wù)是大量分布式的客戶端希望訪問的,我們希望控制訪問或服務(wù)質(zhì)量。

 2 問題 

通過管理一組共享資源和服務(wù),我們可以通過分解公共服務(wù)并在單個位置或少數(shù)位置進(jìn)行修改來提高可修改性和復(fù)用性。我們想要通過在將資源本身分布在多個物理服務(wù)器上的同時集中控制這些資源和服務(wù),來提高可伸縮性和可用性。

 3 方案 

在客戶端 - 服務(wù)器模式中,組件和連接器具有特定的行為。

稱為“客戶端”的組件將請求發(fā)送到稱為“服務(wù)器”的組件,然后等待回復(fù)。

服務(wù)器組件接收到客戶端的請求并向其發(fā)送回復(fù)。

 4 弱點 

服務(wù)器會成為性能瓶頸和單點故障位置。

在系統(tǒng)建成后,關(guān)于功能位置(在客戶端還是在服務(wù)器)的決策通常是復(fù)雜的而且變動成本很大。

 5 用途 

對于有許多組件(客戶端)發(fā)送請求到另外一些提供服務(wù)的組件(服務(wù)器)的系統(tǒng),我們可以使用客戶端 - 服務(wù)器模式來建模這個系統(tǒng)的一部分:在線應(yīng)用程序,例如電子郵件、共享文檔或銀行服務(wù)。

五、模型-視圖-控制器架構(gòu)(MVC)

 1 上下文 

用戶界面通常是一個交互性應(yīng)用程序的最頻繁被修改的部分。用戶通常希望從不同的視角查看數(shù)據(jù),例如柱狀圖或者餅圖。這些表示形式都應(yīng)該反映數(shù)據(jù)當(dāng)前的狀態(tài)。

 2 問題 

用戶界面功能如何獨立于應(yīng)用程序功能,同時還還對用戶輸入或底層應(yīng)用程序數(shù)據(jù)的更改做出響應(yīng)?

當(dāng)?shù)讓討?yīng)用程序數(shù)據(jù)更改時,如何創(chuàng)建、維護(hù)和協(xié)調(diào)用戶界面的多個視圖?

 3 方案 

模型 - 視圖 - 控制器(model-view-controller,即 MVC)模式將應(yīng)用程序功能分為以下三種類型的組件:

  •  模型,包含應(yīng)用程序的數(shù)據(jù)。
  •  視圖,顯示部分底層數(shù)據(jù)并與用戶交互。
  •  控制器,在模型和視圖之間進(jìn)行中介并管理狀態(tài)更改的通知。

 4 弱點 

對于簡單的用戶界面,其復(fù)雜性并不值得這么做。

模型、視圖和控制器抽象可能不適用于某些用戶界面工具包。

 5 用途 

MVC 是網(wǎng)站或移動應(yīng)用程序開發(fā)用戶界面常用的一種架構(gòu)模式。

六、事件驅(qū)動架構(gòu)

 1 上下文 

需要提供計算和信息資源來處理傳入的應(yīng)用程序生成的獨立異步事件,這種方式可以隨著需求的增加而擴(kuò)展。

 2 問題 

構(gòu)建分布式系統(tǒng),這個系統(tǒng)可以服務(wù)異步到達(dá)的事件相關(guān)信息,并且能從簡單小型擴(kuò)展到復(fù)雜大型。

 3 方案 

為事件處理部署獨立的事件進(jìn)程或處理器。到達(dá)的事件進(jìn)入隊列。調(diào)度程序根據(jù)調(diào)度策略從隊列中拉取事件并將它們分配到合適的事件處理器。

 4 弱點 

性能和錯誤恢復(fù)可能是問題。

 5 用途 

使用這個方案的電商應(yīng)用程序?qū)⒐ぷ魅缦拢?/p>

Order Service 創(chuàng)建一個 Order,這個訂單處于待定狀態(tài),然后發(fā)布一個OrderCreated事件。

Customer Service 接收到這個事件并嘗試為這個 Order 扣除信用。然后發(fā)布一個 Credit Reserved 事件或者CreditLimitExceeded(超出信用限額)事件。

Order Service 接收到 Customer Service 發(fā)送的事件并將訂單狀態(tài)更改為已核準(zhǔn)或已取消。

七、微服務(wù)架構(gòu)

 1 上下文 

部署基于服務(wù)器的企業(yè)應(yīng)用程序,支持各種瀏覽器和原生移動客戶端。應(yīng)用程序通過執(zhí)行業(yè)務(wù)邏輯、訪問數(shù)據(jù)庫、與其它系統(tǒng)交換信息并返回響應(yīng)來處理客戶端請求。這個應(yīng)用程序可能會暴露一個第三方 API。

 2 問題 

一體化應(yīng)用程序會變得過于龐大和復(fù)雜,無法得到有效支持和部署來實現(xiàn)最優(yōu)的分布式資源利用,例如在云環(huán)境中。

 3 方案 

將應(yīng)用程序構(gòu)建成服務(wù)套件。每個服務(wù)都是獨立部署和可擴(kuò)展的,擁有自己的 API 邊界。不同的服務(wù)可以用不同的編程語言編寫,管理它們自己的數(shù)據(jù)庫,由不同的團(tuán)隊開發(fā)。

 4 弱點 

系統(tǒng)設(shè)計必須能容忍服務(wù)失敗,需要更多的系統(tǒng)監(jiān)控。服務(wù)編排和事件協(xié)作開銷比較大。

當(dāng)然,我們還需要更多錢。

 5 用途 

許多使用場景都可以應(yīng)用微服務(wù)架構(gòu),特別是那些涉及大量數(shù)據(jù)管道的場景。例如,一個微服務(wù)系統(tǒng)對關(guān)于一個公司的零售店銷售的報表系統(tǒng)會比較理想。數(shù)據(jù)展現(xiàn)過程的每一步都會被一個微服務(wù)處理:數(shù)據(jù)收集、清理、規(guī)范化、濃縮、聚合、報告等。 

 

責(zé)任編輯:龐桂玉 來源: JAVA高級架構(gòu)
相關(guān)推薦

2020-10-26 15:20:05

架構(gòu)運維技術(shù)

2019-07-23 17:20:02

Java微服務(wù)軟件架構(gòu)模式

2021-07-08 09:57:14

程序員架構(gòu)開發(fā)

2015-12-04 09:33:15

程序員前端演進(jìn)史

2019-01-30 14:14:16

LinuxUNIX操作系統(tǒng)

2011-02-23 10:39:56

Java程序員Java開發(fā)

2020-06-28 10:15:39

架構(gòu)模式軟件

2017-09-14 09:30:38

軟件架構(gòu)模式

2015-11-30 11:01:34

前端程序員歷史

2023-09-12 11:25:15

2017-08-03 14:25:13

Python陷阱與缺陷

2012-06-28 14:01:30

Java程序員排序

2023-10-26 18:05:37

Git命令差異

2018-07-11 14:04:53

Python陷阱缺陷

2015-05-19 14:34:17

程序員編程語言

2020-05-13 11:20:57

MySQL規(guī)范數(shù)據(jù)庫

2014-02-09 10:30:17

Python程序員工具

2024-12-04 10:12:06

2023-06-16 13:34:00

軟件架構(gòu)模式

2020-11-25 10:40:58

程序員技能開發(fā)者
點贊
收藏

51CTO技術(shù)棧公眾號

国产无一区二区| 亚洲成人久久久| 久久精品av麻豆的观看方式| 在线免费观看日韩欧美| 精品999在线| 粉嫩av亚洲一区二区图片| 国产成人亚洲精品| 日韩高清在线电影| 欧美不卡1区2区3区| 日韩黄色免费网站| 5g国产欧美日韩视频| 奇米777国产一区国产二区| 精品日韩在线观看| 精品美女在线观看视频在线观看 | 亚洲成人免费av| 在线观看a视频| www.成人网.com| 日韩不卡av| 日韩国产一区二区| 在线亚洲午夜片av大片| 一色桃子av在线| 欧美精品色综合| 一二三四中文在线| 亚洲一区二区三区爽爽爽爽爽| 国产一区二区视频免费在线观看| 日本女人一区二区三区| 99国产超薄丝袜足j在线观看| 米奇777超碰欧美日韩亚洲| 中文字幕在线视频日韩| 日本中文字幕中出在线| 91精品国产aⅴ一区二区| 最新av电影| 亚洲女同女同女同女同女同69| 欧美日韩大尺度| 国产精品毛片久久久久久久| www.男人的天堂.com| 成人欧美一区二区三区白人| 农民人伦一区二区三区| 久久激情五月激情| 久久久久久久午夜| 国产99一区视频免费| 日本美女高潮视频| 在线免费观看成人网| jizz亚洲女人高潮大叫| 一区二区三区www| 日韩一级淫片| 国产精品一久久香蕉国产线看观看| 九热爱视频精品视频| 国产66精品久久久久999小说| 久久国产一二区| 手机在线免费观看毛片| 日韩欧中文字幕| 一区在线影院| 国产精品二区在线观看| 久久亚洲综合av| 黄色网址视频在线观看| 中文字幕亚洲一区在线观看| 给我免费播放日韩视频| 五月天久久狠狠| 亚洲黄色片在线观看| 欧美1—12sexvideos| 国产精品v日韩精品| 国产美女精品一区二区三区| http://嫩草影院| 一区二区三区美女xx视频| 欧美 日韩 国产 一区| 色婷婷狠狠18| www.欧美免费| 免费欧美在线视频| 日韩大胆人体| 91国语精品自产拍在线观看性色| 日本vs亚洲vs韩国一区三区二区 | 欧美一区二区三区免费视频| 啪啪国产精品| 国产在线观看福利| 国产视频亚洲视频| 久久人人97超碰国产公开结果| 黄色录像1级片| 欧美激情在线一区| 成人毛片老司机大片| 亚洲精品无播放器在线播放| 亚洲最大色综合成人av| 日韩欧美国产综合| 亚洲麻豆av| 黄av在线播放| 婷婷五月色综合| 亚洲精品网址在线观看| 国产精品自拍在线| 国产亚洲精彩久久| 日韩精品视频一二三| 国产精品极品美女在线观看免费| 国产精品视频看| 日韩欧美高清| 成人三级黄色免费网站| 99影视tv| 日韩电影免费观看中文字幕| 久久精品国产一区二区| 欧美日韩精品免费观看视欧美高清免费大片| 午夜视频久久久| www.国产精品一二区| 亚洲欧洲av色图| 99精品在线| 久久www人成免费看片中文| 国产精品久久国产| 国产精品入口福利| 亚洲精品一区二三区不卡| 久久亚洲综合色一区二区三区| 另类尿喷潮videofree| 日本中文字幕在线视频| 无码人妻丰满熟妇区96| 91精品网站| 中文字幕欧美日韩| 大陆精大陆国产国语精品| 成人欧美一区二区三区黑人孕妇| 日韩欧美中文字幕公布| 国产成人精品免费一区二区| 中文精品电影| 狂野欧美性猛交xxxx| yjizz视频网站在线播放| 亚洲人免费视频| 欧美视频三区在线播放| 成人手机在线视频| 国产日韩高清一区二区三区在线| 福利一区二区三区视频在线观看| 美国成人毛片| 成人性生生活性生交12| 久久香蕉综合色| 欧美最近摘花xxxx摘花| 亚洲欧美第一页| 欧美调教femdomvk| 亚洲高清免费在线| 国产日韩精品视频一区| 国产一区二区免费看| 欧美午夜影院| 99久久久久久中文字幕一区| ccyy激情综合| 精品久久亚洲| 久久日本片精品aaaaa国产| 欧美裸体视频| 一级毛片视频在线| 欧美色18zzzzxxxxx| 国产美女在线播放| 亚洲欧洲动漫| 992tv在线观看免费进| 色老板在线视频| 自由色视频.| 每日更新av在线播放| 国产精品二线| 国产精品va在线观看视色| av激情在线| 黄色亚洲网站| 午夜不卡一区| 国产传媒欧美日韩成人精品大片| 18国产精品| 欧美极品一区二区三区| 国产婷婷精品| 国产激情91久久精品导航| 成人夜色视频网站在线观看| 国产成人一区在线| 久久久久久久久久美女| 日本一区二区三区四区在线视频 | 国内精品视频一区| 欧美亚洲成人网| 国产精品一区二区三区四区五区| 西游记1978| www.69av| 亚州av影院| 免费网站成人| 欧美一区一区| 六月婷婷一区| 久久精品一区二区三区不卡牛牛| 日韩欧美高清在线视频| 亚洲а∨天堂久久精品喷水| www.欧美免费| 日韩av电影在线观看| 乱小说综合网站| 日本天堂在线观看| 国产精久久一区二区| 亚洲在线观看| 国产麻豆精品久久| 97国产一区二区| 久久久久免费视频| 黄色国产精品视频| 亚洲婷婷影院| 91精品福利视频| 中文字幕av导航| 6080成人| 欧美图片一区二区三区| 色中文字幕在线观看| 亚州国产精品| 亚洲日本一区二区| 欧美在线视频在线播放完整版免费观看| 91福利免费在线| 欧美高清视频在线观看mv| 亚洲视频一二区| 国产精品无av码在线观看| 国产xxxxx在线观看| 国产乱码精品一区二区亚洲| 日韩欧美有码在线| 亚洲精品国产精品国自产|