第2章 Spring Boot簡史
Java Web開發(fā)涉及的技術(shù)比較繁雜,涉及到很多開發(fā)框架和工具(Java, Scala, Kotlin, Clojure,Groovy, Grails,Gradle, Maven, JDBC,Mysql, oracle, mongodb, Tomcat,Jetty,Spring,Struts,Hibernate,Mybatis,JPA,JSP,velocity,freemarker,thymeleaf ,Redis,... ),而且它們各有所長,并不是一個完善的體系。這對程序員能進行Jave Web開發(fā),帶來了一定的技術(shù)門檻和學習成本。
有沒有一個像“航空母艦(Aircraft Carrier)”式的威力強大的武器,可以整合這一切呢?答案就是:Spring Boot。
2.1 用SpringBoot創(chuàng)造一切吧
SpringBoot讓創(chuàng)建獨立的,生產(chǎn)環(huán)境的基于Spring的應用更加快捷簡易。 大部分Spring Boot Application只要一些極簡的配置,即可“一鍵運行”。
SpringBoot的特性如下[1]:
- 創(chuàng)建獨立的Spring applications
- 能夠使用內(nèi)嵌的Tomcat, Jetty or Undertow,不需要部署war
- 提供定制化的starter poms來簡化maven配置(gradle相同)
- 追求極致的自動配置Spring
- 提供一些生產(chǎn)環(huán)境的特性,比如特征指標,健康檢查和外部配置。
- 零代碼生成和零XML配置
Spring由于其繁瑣的配置,一度被人認為“配置地獄”,各種XML、Annotation配置,讓人眼花繚亂,而且如果出錯了也很難找出原因。而Spring Boot更多的是采用Java Config的方式,對Spring進行配置。
我們企業(yè)級軟件的目標是提供穩(wěn)定健壯的服務,以實現(xiàn)其商業(yè)價值。為了滿足這些需求,服務開發(fā)者需要能夠快速構(gòu)建和迭代新的應用,同時應用的架構(gòu)是可擴展的,便攜式的,富彈性的,可以進行頻繁的更新。SpringBoot正式為此而誕生[2]。
2.2 SpringBoot起源
SpringBoot是伴隨著Spring4.0誕生的;
從字面理解,Boot是引導的意思,因此SpringBoot幫助開發(fā)者快速搭建Spring框架;SpringBoot幫助開發(fā)者快速啟動一個Web容器;SpringBoot繼承了原有Spring框架的優(yōu)秀基因;SpringBoot使得基于Spring的開發(fā)過程更加簡易。
Change is inevitable, that's the only constant. Become the Future You Imagine (Rob Mee, Pivotal CEO)[3]
Spring Boot是由Pivotal團隊提供的全新框架,其設(shè)計目的是用來簡化新Spring應用的初始搭建以及開發(fā)過程。該框架使用了特定的方式來進行配置,從而使開發(fā)人員不再需要定義樣板化的配置。通過這種方式,Boot致力于在蓬勃發(fā)展的快速應用開發(fā)領(lǐng)域(rapid application development)成為領(lǐng)導者。
多年以來,Spring IO平臺飽受非議的一點就是大量的XML配置以及復雜的依賴管理。在去年的SpringOne 2GX會議上,Pivotal的CTO Adrian Colyer回應了這些批評,并且特別提到該平臺將來的目標之一就是實現(xiàn)免XML配置的開發(fā)體驗。Boot所實現(xiàn)的功能超出了這個任務的描述,開發(fā)人員不僅不再需要編寫XML,而且在一些場景中甚至不需要編寫繁瑣的import語句。
然而,Spring Boot并不是要成為Spring IO平臺里面眾多“Foundation”層項目的替代者。Spring Boot的目標不在于為已解決的問題域提供新的解決方案,而是為平臺帶來另一種開發(fā)體驗,從而簡化對這些已有技術(shù)的使用。對于已經(jīng)熟悉Spring生態(tài)系統(tǒng)的開發(fā)人員來說,Boot是一個很理想的選擇,不過對于采用Spring技術(shù)的新人來說,Boot提供一種更簡潔的方式來使用這些技術(shù)。[4]
2.3 SpringBoot在整個Spring生態(tài)中
2.3.1 Spring生態(tài)頂級項目
作為當前主流的企業(yè)框架Spring,它提供了一整套相關(guān)的頂級項目,能讓開發(fā)者快速的上手實現(xiàn)自己的應用。請看下圖“Spring航空母艦”:
Spring IO platform:用于系統(tǒng)部署,是可集成的,構(gòu)建現(xiàn)代化應用的版本平臺,具體來說當你使用maven dependency引入spring jar包時它就在工作了。
Spring Boot:旨在簡化創(chuàng)建產(chǎn)品級的 Spring 應用和服務,簡化了配置文件,使用嵌入式web服務器,含有諸多開箱即用微服務功能,可以和spring cloud聯(lián)合部署。
Spring Framework:即通常所說的spring 框架,是一個開源的Java/Java EE全功能棧應用程序框架,其它spring項目如spring boot也依賴于此框架。
Spring Cloud:微服務工具包,為開發(fā)者提供了在分布式系統(tǒng)的配置管理、服務發(fā)現(xiàn)、斷路器、智能路由、微代理、控制總線等開發(fā)工具包。
Spring XD:是一種運行時環(huán)境(服務器軟件,非開發(fā)框架),組合spring技術(shù),如spring batch、spring boot、spring data,采集大數(shù)據(jù)并處理。
Spring Data:是一個數(shù)據(jù)訪問及操作的工具包,封裝了很多種數(shù)據(jù)及數(shù)據(jù)庫的訪問相關(guān)技術(shù),包括:jdbc、Redis、MongoDB、Neo4j等。
Spring Batch:批處理框架,或說是批量任務執(zhí)行管理器,功能包括任務調(diào)度、日志記錄/跟蹤等。
Spring Security:是一個能夠為基于Spring的企業(yè)應用系統(tǒng)提供聲明式的安全訪問控制解決方案的安全框架。
Spring Integration:面向企業(yè)應用集成(EAI/ESB)的編程框架,支持的通信方式包括HTTP、FTP、TCP/UDP、JMS、RabbitMQ、Email等。
Spring Social:一組工具包,一組連接社交服務API,如Twitter、Facebook、LinkedIn、GitHub等,有幾十個。
Spring AMQP:消息隊列操作的工具包,主要是封裝了RabbitMQ的操作。
Spring HATEOAS:是一個用于支持實現(xiàn)超文本驅(qū)動的 REST Web 服務的開發(fā)庫。
Spring Mobile:是Spring MVC的擴展,用來簡化手機上的Web應用開發(fā)。
Spring for Android:是Spring框架的一個擴展,其主要目的在乎簡化Android本地應用的開發(fā),提供RestTemplate來訪問Rest服務。
Spring Web Flow:目標是成為管理Web應用頁面流程的最佳方案,將頁面跳轉(zhuǎn)流程單獨管理,并可配置。
Spring LDAP:是一個用于操作LDAP的Java工具包,基于Spring的JdbcTemplate模式,簡化LDAP訪問。
Spring Session:session管理的開發(fā)工具包,讓你可以把session保存到redis等,進行集群化session管理。
Spring Web Services:是基于Spring的Web服務框架,提供SOAP服務開發(fā),允許通過多種方式創(chuàng)建Web服務。
Spring Shell:提供交互式的Shell可讓你使用簡單的基于Spring的編程模型來開發(fā)命令,比如Spring Roo命令。
Spring Roo:是一種Spring開發(fā)的輔助工具,使用命令行操作來生成自動化項目,操作非常類似于Rails。
Spring Scala:為Scala語言編程提供的spring框架的封裝(新的編程語言,Java平臺的Scala于2003年底/2004年初發(fā)布)。
Spring BlazeDS Integration:一個開發(fā)RIA工具包,可以集成Adobe Flex、BlazeDS、Spring以及Java技術(shù)創(chuàng)建RIA。
Spring Loaded:用于實現(xiàn)java程序和web應用的熱部署的開源工具。
Spring REST Shell:可以調(diào)用Rest服務的命令行工具,敲命令行操作Rest服務。
2.3.2 Spring cloud子項目
目前來說spring主要集中于spring boot(用于開發(fā)微服務)和spring cloud相關(guān)框架的開發(fā)。spring cloud子項目包括:
Spring Cloud Config:配置管理開發(fā)工具包,可以讓你把配置放到遠程服務器,目前支持本地存儲、Git以及Subversion。
Spring Cloud Bus:事件、消息總線,用于在集群(例如,配置變化事件)中傳播狀態(tài)變化,可與Spring Cloud Config聯(lián)合實現(xiàn)熱部署。
Spring Cloud Netflix:針對多種Netflix組件提供的開發(fā)工具包,其中包括Eureka、Hystrix、Zuul、Archaius等。
Netflix Eureka:云端負載均衡,一個基于 REST 的服務,用于定位服務,以實現(xiàn)云端的負載均衡和中間層服務器的故障轉(zhuǎn)移。
Netflix Hystrix:容錯管理工具,旨在通過控制服務和第三方庫的節(jié)點,從而對延遲和故障提供更強大的容錯能力。
Netflix Zuul:邊緣服務工具,是提供動態(tài)路由,監(jiān)控,彈性,安全等的邊緣服務。
Netflix Archaius:配置管理API,包含一系列配置管理API,提供動態(tài)類型化屬性、線程安全配置操作、輪詢框架、回調(diào)機制等功能。
Spring Cloud for Cloud Foundry:通過Oauth2協(xié)議綁定服務到CloudFoundry,CloudFoundry是VMware推出的開源PaaS云平臺。
Spring Cloud Sleuth:日志收集工具包,封裝了Dapper,Zipkin和HTrace操作。
Spring Cloud Data Flow:大數(shù)據(jù)操作工具,通過命令行方式操作數(shù)據(jù)流。
Spring Cloud Security:安全工具包,為你的應用程序添加安全控制,主要是指OAuth2。
Spring Cloud Consul:封裝了Consul操作,consul是一個服務發(fā)現(xiàn)與配置工具,與Docker容器可以無縫集成。
Spring Cloud Zookeeper:操作Zookeeper的工具包,用于使用zookeeper方式的服務注冊和發(fā)現(xiàn)。
Spring Cloud Stream:數(shù)據(jù)流操作開發(fā)包,封裝了與Redis,Rabbit、Kafka等發(fā)送接收消息。
Spring Cloud CLI:基于 Spring Boot CLI,可以讓你以命令行方式快速建立云組件。
2.4 SpringBoot核心組件
2.5 SpringBoot版本歷史
SpringBoot項目源碼:https://github.com/spring-projects/spring-boot
SpringBoot學習示例:https://github.com/netgloo/spring-boot-samples
版本歷史參考:https://github.com/spring-projects/spring-boot/releases
2.6 SpringBoot學習成本
正因為Spring Boot是與Spring一脈相承的,所以對于廣大的Java開發(fā)者而言,對于Spring的學習成本幾乎為零。
在實踐Spring Boot時學習重點,或者說思維方式改變的重點在于:
1)對于REST的理解,這一點尤為重要,需要從設(shè)計、開發(fā)多個角色達成共識,很多時候都是對于HTTP 1.1協(xié)議以及REST的精髓不理解,導致REST被「盲用」而產(chǎn)生一些不好的效果。
2)對于YAML的理解和對于JavaConfig的理解,這兩點相對較為簡單,本質(zhì)上是簡化了xml文件,并提供等價的配置表述能力。
小結(jié)
SpringBoot繼承了原有Spring框架的優(yōu)秀基因;SpringBoot簡化了使用Spring的過程。
參考資料
1.http://projects.spring.io/spring-boot/
2.https://pivotal.io/spring-app-framework#buildanything
3.https://pivotal.io/
4.http://www.infoq.com/cn/articles/microframeworks1-spring-boot
5.http://blog.csdn.net/zeb_perfect/article/details/51945350
6.http://projects.spring.io/
7.SpringBoot官網(wǎng)文檔:
http://docs.spring.io/spring-boot/docs/current-SNAPSHOT/reference/htmlsingle/