java微服務開發最適合使用spring?
那今天就不談微服務是使用Dubbo還是Spring Cloud,也不討論是使用RPC還是Restful API,只單獨說一說為什么大多數的Java微服務會使用Spring Boot。文中會有不少我個人的主觀看法,如果大家有不贊同的地方,可以留言討論。
首先,需要了解一下為什么需要做微服務。
微服務架構是將整個應用程序分割成更小的獨立的服務,每個服務實現了一組獨立的功能,微服務通過API暴露自己的功能實現,再通過服務治理和服務編排等,完成系統的完整功能。
每個服務都是獨立并且微小的(其實這個【小】是很有爭議的,不在這里展開討論),一個微服務由一個團隊負責管理,包括需求、開發、運維,可以自由選擇技術,不過要求遵守一定的規范;每個微服務都需要快速迭代和部署;總的來說,微服務架構突出了一個【快】字。
那么在回到題目中的問題,微服務的開發是否適合使用Spring Boot。個人認為,答案是肯定的,Spring Boot適合使用在微服務的架構中。
Spring Boot在最初設計的初衷,就是為了簡化Spring應用工程的搭建,其實Spring Boot并沒有引入什么新的東西,本質上它是在Spring和第三方框架的基礎上進行了整合;Spring Boot通過定義的注解替代了xml配置文件,內嵌應用服務器;“約定大于配置”的思想;
總之,Spring Boot讓服務的搭建、開發、部署、認證鑒權、監控都變得更加的簡單。
所以結合上面兩點,微服務注重項目粒度的劃分,一個項目會被分成多個子項目,子項目(微服務)之間獨立部署并通過協議進行數據交互,每個微服務都需要【快速】的迭代和部署;而Spring Boot的最大特點就是讓應用開發過程變得【更快】,因此在微服務架構中,Spring Boot是非常適合的。
當然開發框架只是【快速】開發的一部分,微服務框架也不是單指應用服務的微和快,舉個例子來說,如果你們的技術團隊依然是需求、開發、測試分開的,每一次業務提了需求,需要需求人員進行需求評審,然后給開發人員講解需求,開發人員開發完成之后,部署測試環境,測試人員開始進行測試;測試通過之后,提交上線申請,找一個上線節點,運維人員部署開發環境...
這樣是快不起來的...
我將持續分享Java開發、架構設計、程序員職業發展等方面的見解,希望能得到你的關注。