微服務的概念源於Martin Fowler所寫的一篇文章「Microservices」。git
微服務架構是一種架構模式,它提倡將單一應用程序劃分紅一組小的服務,服務之間互相協調、互相配合,爲用戶提供最終價值。每一個服務運行在其獨立的進程中,服務與服務間採用輕量級的通訊機制互相溝通(一般是基於HTTP的RESTful
API)。每一個服務都圍繞着具體業務進行構建,而且可以被獨立地部署到生產環境、類生產環境等。另外,應儘可能避免統一的、集中式的服務管理機制,對具體的一個服務而言,應根據業務上下文,選擇合適的語言、工具對其進行構建。算法
微服務是一種架構風格,一個大型複雜軟件應用由一個或多個微服務組成。系統中的各個微服務可被獨立部署,各個微服務之間是鬆耦合的。每一個微服務僅關注於完成一件任務並很好地完成該任務。在全部狀況下,每一個任務表明着一個小的業務能力。segmentfault
Martin Fowler提出來這一律念能夠說把SOA的理念繼續昇華,精進了一步。 微服務架構強調的第一個重點就是業務系統須要完全的組件化和服務化,原有的單個業務系統會拆分爲多個能夠獨立開發,設計,運行和運維的小應用。這些小應用之間經過服務完成交互和集成。後端
從服務粒度上,既然是微,必然微服務更倡導服務的細粒度,重用組合,甚至是每一個操做(或方法)都是獨立開發的服務,足夠小到不能再進行拆分。而SOA沒有這麼極致的要求,只須要接口契約的規範化,內部實現能夠更粗粒度,微服務更多爲了可擴充性、負載均衡以及提升吞吐量而去分解應用,但同時也引起了打破數據模型以及維護一致性的問題。安全
從部署方式上,這個是最大的不一樣,對比以往的Java
EE部署架構,經過展示層打包WARs,業務層劃分到JARs最後部署爲EAR一個大包,而微服務則把應用拆分紅爲一個一個的單個服務,應用Docker技術,不依賴任何服務器和數據模型,是一個
全棧應用,能夠經過自動化方式獨立部署,每一個服務運行在本身的進程。服務器
若是一句話來談SOA和微服務的區別,即微服務再也不強調傳統SOA架構裏面比較重的ESB企業服務總線,同時SOA的思想進入到單個業務系統內部實現真正的組件化。架構
在將應用分解,每個微服務專一於單一功能,並經過定義良好的接口清晰表述服務邊界。因爲體積小、複雜度低,每一個微服務可由一個小規模開發團隊徹底掌控,易於保持高可維護性和開發效率。負載均衡
因爲微服務具有獨立的運行進程,因此每一個微服務也能夠獨立部署。框架
在微服務架構下,故障會被隔離在單個服務中。若設計良好,其餘服務可經過重試、平穩退化等機制實現應用層面的容錯。運維
單塊架構應用也能夠實現橫向擴展,就是將整個應用完整的複製到不一樣的節點。
Spring
Boot 框架是由 Pivotal 團隊提供的全新框架,其設計目的是用來簡化基於 Spring
應用的初始搭建以及開發過程。SpringBoot
框架使用了特定的方式來進行應用系統的配置,從而使開發人員再也不須要耗費大量精力去定義模板化的配置文件。
Spring Cloud 是一個基於 Spring Boot 實現的雲應用開發工具,它爲基於 JVM 的雲應用開發中的配置管理、服務發現、斷路器、智能路由、微代理、控制總線、全局鎖、決策競選、分佈式會話和集羣狀態管理等,是微服務的一種實現。
Spring Cloud Netflix 集成衆多Netflix的開源軟件:Eureka, Hystrix, Zuul, Archaius,組成了微服務的最重要的核心組件。
服務中心,用於服務註冊與發現,一個基於 REST 的服務,用於定位服務。
熔斷器,容錯管理工具,旨在經過熔斷機制控制服務和第三方庫的節點,從而對延遲和故障提供更強大的容錯能力。
Zuul 是在雲平臺上提供動態路由,監控,彈性,安全等邊緣服務的框架。
配置管理API,包含一系列配置管理API,提供動態類型化屬性、線程安全配置操做、輪詢框架、回調機制等功能,能夠實現動態獲取配置。
配置中心,利用git集中管理程序的配置。
事件、消息總線,用於在集羣(例如,配置變化事件)中傳播狀態變化,可與Spring Cloud Config聯合實現熱部署。
Ribbon是Netflix發佈的負載均衡器,它有助於控制HTTP和TCP的客戶端的行爲。爲Ribbon配置服務提供者地址後,Ribbon就可基於某種負載均衡算法,自動地幫助服務消費者去請求。
經過這張圖,能夠比較清楚的瞭解到各組件配置使用運行機制:
一、請求統一經過API網關(Zuul)來訪問內部服務.
二、網關接收到請求後,從註冊中心(Eureka)獲取可用服務
三、由Ribbon進行均衡負載後,分發到後端具體實例
四、微服務之間經過Feign進行通訊處理業務
五、Hystrix負責處理服務超時熔斷
六、Turbine監控服務間的調用和熔斷相關指標
微服務是一種架構的理念,提出了微服務的設計原則,從理論爲具體的技術落地提供了指導思想。