若是你刚刚开始使用Spring Boot,这是你的一部份内容! 在这里咱们将会回答一些基本的“what?”, “how?” 和 “why?”的问题。 在这里你会找到一个详细的Spring Boot介绍和安装说明。 而后,咱们将构建咱们的第一个Spring Boot应用程序,并讨论一些核心原则。html
Spring Boot能够基于Spring轻松建立能够“运行”的、独立的、生产级的应用程序。 对Spring平台和第三方类库咱们有本身见解和意见(约定大于配置),因此你最开始的时候不要感到奇怪。大多数Spring Boot应用程序须要不多的Spring配置。java
您可使用Spring Boot建立可使用java -jar
或传统 war 包部署启动的Java应用程序。 咱们还提供一个运行“spring scripts”的命令行工具。git
咱们的主要目标是:程序员
默认状况下,Spring Boot 1.5.2.RELEASE须要Java 7和Spring Framework 4.3.7.RELEASE或更高版本。 您能够进行一些其余配置在Java 6上使用Spring Boot。 有关详细信息,请参见第84.11节“如何使用Java 6”。 为Maven(3.2+)、Gradle 2(2.9或更高版本)和3提供了显式构建支持。github
虽然您能够在Java 6或7上使用 Spring Boot,但咱们一般推荐Java 8。web
如下嵌入式servlet容器能够直接使用:spring
名称 | Servlet 版本 | Java 版本 |
---|---|---|
Tomcat 8 | 3.1 | Java 7+ |
Tomcat 7 | 3.0 | Java 6+ |
Jetty 9.3 | 3.1 | Java 8+ |
Jetty 9.2 | 3.1 | Java 7+ |
Jetty 8 | 3.0 | Java 6+ |
Undertow 1.3 | 3.1 | Java 7+ |
您还能够将Spring Boot应用程序部署到任何兼容Servlet 3.0+ 的容器中。shell
Spring Boot能够与“经典(classic)”Java开发工具一块儿使用或做为命令行工具安装。 不管如何,您将须要Java SDK v1.6或更高版本。 在开始以前检查当前的Java安装:apache
|
若是您是Java开发的新手,或者您只想尝试一下 Spring Boot,您可能须要首先尝试使用 Spring Boot CLI,若是想正式使用Spring Boot,请阅读“经典(classic)”安装说明。数组
虽然Spring Boot 与Java 1.6兼容,但咱们建议使用最新版本的Java。
Spring Boot的使用方式与标准Java库的使用相同,只需在类路径中包含适当的spring-boot-*.jar
文件。Spring Boot不须要任何特殊的集成工具,因此可使用任何IDE或文本编辑器进行开发;而且Spring Boot 应用程序没有什么特殊的地方,所以您能够像其余Java程序同样运行和调试。虽然您能够直接复制Spring Boot 的jar包,但咱们一般建议您使用依赖关系管理的构建工具(如Maven或Gradle)。
Spring Boot 兼容 Apache Maven 3.2。 若是您尚未安装Maven,能够按照 https://maven.apache.org/ 上的说明进行安装。
在许多操做系统上,Maven能够经过软件包管理器进行安装。 若是您是OSX Homebrew用户,请尝试使用命令:brew install maven。 Ubuntu用户能够运行命令:sudo apt-get install maven。
Spring Boot 依赖 org.springframework.boot groupId。一般,您的Maven POM文件将从 spring-boot-starter-parent 项目继承,并声明一个或多个“启动器(启动器)”的依赖关系。Spring Boot还提供了一个可选的Maven插件来建立可执行的jar包。
典型的pom.xml文件:
<?xml version="1.0" encoding="UTF-8"?> |
spring-boot-starter-parent是使用Spring Boot的一个很好的方式,但它并非全部的时候都适合。有时您可能须要从不一样的父POM继承,或者您可能不喜欢咱们的默认设置。 请参见第13.2.2节“使用不带父POM的Spring Boot”做为使用导入做用域(import scope)的替代解决方案。
Spring Boot 兼容 Gradle 2(2.9或更高版本)和Gradle 3。若是您还没有安装Gradle,您能够按照 http://www.gradle.org/ 上的说明进行操做。
可使用org.springframework.boot 组(group)声明Spring Boot 的依赖项。 一般,您的项目将声明一个或多个“启动器(Starters)”的依赖。Spring Boot提供了一个有用的Gradle插件,可用于简化依赖关系声明和建立可执行 jar包。
Gradle Wrapper
当您须要构建项目时,Gradle Wrapper提供了一种“获取(obtaining)”Gradle的更好的方式。 它是一个小脚本和库,它与代码一块儿引导构建过程。 有关详细信息,请参阅 https://docs.gradle.org/2.14.1/userguide/gradle_wrapper.html 。
典型的 build.gradle 文件:
plugins { |
Spring Boot CLI是一个命令行工具,若是要使用Spring快速原型(quickly prototype),可使用它。 它容许您运行Groovy脚本,这意味着会有您熟悉的相似Java的语法,没有太多的样板代码(boilerplate code)。
您也没必要要经过CLI来使用Spring Boot,但它绝对是开始Spring应用程序最快方法。
您能够从Spring软件版本库下载Spring CLI发行版:
各发布版本的快照。
下载完成后,请按照解压缩后文件中的INSTALL.txt的说明进行操做。 总而言之:在.zip文件的bin/目录中有一个spring脚本(Windows的spring.bat),或者你可使用java -jar(脚本能够帮助您确保类路径设置正确)。
SDKMAN!(软件开发套件管理器)可用于管理各类二进制SDK的多个版本,包括Groovy和Spring Boot CLI。从http://sdkman.io/ 获取SDKMAN!并安装Spring Boot。
|
若是您正在开发CLI的功能,并但愿轻松访问刚建立的版本,请遵循如下额外说明。
|
这将安装一个称为dev的spring的本地实例(instance)。 它指向您构建位置的target,因此每次重建(rebuild)Spring Boot时,Spring 将是最新的。
你能够看到:
|
若是您在Mac上使用 Homebrew,安装Spring Boot CLI 只须要下面命令:
|
Homebrew会将Spring 安装到 /usr/local/bin。
若是您没有看到公式(formula),您的安装可能会过时。 只需执行brew更新,而后重试。
若是您在Mac上使用 MacPorts,安装Spring Boot CLI 只须要下面命令:
|
Spring Boot CLI为BASH和zsh shell提供命令提示的功能。 您能够在任何shell中引用脚本(也称为spring),或将其放在您的我的或系统范围的bash完成初始化中。 在Debian系统上,系统范围的脚本位于 /shell-completion/bash 中,当新的shell启动时,该目录中的全部脚本将被执行。 手动运行脚本,例如 若是您使用SDKMAN安装了!
|
若是使用Homebrew或MacPorts安装Spring Boot CLI,则命令行补全脚本将自动注册到您的shell。
这是一个很是简单的Web应用程序,可用于测试您的安装是否正确。 建立一个名为app.groovy的文件:
|
而后从shell运行它:
|
由于下载依赖的库,首次运行应用程序须要一些时间,。 后续运行将会更快。
在浏览器中打开 http://localhost:8080 ,您应该会看到如下输出:
Hello World! |
若是您从早期版本的 Spring Boot 升级,请检查项目wiki上托管的“发行说明”。 您将找到升级说明以及每一个版本的“新的和值得注意的”功能的列表。
要升级现有的CLI安装,请使用包管理工具相应的package manager命令(例如brew upgrade),若是您手动安装了CLI,请按照标准说明记住更新PATH环境变量以删除任何旧的引用。
让咱们在Java中开发一个简单的“Hello World!”Web应用程序,突显Spring Boot一些主要的功能。 咱们将使用Maven构建该项目,由于大多数IDE支持它。
https://spring.io/ 包含许多使用Spring Boot的“入门指南”。 若是您正在寻求解决一些具体问题; 能够先看一下那里。
您能够在 https://start.spring.io/ 的依赖关系搜索器中选择Web启动器来快速完成如下步骤。
这会自动生成一个新的项目结构,方便您当即开始编码。 查看文档了解更多详细信息。
在开始以前,打开终端来检查您是否安装了有效的Java和Maven版本。
|
这个示例须要在其本身的文件夹中建立。 后面咱们假设您在当前目录已经建立了一个正确的文件夹。
咱们须要先建立一个Maven pom.xml文件。 pom.xml是用于构建项目的配置文件。打开编辑器并添加如下内容:
<?xml version="1.0" encoding="UTF-8"?> |
这应该给你一个工做构建(working build),你能够经过运行 mvn package 进行测试(你能够暂时忽略警告:“jar will be empty - no content was marked for inclusion!”)。
如今,您能够将项目导入到IDE中(最新的Java IDE内置对Maven的支持)。 为了简单起见,这个示例咱们继续使用纯文本编辑器。
Spring Boot提供了一些“启动器(Starters)”,能够方便地将jar添加到类路径中。咱们的示例应用程序已经在POM的父部分使用了spring-boot-starter-parent。spring-boot-starter-parent是一个特殊启动器,提供一些Maven的默认值。它还提供依赖管理 dependency-management 标签,以便您能够省略子模块依赖关系的版本标签。
其余“启动器(Starters)”只是提供您在开发特定类型的应用程序时可能须要的依赖关系。 因为咱们正在开发Web应用程序,因此咱们将添加一个spring-boot-starter-web依赖关系,但在此以前,咱们来看看咱们目前的依赖。
|
mvn dependency:tree:打印项目依赖关系的树形表示。 您能够看到spring-boot-starter-parent自己不在依赖关系中。 编辑pom.xml并在 parent 下添加spring-boot-starter-web依赖关系:
<dependencies> |
若是您再次运行 mvn dependency:tree ,您将看到如今有许多附加依赖关系,包括Tomcat Web服务器和Spring Boot自己。
要完成咱们的应用程序,咱们须要建立一个的Java文件。 默认状况下,Maven将从src/main/java编译源代码,所以您须要建立该文件夹结构,而后添加一个名为src/main/java/Example.java的文件:
import org.springframework.boot.*; |
虽然这里没有太多的代码,可是有一些重要的部分。
咱们的Example类的第一个注解是@RestController。 这被称为 stereotype annotation。它为人们阅读代码提供了一些提示,对于Spring来讲,这个类具备特定的做用。在这里,咱们的类是一个web @Controller,因此Spring在处理传入的Web请求时会考虑这个类。
@RequestMapping注解提供“路由”信息。 告诉Spring,任何具备路径“/”的HTTP请求都应映射到home方法。 @RestController注解告诉Spring将生成的字符串直接返回给调用者。
@RestController和@RequestMapping注解是Spring MVC 的注解(它们不是Spring Boot特有的)。 有关更多详细信息,请参阅Spring参考文档中的MVC部分。
第二个类级别的注释是@EnableAutoConfiguration。 这个注解告诉 Spring Boot 根据您添加的jar依赖关系来“猜(guess)”你将如何配置Spring。因为spring-boot-starter-web添加了Tomcat和Spring MVC,自动配置将假定您正在开发Web应用程序并相应地配置Spring。
启动器和自动配置
自动配置旨在与“起动器”配合使用,但两个概念并不直接相关。 您能够自由选择启动器以外的jar依赖项,Spring Boot仍然会自动配置您的应用程序。
咱们的应用程序的最后一部分是main()方法。 这只是一个遵循Java惯例的应用程序入口点的标准方法。 咱们的main()方法经过调用run()委托(delegates)给Spring Boot的SpringApplication类。 SpringApplication将引导咱们的应用程序,启动Spring,而后启动自动配置的Tomcat Web服务器。 咱们须要将Example.class做为一个参数传递给run方法来告诉SpringApplication,它是主要的Spring组件。 还传递了args数组以传递命令行参数。
因为咱们使用了spring-boot-starter-parent POM,因此咱们有一个可用的运行目标,咱们可使用它来启动应用程序。 键入mvn spring-boot:从根目录运行以启动应用程序:
|
若是你用浏览器打开 http://localhost:8080 你应该看到如下输出:
Hello World! |
ctrl-c 正常(gracefully)退出应用程序。
让咱们完成咱们的例子,建立一个彻底自包含的可执行jar文件,咱们能够在生产环境中运行。 可执行的jar(有时称为“fat jars”)是包含编译的类以及代码运行所须要的全部jar包依赖的归档(archives)。
可执行jar和Java
Java不提供任何标准的方法来加载嵌套的jar文件(即自己包含在jar中的jar文件)。 若是您正在寻找能够发布自包含的应用程序,这多是有问题的。
为了解决这个问题,许多开发人员使用“uber” jars。 一个uber jar简单地将全部类、jar包进行档案。 这种方法的问题是,很难看到您在应用程序中实际使用哪些库。 若是在多个jar中使用相同的文件名(但具备不一样的内容),也可能会出现问题。
Spring Boot采用一个不一样的方法这样能够直接对jar进行嵌套。
要建立可执行的jar,咱们须要将spring-boot-maven-plugin添加到咱们的pom.xml中。 在 dependencies标签 下方插入如下行:
<build> |
spring-boot-starter-parent POM 包括从新打包目标的 executions标签 配置。 若是您不使用该父POM,您将须要本身声明此配置。 有关详细信息,请参阅插件文档。
保存您的pom.xml并从命令行运行 mvn package:
|
若是你看看target目录,你应该看到myproject-0.0.1-SNAPSHOT.jar。 该文件的大小约为10 MB。 若是你想查看里面,可使用jar tvf:
|
您还应该在target目录中看到一个名为myproject-0.0.1-SNAPSHOT.jar.original的较小文件。 这是Maven在Spring Boot从新打包以前建立的原始jar文件。
使用java -jar命令运行该应用程序:
|
像以前同样,ctrl+c正常退出应用程序。
但愿本节能为您提供一些Spring Boot基础知识,并让您准备编写本身的应用程序。 若是你是一个面向具体任务的开发人员,你可能想跳过 https://spring.io/ ,看看一些解决具体的“如何用Spring”问题的入门指南; 咱们还有Spring Boot-specific How-to参考文档。
Spring Boot库还有一大堆能够运行的示例。 示例与代码的其他部分是独立的(这样您不须要构建多余的代码来运行或使用示例)。
下一个是第三部分“使用 Spring Boot”。 若是你真的没有这个耐心,也能够跳过去阅读Spring Boot功能。