
理解不是很深刻會(huì)經(jīng)常問(wèn)道這樣類(lèi)似的問(wèn)題,下面我就簡(jiǎn)單講解一下Spring boot與Spring cloud 之間的關(guān)系!
學(xué)過(guò)Spring的都知道,Spring開(kāi)發(fā)有非常頭疼的三點(diǎn):
以啟動(dòng)一個(gè)帶Hibernate的Spring MVC為例。
1. 依賴(lài)太多了,而且要注意版本兼容。這個(gè)應(yīng)用,要添加10-20個(gè)依賴(lài),Spring相關(guān)的包10多個(gè),然后是Hibernate包,Spring與Hibernate整合包,日志包,json包一堆,而且要注意版本兼容性。
2. 配置太多了,要配置注解驅(qū)動(dòng),要配置數(shù)據(jù)庫(kù)連接池,要配置Hibernate,要配置事務(wù)管理器,要配置Spring MVC的資源映射,要在web.xml中配置啟動(dòng)Spring和Spring MVC等
3.部署和運(yùn)行麻煩。要部署到tomcat里面。不能直接用java命令運(yùn)行。
太多重復(fù)和大家都一樣的配置了。
Spring Boot的哲學(xué)就是約定大于配置。既然很多東西都是一樣的,為什么還要去配置。
1. 通過(guò)starter和依賴(lài)管理解決依賴(lài)問(wèn)題。
2. 通過(guò)自動(dòng)配置,解決配置復(fù)雜問(wèn)題。
3. 通過(guò)內(nèi)嵌web容器,由應(yīng)用啟動(dòng)tomcat,而不是tomcat啟動(dòng)應(yīng)用,來(lái)解決部署運(yùn)行問(wèn)題。
Spring Cloud體系就比較復(fù)雜了?;究梢岳斫鉃橥ㄟ^(guò)Spring Boot的三大魔法,將各種組件整合在一起,非常簡(jiǎn)單易用。
你可以把spring boot的官方的包分為兩類(lèi),一種是為了搭建一個(gè)服務(wù)用的,比如hibernate jpa,比如 message。另外一種含有cloud關(guān)鍵字的,是為了各個(gè)spring boot之前管理和使用的包。
因?yàn)楫?dāng)把集群、CI等方法集中進(jìn)來(lái)一起考慮的時(shí)候,這件事情就復(fù)雜了。
多個(gè)小有服務(wù)整合成的大服務(wù),要有一個(gè)消息總線來(lái)用于互相通知和調(diào)用,要有一個(gè)服務(wù)發(fā)現(xiàn)程序來(lái)管理某個(gè)小服務(wù)上線可用,同時(shí)在服務(wù)離線時(shí)也要能處理,各個(gè)小服務(wù)要盡量各自獨(dú)立,還要考慮服務(wù)的依賴(lài)性,集群的負(fù)載均衡,配置文件的分離。
再把CI和Docker拿進(jìn)來(lái)一起考慮的話(huà),更亂。
但我認(rèn)為這樣完成的一個(gè)服務(wù)是更具有可插拔性,更容易維護(hù)的。而且遵循了上面的cloud方案的話(huà),在服務(wù)的健壯性上面也很強(qiáng)。
寫(xiě)到這里對(duì)于新接觸的我認(rèn)為可以先從單獨(dú)的spring boot程序開(kāi)始入門(mén),當(dāng)要添加一個(gè)新功能時(shí),考慮拆分成另外服務(wù)。兩個(gè)程序間可以通過(guò) jmx或是 其它消息中間件或是rest通訊。最后實(shí)現(xiàn)了一個(gè)各自獨(dú)立的功能集群。
總結(jié)一句:Spring boot可以離開(kāi)Spring Cloud獨(dú)立使用開(kāi)發(fā)項(xiàng)目,但是Spring Cloud離不開(kāi)Spring boot,屬于依賴(lài)的關(guān)系。