前言
微服務(wù)并不神秘,只是在互聯(lián)網(wǎng)技術(shù)發(fā)展過程中的一個(gè)產(chǎn)物,整個(gè)架構(gòu)系統(tǒng)隨著客戶端的多樣性,服務(wù)越來越多,devops的發(fā)展而產(chǎn)生的架構(gòu)變種。
許多公司,通過采用微處理結(jié)構(gòu)模式解決單體應(yīng)用的問題,分解的服務(wù)之間互相連接提供支持。
每個(gè)微服務(wù)都是六邊形應(yīng)用,都有自己的業(yè)務(wù)邏輯和適配器。服務(wù)之間通過API互相通信,提供接口供客戶端使用。每個(gè)實(shí)例可能是一個(gè)云VM或者是Docker容器。
之前的web應(yīng)用拆分成一系列簡單的服務(wù)應(yīng)用。拆分之后可以對(duì)不同用戶,不同設(shè)備,不同場景進(jìn)行自行部署。
微服務(wù)之間通過REST API或者M(jìn)Q異步方式通信,供外網(wǎng)使用的API,通過Gateway來傳遞信息。
微服務(wù)的拆分,不像傳統(tǒng)多個(gè)服務(wù)共享一個(gè)數(shù)據(jù)庫,微服務(wù)架構(gòu)每個(gè)服務(wù)都有自己的數(shù)據(jù)庫,每種服務(wù)都可以有自己適合的數(shù)據(jù)庫類型。
微服務(wù)好處
分解了單體應(yīng)用提供多個(gè)服務(wù)的復(fù)雜性問題,拆分之后每個(gè)服務(wù)都有一個(gè)用RPC或是MQ或是API定義的邊界。由于傳統(tǒng)單體應(yīng)用沒有清晰的邊界,存在開發(fā),理解,維護(hù),部署的復(fù)雜問題;
每個(gè)服務(wù)都可以有單獨(dú)的團(tuán)隊(duì)維護(hù)開發(fā),開發(fā)者客戶選擇自己擅長和合適的技術(shù);
每個(gè)服務(wù)都可以獨(dú)立部署,開發(fā)者不需要協(xié)調(diào)因其他服務(wù)調(diào)用,部署對(duì)本服務(wù)的影響。加快部署速度,更好的執(zhí)行AB測試。持續(xù)部署變?yōu)榭赡堋?/p>
每個(gè)服務(wù)都可以獨(dú)立擴(kuò)展。