Spring 歷史
說起 Spring Boot 我們不得不先了解一下 Spring 這個(gè)企業(yè),不僅因?yàn)?Spring Boot 來源于 Spirng 大家族,而且 Spring Boot 的誕生和 Sping 框架的發(fā)展息息相關(guān)。
時(shí)間回到2002年,當(dāng)時(shí)正是 Java EE 和 EJB 大行其道的時(shí)候,很多知名公司都是采用此技術(shù)方案進(jìn)行項(xiàng)目開發(fā)。這時(shí)候有一個(gè)美國的小伙子認(rèn)為 EJB 太過臃腫,并不是所有的項(xiàng)目都需要使用 EJB 這種大型框架,應(yīng)該會(huì)有一種更好的方案來解決這個(gè)問題。
為了證明他的想法是正確的,于2002年10月甚至寫了一本書《 Expert One-on-One J2EE 》,介紹了當(dāng)時(shí) Java 企業(yè)應(yīng)用程序開發(fā)的情況,并指出了 Java EE 和 EJB 組件框架中存在的一些主要缺陷。在這本書中,他提出了一個(gè)基于普通 Java 類和依賴注入的更簡(jiǎn)單的解決方案。
在書中,他展示了如何在不使用 EJB 的情況下構(gòu)建高質(zhì)量,可擴(kuò)展的在線座位預(yù)留系統(tǒng)。為了構(gòu)建應(yīng)用程序,他編寫了超過 30,000 行的基礎(chǔ)結(jié)構(gòu)代碼,項(xiàng)目中的根包命名為 com.interface21,所以人們最初稱這套開源框架為 interface21,也就是 Spring 的前身。
他是誰呢,他就是大名鼎鼎的 Rod Johnson (下圖), Rod Johnson 在悉尼大學(xué)不僅獲得了計(jì)算機(jī)學(xué)位,同時(shí)還獲得了音樂學(xué)位,更令人吃驚的是在回到軟件開發(fā)領(lǐng)域之前,他還獲得了音樂學(xué)的博士學(xué)位?,F(xiàn)在 Rod Johnson 已經(jīng)離開了 Spring ,成為了一個(gè)天使投資人,同時(shí)也是多個(gè)公司的董事,早已走上人生巔峰。
在這本書發(fā)布后,一對(duì)一的 J2EE 設(shè)計(jì)和開發(fā)一炮而紅。這本書免費(fèi)提供的大部分基礎(chǔ)架構(gòu)代碼都是高度可重用的。 2003 年 Rod Johnson 和同伴在此框架的基礎(chǔ)上開發(fā)了一個(gè)全新的框架命名為 Spring ,據(jù) Rod Johnson 介紹 Spring 是傳統(tǒng) J2EE 新的開始。隨后 Spring 發(fā)展進(jìn)入快車道。
2004 年 03 月,1.0 版發(fā)布。
2006 年 10 月,2.0 版發(fā)布。
2007 年 11 月更名為 SpringSource,同時(shí)發(fā)布了 Spring 2.5。
2009 年 12 月,Spring 3.0 發(fā)布。
2013 年 12 月,Pivotal 宣布發(fā)布 Spring 框架 4.0。
2017 年 09 月,Spring 5.0 發(fā)布。
Spring Boot 的誕生
隨著使用 Spring 進(jìn)行開發(fā)的個(gè)人和企業(yè)越來越多,Spring 也慢慢從一個(gè)單一簡(jiǎn)潔的小框架變成一個(gè)大而全的開源軟件,Spring 的邊界不斷的進(jìn)行擴(kuò)充,到了后來 Spring 幾乎可以做任何事情了,市面上主流的開源軟件、中間件都有 Spring 對(duì)應(yīng)組件支持,人們?cè)谙碛?Spring 的這種便利之后,也遇到了一些問題。
Spring 每集成一個(gè)開源軟件,就需要增加一些基礎(chǔ)配置,慢慢的隨著人們開發(fā)的項(xiàng)目越來越龐大,往往需要集成很多開源軟件,因此后期使用 Spirng 開發(fā)大型項(xiàng)目需要引入很多配置文件,太多的配置非常難以理解,并容易配置出錯(cuò),到了后來人們甚至稱 Spring 為配置地獄。
Spring 似乎也意識(shí)到了這些問題,急需有這么一套軟件可以解決這些問題,這個(gè)時(shí)候微服務(wù)的概念也慢慢興起,快速開發(fā)微小獨(dú)立的應(yīng)用變得更為急迫,Spring 剛好處在這么一個(gè)交叉點(diǎn)上,于 2013 年初開始的 Spring Boot 項(xiàng)目的研發(fā),2014年4月,Spring Boot 1.0.0 發(fā)布。
Spring Boot 誕生之初,就受到開源社區(qū)的持續(xù)關(guān)注,陸續(xù)有一些個(gè)人和企業(yè)嘗試著使用了 Spring Boot,并迅速喜歡上了這款開源軟件。直到2016年,在國內(nèi) Spring Boot 才被正真使用了起來,期間很多研究 Spring Boot 的開發(fā)者在網(wǎng)上寫了大量關(guān)于 Spring Boot 的文章,同時(shí)有一些公司在企業(yè)內(nèi)部進(jìn)行了小規(guī)模的使用,并將使用經(jīng)驗(yàn)分享了出來。從2016年到2018年,使用 Spring Boot 的企業(yè)和個(gè)人開發(fā)者越來越多,我們從 Spring Boot 關(guān)鍵字的百度指數(shù)就可以看出。
上圖為2014年到2018年 Spring Boot 的百度指數(shù),可以看出 Spring Boot 2.0 的推出引發(fā)了搜索高峰。
當(dāng)然 Spring Boot 不是為了取代 Spring ,Spring Boot 基于 Spring 開發(fā),是為了讓人們更容易的使用 Spring??吹?Spring Boot 的市場(chǎng)反應(yīng),Spring 官方也非常重視 Spring Boot 的后續(xù)發(fā)展,已經(jīng)將 Spring Boot 作為公司最頂級(jí)的項(xiàng)目來推廣,放到了官網(wǎng)上第一的位置,因此后續(xù) Spring Boot 的持續(xù)發(fā)展也被看好。
什么是 Spring Boot
Spring Boot 介紹
Spring Boot 是由 Pivotal 團(tuán)隊(duì)提供的全新框架,其設(shè)計(jì)目的是用來簡(jiǎn)化新 Spring 應(yīng)用的初始搭建以及開發(fā)過程。該框架使用了特定的方式來進(jìn)行配置,從而使開發(fā)人員不再需要定義樣板化的配置。用我的話來理解,就是 Spring Boot 其實(shí)不是什么新的框架,它默認(rèn)配置了很多框架的使用方式,就像 maven 整合了所有的 jar 包,Spring Boot 整合了所有的框架(不知道這樣比喻是否合適)。
Spring Boot 簡(jiǎn)化了基于 Spring 的應(yīng)用開發(fā),通過少量的代碼就能創(chuàng)建一個(gè)獨(dú)立的、產(chǎn)品級(jí)別的 Spring 應(yīng)用。 Spring Boot 為 Spring 平臺(tái)及第三方庫提供開箱即用的設(shè)置,這樣你就可以有條不紊地開始。Spring Boot 的核心思想就是約定大于配置,多數(shù) Spring Boot 應(yīng)用只需要很少的 Spring 配置。采用 Spring Boot 可以大大的簡(jiǎn)化你的開發(fā)模式,所有你想集成的常用框架,它都有對(duì)應(yīng)的組件支持。
Spring Boot 特性
使用 Spring 項(xiàng)目引導(dǎo)頁面可以在幾秒構(gòu)建一個(gè)項(xiàng)目
方便對(duì)外輸出各種形式的服務(wù),如 REST API、WebSocket、Web、Streaming、Tasks
非常簡(jiǎn)潔的安全策略集成
支持關(guān)系數(shù)據(jù)庫和非關(guān)系數(shù)據(jù)庫
支持運(yùn)行期內(nèi)嵌容器,如 Tomcat、Jetty
強(qiáng)大的開發(fā)包,支持熱啟動(dòng)
自動(dòng)管理依賴
自帶應(yīng)用監(jiān)控
支持各種 IED,如 IntelliJ IDEA 、NetBeans
Spring Boot 這些特性會(huì)給我們研發(fā)帶來非常大的優(yōu)勢(shì),下面我們可以分開來介紹:
使用 Spring Boot 的優(yōu)勢(shì)
使用 Spring Boot 開發(fā)項(xiàng)目,會(huì)給我們帶來非常美妙的開發(fā)體驗(yàn),可以從以下幾個(gè)方面展開來說明
Spring Boot 讓開發(fā)變得更簡(jiǎn)單
Spring Boot 對(duì)開發(fā)效率的提升是全方位的,我們可以簡(jiǎn)單做一下對(duì)比:
在沒有使用 Spring Boot 之前我們開發(fā)一個(gè) web 項(xiàng)目需要做哪些工作:
1)配置 web.xml,加載 Spring 和 Spring mvc
2)配置數(shù)據(jù)庫連接、配置 Spring 事務(wù)
3)配置加載配置文件的讀取,開啟注解
4)配置日志文件
…
n) 配置完成之后部署 tomcat 調(diào)試
可能你還需要考慮各個(gè)版本的兼容性,jar 包沖突的各種可行性。
那么使用 Spring Boot 之后我們需要開發(fā)一個(gè) web 項(xiàng)目需要哪些操作呢?
1)登錄網(wǎng)址 http://start.spring.io/ 選擇對(duì)應(yīng)的組件直接下載
2)導(dǎo)入項(xiàng)目,直接開發(fā)
上面的 N 步和下面的2步形成巨大的反差,這僅僅只是在開發(fā)環(huán)境搭建的這個(gè)方面。
Spring Boot 使測(cè)試變得更簡(jiǎn)單
Spring Boot 對(duì)測(cè)試的支持不可謂不強(qiáng)大,Spring Boot 內(nèi)置了7種強(qiáng)大的測(cè)試框架:
JUnit: 一個(gè) Java 語言的單元測(cè)試框架
Spring Test & Spring Boot Test:為 Spring Boot 應(yīng)用提供集成測(cè)試和工具支持
AssertJ:支持流式斷言的 Java 測(cè)試框架
Hamcrest:一個(gè)匹配器庫
Mockito:一個(gè) java mock 框架
JSONassert:一個(gè)針對(duì) JSON 的斷言庫
JsonPath:JSON XPath 庫
我們只需要在項(xiàng)目中引入spring-boot-start-test依賴包,就可以對(duì)數(shù)據(jù)庫、Mock、 Web 等各種情況進(jìn)行測(cè)試。
Spring Boot Test 中包含了我們需要使用的各種測(cè)試場(chǎng)景,滿足我們?nèi)粘m?xiàng)目的測(cè)試需求。
Spring Boot 讓配置變得更簡(jiǎn)單
Spring Boot 讓配置變簡(jiǎn)單,說到這里我們就需要了解一下 Spring Boot 的核心思想:約定優(yōu)于配置。那么什么是約定優(yōu)于配置呢?
約定優(yōu)于配置(convention over configuration),也稱作按約定編程,是一種軟件設(shè)計(jì)范式,旨在減少軟件開發(fā)人員需做決定的數(shù)量,獲得簡(jiǎn)單的好處,而又不失靈活性。
本質(zhì)是說,開發(fā)人員僅需規(guī)定應(yīng)用中不符約定的部分。例如,如果模型中有個(gè)名為 User 的類,那么數(shù)據(jù)庫中對(duì)應(yīng)的表就會(huì)默認(rèn)命名為 user。只有在偏離這一約定時(shí),例如將該表命名為”user_info”,才需寫有關(guān)這個(gè)名字的配置。
Spring Boot 讓部署變得更簡(jiǎn)單
說起 Spring Boot 讓部署變簡(jiǎn)單,就不得不說 Spring Boot 內(nèi)嵌容器。內(nèi)嵌容器不只讓部署變得簡(jiǎn)單,其實(shí)在開發(fā)調(diào)試階段也會(huì)帶來非常大的便利性,對(duì)比以往開發(fā) Web 項(xiàng)目時(shí)配置 Tomcat 的繁瑣,會(huì)讓大家使用 Spring Boot 內(nèi)嵌容器開發(fā)時(shí)有更深的感觸。使用 Spring Boot 開發(fā) Web 項(xiàng)目,讓我們不需要關(guān)心容器的環(huán)境問題,專心寫業(yè)務(wù)代碼即可。
Jenkins 是目前持續(xù)構(gòu)建領(lǐng)域使用最廣泛的工具之一,Jenkins 是一個(gè)獨(dú)立的開源自動(dòng)化服務(wù)器,可用于自動(dòng)化各種任務(wù),如構(gòu)建,測(cè)試和部署軟件。Jenkins 可以通過本機(jī)系統(tǒng)包 Docker 安裝,甚至可以通過安裝 Java Runtime Environment 的任何機(jī)器獨(dú)立運(yùn)行。
說直白一點(diǎn) Jenkins 就是專門來負(fù)責(zé)如何將代碼變成可執(zhí)行的程序包,將它部署到目標(biāo)服務(wù)器中,并對(duì)其運(yùn)營(yíng)狀態(tài)(日志)進(jìn)行監(jiān)控的軟件。自動(dòng)化、性能、打包、部署、發(fā)布、發(fā)布結(jié)果自動(dòng)化驗(yàn)證、接口測(cè)試、單元測(cè)試等等關(guān)于我們打包測(cè)試部署的方方面面 Jenkins 都可以很友好的支持。
使用 Jenkins 部署 Spring Boot 項(xiàng)目非常簡(jiǎn)單,大家想繼續(xù)了解可以參考我的文章:使用Jenkins部署Spring Boot,只需要前期做一些簡(jiǎn)單的配置,當(dāng)我們需要發(fā)布項(xiàng)目時(shí)只需要點(diǎn)擊項(xiàng)目對(duì)應(yīng)的發(fā)布按鈕,就可以將項(xiàng)目從版本庫中拉取、打包、發(fā)布到目標(biāo)服務(wù)器中,大大簡(jiǎn)化了運(yùn)維后期的部署工作。
虛擬化技術(shù)的發(fā)展給我們帶來了更多的可能性,我們可以利用容器化技術(shù),將 Spring Boot 項(xiàng)目做成鏡像,根據(jù)容器集群的策略來實(shí)現(xiàn)彈性擴(kuò)容、動(dòng)態(tài)部署等。所以 Spring Boot + Docker + Jenkins 會(huì)將 Spring Boot 項(xiàng)目的部署做得更簡(jiǎn)單化、智能化。
Spring Boot 讓監(jiān)控變得更簡(jiǎn)單
可以說 Spring Boot 就是一款自帶監(jiān)控的開源軟件,在設(shè)計(jì)之初就考慮到應(yīng)用的監(jiān)控問題,專門提供了一款監(jiān)控組件來完成這個(gè)工作,這個(gè)組件就是
Spring Boot Actuator 。
Spring Boot Actuator 是 Spring Boot 提供的對(duì)應(yīng)用系統(tǒng)監(jiān)控的集成功能,可以查看應(yīng)用配置的詳細(xì)信息,例如自動(dòng)化配置信息、創(chuàng)建的 Spring beans 以及一些環(huán)境屬性等。
當(dāng)然 Spring Boot Actuator 雖然可以監(jiān)控一個(gè) Spring Boot 應(yīng)用的健康情況,實(shí)際上現(xiàn)在的系統(tǒng)都是需要很多的服務(wù)相互配合來完成工作,如何通過一個(gè)監(jiān)控軟件來監(jiān)控所以的 Spring Boot 項(xiàng)目將變得比較緊迫。
在開源界也有人意識(shí)到了這個(gè)問題,并且基于 Spring boot actuator 做出了一款強(qiáng)大的監(jiān)控軟件,這個(gè)軟件就是 Spring Boot admin 。
Spring Boot Admin 是一個(gè)管理和監(jiān)控 Spring Boot 應(yīng)用程序的開源軟件。每個(gè)應(yīng)用都認(rèn)為是一個(gè)客戶端,通過 HTTP 或者使用 Eureka 注冊(cè)到 admin server 中進(jìn)行展示,Spring Boot Admin UI 部分使用 AngularJs 將數(shù)據(jù)展示在前端。
Spring Boot Admin 是一個(gè)針對(duì) spring-boot 的 actuator 接口進(jìn)行UI美化封裝的監(jiān)控工具。他可以:在列表中瀏覽所有被監(jiān)控 spring-boot 項(xiàng)目的基本信息,詳細(xì)的 Health 信息、內(nèi)存信息、JVM 信息、垃圾回收信息、各種配置信息(比如數(shù)據(jù)源、緩存列表和命中率)等,還可以直接修改logger的level。
使用 Spring Boot Admin 不僅可以監(jiān)控 Spring Boot 項(xiàng)目,還可以監(jiān)控 Spring Cloud 項(xiàng)目,因此使用了 Spring Boot 項(xiàng)目之后我們監(jiān)控 Spring Boot 集群效果如下:
簡(jiǎn)單、直觀、易用是它的特點(diǎn),針對(duì)一些特殊情況還可以提供報(bào)警服務(wù)。所以說使用 Spring Boot Actuator 解決了單個(gè) Spring Boot 的監(jiān)控問題,使用 Spring Boot Admin 就是解決了整個(gè)集群監(jiān)控的問題。
Spring 、Spring Boot 和 Spring Cloud 的關(guān)系
Spring 最初最核心的兩大核心功能 Spring Ioc 和 Spring Aop 成就了 Spring,Spring 在這兩大核心的功能上不斷的發(fā)展,才有了 Spring 事務(wù)、Spirng Mvc 等一系列偉大的產(chǎn)品,最終成就了 Spring 帝國,到了后期 Spring 幾乎可以解決企業(yè)開發(fā)中的所有問題。
Spring Boot 是在強(qiáng)大的 Spring 帝國生態(tài)基礎(chǔ)上面發(fā)展而來,發(fā)明 Spring Boot 不是為了取代 Spring ,是為了讓人們更容易的使用 Spring 。所以說沒有 Spring 強(qiáng)大的功能和生態(tài),就不會(huì)有后期的 Spring Boot 火熱, Spring Boot 使用約定優(yōu)于配置的理念,重新重構(gòu)了 Spring 的使用,讓 Spring 后續(xù)的發(fā)展更有生命力。
Spring Cloud 是一系列框架的有序集合。它利用 Spring Boot 的開發(fā)便利性巧妙地簡(jiǎn)化了分布式系統(tǒng)基礎(chǔ)設(shè)施的開發(fā),如服務(wù)發(fā)現(xiàn)注冊(cè)、配置中心、消息總線、負(fù)載均衡、斷路器、數(shù)據(jù)監(jiān)控等,都可以用 Spring Boot 的開發(fā)風(fēng)格做到一鍵啟動(dòng)和部署。
Spring 并沒有重復(fù)制造輪子,它只是將目前各家公司開發(fā)的比較成熟、經(jīng)得起實(shí)際考驗(yàn)的服務(wù)框架組合起來,通過 Spring Boot 風(fēng)格進(jìn)行再封裝屏蔽掉了復(fù)雜的配置和實(shí)現(xiàn)原理,最終給開發(fā)者留出了一套簡(jiǎn)單易懂、易部署和易維護(hù)的分布式系統(tǒng)開發(fā)工具包。
根據(jù)上面的說明我們可以看出來,Spring Cloud 是為了解決微服務(wù)架構(gòu)中服務(wù)治理而提供的一系列功能的開發(fā)框架,并且 Spring Cloud 是完全基于 Spring Boot 而開發(fā),Spring Cloud 利用 Spring Boot 特性整合了開源行業(yè)中優(yōu)秀的組件,整體對(duì)外提供了一套在微服務(wù)架構(gòu)中服務(wù)治理的解決方案。
綜上我們可以這樣來理解,正是由于 Spring Ioc 和 Spring Aop 兩個(gè)強(qiáng)大的功能才有了 Spring ,Spring 生態(tài)不斷的發(fā)展才有了 Spring Boot ,使用 Spring Boot 讓 Spring 更易用更有生命力,Spring Cloud 是基于 Spring Boot 開發(fā)的一套微服務(wù)架構(gòu)下的服務(wù)治理方案。
用一組不太合理的包含關(guān)系來表達(dá)它們之間的關(guān)系。
Spring ioc/aop > Spring > Spring Boot > Spring Cloud
給大家推薦一個(gè)專門收集 Spring Boot 學(xué)習(xí)資源的網(wǎng)站:Spring Boot 中文索引
總結(jié)
不知道什么時(shí)候起,行業(yè)里一些開發(fā)人員愿意相信,使用復(fù)雜的軟件就意味著采用了高深的技術(shù);使用了大量的配置,就意味著軟件有著很多比較強(qiáng)大的功能。在產(chǎn)品設(shè)計(jì)的時(shí)候有一個(gè)理念就是讓產(chǎn)品操作足夠的傻瓜化,假設(shè)用戶是一個(gè)智商并不高的群體,卻可以使他很容易的學(xué)會(huì)使用其產(chǎn)品,將此特性做為產(chǎn)品設(shè)計(jì)的一項(xiàng)標(biāo)準(zhǔn)之一。
其實(shí)我們的開源軟件也是一款產(chǎn)品,繁瑣并不意味著功能強(qiáng)大,反而有可能是設(shè)計(jì)不夠合理;簡(jiǎn)潔也并不意味著簡(jiǎn)單,很有可能它只是將眾多復(fù)雜的功能進(jìn)行了封裝,讓我們?cè)谑褂玫臅r(shí)候足夠的簡(jiǎn)單。好的產(chǎn)品如此,好的開源軟件也應(yīng)該如此,Spring Boot 的出現(xiàn)就是讓編程變得更簡(jiǎn)單一些。
在此引用 Python 的經(jīng)典設(shè)計(jì)格言,格言來源于 Python 但不限于 Python。
美麗優(yōu)于丑陋。
清楚優(yōu)于含糊。
簡(jiǎn)單優(yōu)于復(fù)雜。
復(fù)雜優(yōu)于繁瑣。
平坦優(yōu)于曲折。
寬松優(yōu)于密集。
重要的是可讀性。
特殊的案例不足以特殊到破壞規(guī)則。
盡管實(shí)踐可以打破真理。
錯(cuò)誤卻不可置之不理。
除非另有明確要求。
面對(duì)模棱兩可,拒絕猜測(cè)。
總會(huì)有一個(gè) —— 最好是只有一個(gè) —— 顯而易見的方式來明辨。
哪怕這種方式在開始的時(shí)候可能并不明顯。
現(xiàn)在有比沒有好。
盡管沒有經(jīng)常好于現(xiàn)在。
如果如何實(shí)現(xiàn)很難被解釋清楚,那么這個(gè)想法就是一個(gè)壞想法。
如果如何實(shí)現(xiàn)可以被很好的解釋,那么這是一個(gè)好想法。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。