今天吃完飯休息的時候瞎逛知乎,忽然看到這個一個問題Spring Cloud在國內中小型公司能用起來嗎?,吸引了個人注意。仔細的看了題主的問題,發現這是一個好問題,題主通過了一番思考,而且用圖形全面的將本身的疑問表達了出來,做爲一個研究並使用Spring Boot和Spring Cloud近兩年的程序員,看的我手癢癢不答不快呀。html
好問題必須配認真的回答,仔細的看了題主的問題,發現這個問題很是具備表明性,多是廣大網友想使用Spring Cloud卻又對Spring Cloud不太瞭解的共同想法,題主對Spring Cloud使用的方方面面都進行過了思考,包括市場,學習、先後端、測試、配置、部署、開發以及運維,下面就是題主本來的問題:前端
想在公司推廣Spring Cloud,但我對這項技術還缺少了解,畫了一張腦圖,總結了種種問題。java
微服務是這樣一個結構嗎? nginx
前端或二方 - > ng集羣 -> zuul集羣 -> eureka-server集羣 -> service provider集羣複製代碼
(二方指其餘業務部門)git
想要明白這個問題,首先須要知道什麼是Spring Boot,什麼是Spring Cloud,以及二者之間有什麼關係?程序員
Spring Boot簡化了基於Spring的應用開發,經過少許的代碼就能建立一個獨立的、產品級別的Spring應用。 Spring Boot爲Spring平臺及第三方庫提供開箱即用的設置,這樣你就能夠有條不紊地開始。多數Spring Boot應用只須要不多的Spring配置。github
Spring Boot是由Pivotal團隊提供的全新框架,其設計目的是用來簡化新Spring應用的初始搭建以及開發過程。該框架使用了特定的方式來進行配置,從而使開發人員再也不須要定義樣板化的配置。用個人話來理解,就是Spring Boot其實不是什麼新的框架,它默認配置了不少框架的使用方式,就像maven整合了全部的jar包,Spring Boot整合了全部的框架(不知道這樣比喻是否合適)。redis
Spring Boot的核心思想就是約定大於配置,一切自動完成。採用Spring Boot能夠大大的簡化你的開發模式,全部你想集成的經常使用框架,它都有對應的組件支持。若是你對Spring Boot徹底不瞭解,能夠參考個人這篇文章:Springboot(一):入門篇spring
Spring Cloud是一系列框架的有序集合。它利用Spring Boot的開發便利性巧妙地簡化了分佈式系統基礎設施的開發,如服務發現註冊、配置中心、消息總線、負載均衡、斷路器、數據監控等,均可以用Spring Boot的開發風格作到一鍵啓動和部署。Spring並無重複製造輪子,它只是將目前各家公司開發的比較成熟、經得起實際考驗的服務框架組合起來,經過Spring Boot風格進行再封裝屏蔽掉了複雜的配置和實現原理,最終給開發者留出了一套簡單易懂、易部署和易維護的分佈式系統開發工具包。數據庫
微服務是能夠獨立部署、水平擴展、獨立訪問(或者有獨立的數據庫)的服務單元,Spring Cloud就是這些微服務的大管家,採用了微服務這種架構以後,項目的數量會很是多,Spring Cloud作爲大管家就須要提供各類方案來維護整個生態。
Spring Cloud就是一套分佈式服務治理的框架,既然它是一套服務治理的框架,那麼它自己不會提供具體功能性的操做,更專一於服務之間的通信、熔斷、監控等。所以就須要不少的組件來支持一套功能,若是你對Spring Cloud組件不是特別瞭解的話,能夠參考個人這篇文章:springcloud(一):大話Spring Cloud
Spring Boot 是 Spring 的一套快速配置腳手架,能夠基於Spring Boot 快速開發單個微服務,Spring Cloud是一個基於Spring Boot實現的雲應用開發工具;Spring Boot專一於快速、方便集成的單個微服務個體,Spring Cloud關注全局的服務治理框架;Spring Boot使用了默認大於配置的理念,不少集成方案已經幫你選擇好了,能不配置就不配置,Spring Cloud很大的一部分是基於Spring Boot來實現,能夠不基於Spring Boot嗎?不能夠。
Spring Boot能夠離開Spring Cloud獨立使用開發項目,可是Spring Cloud離不開Spring Boot,屬於依賴的關係。
Spring -> Spring Boot > Spring Cloud 這樣的關係。
如下爲我在知乎的回答。
首先樓主問的這些問題都挺好的,算是通過了本身的一番思考,我剛好經歷了你所說的中小公司,且都使用Spring Cloud而且已經投產上線。第一家公司技術開發人員15人左右,項目實例 30多,第二家公司開發人員100人左右,項目實例達160多。
實話說Spring Boot、Spring Cloud仍在高速發展,技術生態不斷的完善和擴張,難免也會有一些小的bug,但對於中小公司的使用來將,徹底能夠忽略,基本均可以找到解決方案,接下來回到你的問題。
一、市場
據我所知有不少知名互聯網公司都已經使用了Spring Cloud,好比阿里、美團但都是小規模,沒有像我經歷的這倆家公司,業務線所有擁抱Spring Cloud;另外Spring Cloud並非一套高深的技術,普通的Java程序員通過一到倆個月徹底就能夠上手,但前期須要一個比較精通人的來帶隊。
二、學習
有不少種方式,如今Spring Cloud愈來愈火的狀況下,各類資源也愈來愈豐富,查看官方文檔和示例,如今不少優秀的博客在寫spirng cloud的相關教程,我這裏收集了一些Spring Boot和Spring Cloud的相關資源能夠參考,找到博客也就找到人和組織了。
三、先後職責劃分
其實這個問題是每一個系統架構都應該考慮的問題,Spring Cloud只是後端服務治理的一套框架,惟一和前端有關係的是thymeleaf,Spring推薦使用它作模板引擎。通常狀況下,前端app或者網頁經過zuul來調用後端的服務,若是包含靜態資源也可使用nginx作一下代理轉發。
四、測試
Spring-boot-starter-test支持項目中各層方法的測試,也支持controller層的各類屬性。因此通常測試的步奏是這樣,首先開發人員覆蓋本身的全部方法,而後測試微服務內全部對外接口保證微服務內的正確性,再進行微服務之間集成測試,最後交付測試。
五、配置
session共享有不少種方式,好比使用tomcat sesion共享機制,但我比較推薦使用redis緩存來作session共享。徹底能夠分批引入,我在上一家公司就是分批過渡上線,新舊項目經過zuul進行交互,分批引入的時候,最好是新業務線先使用Spring Cloud,老業務作過渡,當徹底掌握以後在所有替換。若是隻是請求轉發,zuul的性能不必定比nginx低,可是若是涉及到靜態資源,仍是建議在前端使用nginx作一下代理。另外Spring Cloud有配置中心,能夠很是靈活的作全部配置的事情。
六、部署
多環境不一樣配置,Spring Boot最擅長作這個事情了,使用不一樣的配置文件來配置不一樣環境的參數,在服務啓動的時候指明某個配置文件便可,例如:java -jar app.jar --spring.profiles.active=dev
就是啓動測試環境的配置文件;Spring Cloud 沒有提供發佈平臺,由於jenkins已經足夠完善了,推薦使用jenkins來部署Spring Boot項目,會省很是多的事情;灰度暫時不支持,可能須要本身來作,若是有多個實例,能夠一個一個來更新;支持混合部署,一臺機子部署多個是常見的事情。
七、開發
你說的包含html接口就是前端頁面吧,Spring Boot能夠支持,但其實也是Spring Mvc在作這個事情,Spring Cloud只作服務治理,其它具體的功能都是集成了各類框架來解決而已;excel報表能夠,其實除過swing項目外,其它Java項目均可以想象;Spring Cloud和老項目能夠混合使用,經過zuul來支持。是否支持callback,能夠經過MQ來實現,仍是強調Spring Cloud只是服務治理。
八、運維
Turbine、zipkin能夠用來作熔斷和性能監控;動態上下線某個節點能夠經過jenkins來實現;provider下線後,會有其它相同的實例來提供服務,Eureka會間隔一段時間來檢測服務的可用性;不一樣節點配置不一樣的流量權值目前還不支持。註冊中心必須作高可用集羣,註冊中心掛掉以後,服務實例會所有中止。
總結,中小企業是否能用的起來Spring Cloud,徹底取決於本身公司的環境,若是是一個技術活躍型的團隊就大膽的去嘗試吧,目前Spring Cloud是全部微服務治理中最優秀的方案,也是一個趨勢,將來一兩年可能就會像Spring同樣流行,早接觸早學習豈不更好。
但願能解答了你的疑問。
咱們從總體來看一下Spring Cloud主要的組件,以及它的訪問流程
圖中沒有畫出配置中心,配置中心管理各微服務不一樣環境下的配置文件。
以上就是一個完整的Spring Cloud生態圖。
最後送一個完整示例的Spirng Cloud開源項目等你去spring-cloud-examples
喜歡個人文章,請關注個人公衆號
做者:純潔的微笑
出處:www.ityouknow.com/
版權歸做者全部,轉載請註明出處