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

四種常見的軟件架構概述

開發 架構
如果一個軟件開發人員,不了解軟件架構的演進,會制約技術的選型和開發人員的生存、晉升空間。這里我列舉了目前主要的四種軟件架構以及他們的優缺點,希望能夠幫助軟件開發人員拓展知識面。

 [[403668]]

前言

如果一個軟件開發人員,不了解軟件架構的演進,會制約技術的選型和開發人員的生存、晉升空間。這里我列舉了目前主要的四種軟件架構以及他們的優缺點,希望能夠幫助軟件開發人員拓展知識面。

單體架構

單體架構比較初級,典型的三級架構,前端(Web/手機端)+中間業務邏輯層+數據庫層。這是一種典型的Java Spring mvc或者Python Django框架的應用。其架構圖如下所示:

單體架構模型

單體架構的應用比較容易部署、測試, 在項目的初期,單體應用可以很好地運行。然而,隨著需求的不斷增加, 越來越多的人加入開發團隊,代碼庫也在飛速地膨脹。慢慢地,單體應用變得越來越臃腫,可維護性、靈活性逐漸降低,維護成本越來越高。下面是單體架構應用的一些缺點:

復雜性高:以一個百萬行級別的單體應用為例,整個項目包含的模塊非常多、模塊的邊界模糊、 依賴關系不清晰、 代碼質量參差不齊、 混亂地堆砌在一起??上攵麄€項目非常復雜。每次修改代碼都心驚膽戰, 甚至添加一個簡單的功能, 或者修改一個Bug都會帶來隱含的缺陷。

技術債務:隨著時間推移、需求變更和人員更迭,會逐漸形成應用程序的技術債務, 并且越積 越多。“ 不壞不修”, 這在軟件開發中非常常見, 在單體應用中這種思想更甚。已使用的系統設計或代碼難以被修改,因為應用程序中的其他模塊可能會以意料之外的方式使用它。

部署頻率低:隨著代碼的增多,構建和部署的時間也會增加。而在單體應用中, 每次功能的變更或缺陷的修復都會導致需要重新部署整個應用。全量部署的方式耗時長、 影響范圍大、 風險高, 這使得單體應用項目上線部署的頻率較低。而部署頻率低又導致兩次發布之間會有大量的功能變更和缺陷修復,出錯率比較高。

可靠性差:某個應用Bug,例如死循環、內存溢出等, 可能會導致整個應用的崩潰。

擴展能力受限:單體應用只能作為一個整體進行擴展,無法根據業務模塊的需要進行伸縮。例如,應用中有的模塊是計算密集型的,它需要強勁的CPU;有的模塊則是IO密集型的,需要更大的內存。由于這些模塊部署在一起,不得不在硬件的選擇上做出妥協。

阻礙技術創新:單體應用往往使用統一的技術平臺或方案解決所有的問題, 團隊中的每個成員 都必須使用相同的開發語言和框架,要想引入新框架或新技術平臺會非常困難。

分布式應用

中級架構,分布式應用,中間層分布式+數據庫分布式,是單體架構的并發擴展,將一個大的系統劃分為多個業務模塊,業務模塊分別部署在不同的服務器上,各個業務模塊之間通過接口進行數據交互。數據庫也大量采用分布式數據庫,如redis、ES、solor等。通過LVS/Nginx代理應用,將用戶請求均衡的負載到不同的服務器上。其架構圖如下所示:

分布式架構

該架構相對于單體架構來說,這種架構提供了負載均衡的能力,大大提高了系統負載能力,解決了網站高并發的需求。另外還有以下特點:

降低了耦合度:把模塊拆分,使用接口通信,降低模塊之間的耦合度。

責任清晰:把項目拆分成若干個子項目,不同的團隊負責不同的子項目。

擴展方便:增加功能時只需要再增加一個子項目,調用其他系統的接口就可以。

部署方便:可以靈活的進行分布式部署。

提高代碼的復用性:比如service層,如果不采用分布式rest服務方式架構就會在手機wap商城,微信商城,pc,android,ios每個端都要寫一個service層邏輯,開發量大,難以維護一起升級,這時候就可以采用分布式rest服務方式,公用一個service層。

缺點 : 系統之間的交互要使用遠程通信,接口開發增大工作量,但是利大于弊。

微服務架構

微服務架構,主要是中間層分解,將系統拆分成很多小應用(微服務),微服務可以部署在不同的服務器上,也可以部署在相同的服務器不同的容器上。當應用的故障不會影響到其他應用,單應用的負載也不會影響到其他應用,其代表框架有Spring cloud、Dubbo等。其架構圖如下所示:

微服務架構

易于開發和維護:一個微服務只會關注一個特定的業務功能,所以它業務清晰、代碼量較少。開發和維護單個微服務相對簡單。而整個應用是由若干個微服務構建而成的,所以整個應用也會被維持在一個可控狀態。

單個微服務啟動較快:單個微服務代碼量較少, 所以啟動會比較快。

局部修改容易部署:單體應用只要有修改,就得重新部署整個應用,微服務解決了這樣的問題。一般來說,對某個微服務進行修改,只需要重新部署這個服務即可。

技術棧不受限:在微服務架構中,可以結合項目業務及團隊的特點,合理地選擇技術棧。例如某些服務可使用關系型數據庫MySQL;某些微服務有圖形計算的需求,可以使用Neo4j;甚至可根據需要,部分微服務使用Java開發,部分微服務使用Node.js開發。

微服務雖然有很多吸引人的地方,但它并不是免費的午餐,使用它是有代價的。使用微服務架構面臨的挑戰。

運維要求較高:更多的服務意味著更多的運維投入。在單體架構中,只需要保證一個應用的正常運行。而在微服務中,需要保證幾十甚至幾百個服務服務的正常運行與協作,這給運維帶來了很大的挑戰。

分布式固有的復雜性:使用微服務構建的是分布式系統。對于一個分布式系統,系統容錯、網絡延遲、分布式事務等都會帶來巨大的挑戰。

接口調整成本高:微服務之間通過接口進行通信。如果修改某一個微服務的API,可能所有使用了該接口的微服務都需要做調整。

重復勞動:很多服務可能都會使用到相同的功能,而這個功能并沒有達到分解為一個微服務的程度,這個時候,可能各個服務都會開發這一功能,從而導致代碼重復。盡管可以使用共享庫來解決這個問題(例如可以將這個功能封裝成公共組件,需要該功能的微服務引用該組件),但共享庫在多語言環境下就不一定行得通了。

Serverless 架構

當我們還在容器的浪潮中前行時,已經有一些革命先驅悄然布局另外一個云計算戰場:Serverless架構。

Serverless架構

2014年11月14日,亞馬遜AWS發布了新產品Lambda。當時Lambda被描述為:一種計算服務,根據時間運行用戶的代碼,無需關心底層的計算資源。從某種意義上來說,Lambda姍姍來遲,它像云計算的PaaS理念:客戶只管業務,無需擔心存儲和計算資源。在此前不久,2014年10月22日,谷歌收購了實時后端數據庫創業公司Firebase。Firebase聲稱開發者只需引用一個API庫文件就可以使用標準REST API的各種接口對數據進行讀寫操作,只需編寫HTML+CSS+JavaScrip前端代碼,不需要服務器端代碼(如需整合,也極其簡單)。

相對于上兩者,Facebook 在2014年二月收購的 Parse,則側重于提供一個通用的后臺服務。這些服務被稱為Serverless或no sever。想到PaaS(平臺即服務)了是嗎?很像,用戶不需要關心基礎設施,只需要關心業務,這是遲到的PaaS,也是更實用的PaaS。這很有可能將會變革整個開發過程和傳統的應用生命周期,一旦開發者們習慣了這種全自動的云上資源的創建和分配,或許就再也回不到那些需要微應用配置資源的時代里去了。

Serverless架構能夠讓開發者在構建應用的過程中無需關注計算資源的獲取和運維,由平臺來按需分配計算資源并保證應用執行的SLA(服務等級協議),按照調用次數進行計費,有效的節省應用成本。ServerLess的架構如上圖所示。其優點如下所示:

低運營成本:在業務突發性極高的場景下,系統為了應對業務高峰,必須構建能夠應對峰值需求的系統,這個系統在大部分時間是空閑的,這就導致了嚴重的資源浪費和成本上升。在微服務架構中,服務需要一直運行,實際上在高負載情況下每個服務都不止一個實例,這樣才能完成高可用性;在Serverless架構下,服務將根據用戶的調用次數進行計費,按照云計算pay-as-you-go原則,如果沒有東西運行,你就不必付款,節省了使用成本。同時,用戶能夠通過共享網絡、硬盤、CPU等計算資源,在業務高峰期通過彈性擴容方式有效的應對業務峰值,在業務波谷期將資源分享給其他用戶,有效的節約了成本。

簡化設備運維:在原有的IT體系中,開發團隊即需要維護應用程序,同時還要維護硬件基礎設施;Serverless架構中,開發人員面對的將是第三方開發或自定義的API 和URL,底層硬件對于開發人員透明化了,技術團隊無需再關注運維工作,能夠更加專注于應用系統開發。

提升可維護性:Serverless架構中,應用程序將調用多種第三方功能服務,組成最終的應用邏輯。目前,例如登陸鑒權服務,云數據庫服務等第三方服務在安全性、可用性、性能方面都進行了大量優化,開發團隊直接集成第三方的服務,能夠有效的降低開發成本,同時使得應用的運維過程變得更加清晰,有效的提升了應用的可維護性。

更快的開發速度:這一點在現在互聯網創業公司得到很好的體現,創業公司往往開始由于人員和資金等問題,不可能每個產品線都同時進行,這時候就可以考慮第三方的Baas平臺,比如使用微信的用戶認證、阿里云提供的RDS,極光的消息推送,第三方支付及地理位置等等,能夠很快進行產品開發的速度,把工作重點放在業務實現上,把產品更快的推向市場。

但ServerLess架構也有其缺點:

廠商平臺綁定:平臺會提供Serverless架構給大玩家,比如AWS Lambda,運行它需要使用AWS指定的服務,比如API網關,DynamoDB,S3等等,一旦你在這些服務上開發一個復雜系統,你會粘牢AWS,以后只好任由他們漲價定價或者下架等操作,個性化需求很難滿足,不能進行隨意的遷移或者遷移的成本比較大,同時不可避免帶來一些損失。Baas行業內一個比較典型的事件,2016年1月19日Facebook關閉曾經花巨額資金收購的Parse,造成用戶不得不遷移在這個平臺中產生一年多的數據,無疑需要花費比較大的人力和時間成本。

成功案例比較少,沒有行業標準:目前的情況也只適合簡單的應用開發,缺乏大型成功案例的推動。對于Serverless缺乏統一的認知以及相應的標準,無法適應所有的云平臺。

目前微服務架構在四種架構中處于主流地位,很多應用第一、第二種架構的企業也開始慢慢轉向微服務架構。到目前為止微服務的技術相對于二三年前已經比較成熟,第四種架構將是未來發展的一種趨勢。 

 

責任編輯:龐桂玉 來源: 良許Linux
相關推薦

2011-11-24 16:34:39

Java

2024-10-24 08:04:00

2017-07-14 16:28:21

2015-05-08 12:24:10

惡意軟件逃避技術

2024-03-20 15:33:12

2025-09-05 01:23:00

PyTorchPython分支

2010-08-13 13:31:48

Flex效果組件

2021-09-01 10:05:04

機器學習人工智能算法

2022-01-05 22:43:55

云安全架構數據

2025-04-22 03:00:00

2024-11-28 09:06:52

2011-06-30 14:45:52

外鏈

2024-11-07 11:17:50

2021-08-12 11:37:23

數據分析錯誤

2009-03-06 16:30:51

2018-06-20 08:47:44

DevOps微服務UX設計師

2023-10-30 11:40:36

OOM線程池單線程

2021-11-15 09:18:39

勒索軟件黑客數據備份

2010-06-18 09:19:39

UML面向對象建模

2020-06-28 10:15:39

架構模式軟件
點贊
收藏

51CTO技術棧公眾號

91精品国产一区二区三区动漫| 黄网站免费入口| 制服丝袜亚洲播放| 伊人一区二区三区久久精品| 成人丁香基地| 九九久久精品视频| 国产精品夫妻激情| 卡通欧美亚洲| 在线观看av不卡| 午夜伦伦电影理论片费看| 蜜桃av噜噜一区| 国产精品欧美激情| 精品成人免费一区二区在线播放| 欧美日韩黄色大片| 少妇高清精品毛片在线视频| 青青国产91久久久久久| 国产欧美精品va在线观看| 91成人在线| 精品国内二区三区| 国产最新视频在线| 亚洲欧美区自拍先锋| 97超碰在线视| 老司机久久99久久精品播放免费| 成人激情电影一区二区| 一本久久青青| 久久久久久高潮国产精品视| 日本一区免费网站| 亚洲电影免费观看高清完整版在线| 中午字幕在线观看| 玉米视频成人免费看| www.日本xxxx| 国产九九视频一区二区三区| 国产在线精品一区| 亚洲激情中文| 国产精品久久久久久久久免费看| 91综合精品国产丝袜长腿久久| 亚洲天堂久久av| 亚洲综合影视| 欧美本精品男人aⅴ天堂| 国产一级二级三级在线观看| 久久亚洲春色中文字幕久久久| 91香蕉视频网址| 奇米色一区二区三区四区| 好看的日韩精品视频在线| 欧美日韩 国产精品| 99精品99久久久久久宅男| 激情综合在线| 欧美不卡在线一区二区三区| 久久久水蜜桃av免费网站| 欧美一区1区三区3区公司| 日韩二区在线观看| 欧美性受xxxx黑人猛交88| 国产伦精一区二区三区| 国产卡一卡二在线| 国产99久久久国产精品潘金网站| 欧美日韩视频免费在线观看| 成人深夜在线观看| 国产v亚洲v天堂无码久久久| 久久久久久夜精品精品免费| 成人小视频在线看| 1区2区3区国产精品| 青檬在线电视剧在线观看| 精品国产1区2区| 91最新在线| 亚洲精品国产精品国自产观看浪潮| 蜜桃av在线| 日韩在线观看av| 国产一区二区三区免费在线| 久久成人在线视频| 日韩电影一区| 欧美日本国产精品| 国产成人aaa| 99aiav| 欧美性高潮在线| 色a资源在线| 亚洲精品永久免费精品| 热久久久久久| 日韩美女视频在线观看| 亚洲国产高清一区| 精品国产无码在线| 中文字幕在线观看一区| 国产资源在线看| 亚洲精品一区二三区不卡| 中文字幕一区二区三区中文字幕 | 日本韩国精品一区二区在线观看| 97最新国自产拍视频在线完整在线看| 日韩一区二区三区在线| 一区二区三区电影大全| 欧美孕妇与黑人孕交| 欧美体内she精视频在线观看| 色香蕉在线观看| 国产精品欧美久久久久一区二区| 国产高清视频免费最新在线| 欧美成人精品二区三区99精品| 四虎影视精品永久在线观看| 成人欧美一区二区三区在线湿哒哒| 久99久精品视频免费观看| 四虎av网址| 欧美tickling网站挠脚心| 精品中文视频| 91在线观看免费高清完整版在线观看| 美女看a上一区| 在线观看国产视频一二三| 亚洲第一av网站| 成人午夜国产| 一区二区三区精品国产| 午夜伊人狠狠久久| 四虎精品一区二区免费| 国内精品视频免费| 国产精品不卡在线观看| 丰满大乳少妇在线观看网站| 欧洲美女免费图片一区| 六月婷婷色综合| 一级片在线观看| 欧美成人中文字幕| 日韩二区三区在线观看| 中文字幕校园春色| 最好看的2019的中文字幕视频| 亚洲国产二区| 日日噜噜噜夜夜爽爽狠狠| 在线日韩av观看| 爽爽淫人综合网网站 | 久久成人一区| 免费毛片aaaaaa| 日韩视频免费中文字幕| 久久精品一区| 啦啦啦啦免费高清视频在线观看1| 国产一区二区三区在线观看视频 | 韩国精品免费视频| 大片免费在线观看| 亚洲一区二区三区xxx视频| 亚洲一区二区中文在线| 亚洲资源网站| 免费黄色av电影| 国产精品高清在线观看| 一区二区高清在线| 成人羞羞网站| 日本一区二区三区在线观看视频| 成人国产精品日本在线| 色婷婷综合激情| 在线精品一区二区| 色a资源在线| 国产精品jizz在线观看老狼| 亚洲国产精品系列| 国产精品99久久久久久似苏梦涵 | 极品束缚调教一区二区网站| 日韩一级免费看| 欧美做爰性生交视频| 久久亚洲私人国产精品va| 一区二区三区在线免费视频| 99re国产精品| 亚洲黑丝一区二区| 日韩综合在线视频| 久久婷婷一区| 亚洲男帅同性gay1069| 亚洲成人av电影在线| 欧美一区欧美二区| 日本欧美国产在线| 久久久久久久久久久久久9999| 777精品久无码人妻蜜桃| 免费av在线| 教室别恋欧美无删减版| 国产99精品国产| 在线看一区二区| 2019av中文字幕| 男人天堂成人网| 欧美亚洲精品一区二区| 91精彩视频在线播放| 国产精品一区二区三区美女| 日韩成人午夜精品| 中文字幕在线观看不卡| 中文字幕亚洲图片| 性生活免费观看视频| 免费看a在线观看| 草民电影神马电影一区二区| 国产一区在线精品| 在线播放日韩专区| 人人澡人一摸人人添| 日韩精品四区| 欧美日韩电影一区| 亚洲在线播放电影| 亚洲精品观看| 国产亚洲制服色| 欧美va日韩va| 91精品91久久久中77777老牛| 中文字幕日韩亚洲| 精品一区二区三区久久久| 91精品婷婷国产综合久久竹菊| 久久久久久久久一区二区| 男女视频在线| 国产麻豆视频一区| 欧美日韩精品在线| 国产精品香蕉在线观看| 日本24小时在线高清视频| 欧美黄色录像片| 久久影院午夜片一区| 欧美精品一区二区免费| 国产精品裸体瑜伽视频| 日韩一级视频| 激情文学综合丁香|