其实也是参考官方的:http://spring.io/guides/gs/rest-service/ ,在官方代码基础上加入了很多实用的东西,比如运行环境启动命令等等。
官方文档:http://docs.spring.io/spring-boot/docs/current/reference/html/
SpringBoot并不神秘,其最大的好处是可以帮你省略引用一堆jar包,需要神秘jar它自动帮你引用,集成tomcat,集成配置等待好处太多,总之就是更方便开发而已。
还是自己体验下比较好。
1.建立java应用程序
起一个Maven的java应用程序,注意不要再起Web应用程序了:
2.maven配置文件
pom.xml:
4.0.0
com.xxx
spring-boot-hello
1.0.0
jar
org.springframework.boot
spring-boot-starter-parent
1.4.3.RELEASE
UTF-8
1.8
1.8
org.springframework.boot
spring-boot-starter-web
org.springframework.boot
spring-boot-starter-test
test
com.jayway.jsonpath
json-path
test
org.springframework.boot
spring-boot-maven-plugin
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
public class Greeting {
private final long id;
private final String content;
public Greeting(long id, String content) {
this.id = id;
this.content = content;
}
public long getId() {
return id;
}
public String getContent() {
return content;
}
}
import java.util.concurrent.atomic.AtomicLong;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class GreetingController {
private static final String template = "Hello, %s!";
private final AtomicLong counter = new AtomicLong();
@RequestMapping("/greeting")
public Greeting greeting(@RequestParam(value="name", defaultValue="World") String name) {
return new Greeting(counter.incrementAndGet(),
String.format(template, name));
}
}
注意:SpringBoot已经集成了tomcat所以无需再安装了,默认是8080不要和现有的tomcat冲突
成功启动会提示:FrameworkServlet 'dispatcherServlet': initialization completed in 10 ms
5.验证
http://localhost:8080/greeting
6.集成依赖文件
我们去看下系统依赖文件,发现springmvc都自动被引入,如果不适用springboot就需要一个个去单独引用。
7.命令行下启动
实际项目中肯定是到命令行下启动
Windows下
# java -jar spring-boot-hello-1.0.0.jar
Linux下
实际是需要再后台运行的加个&符号,比如这样
# nohup java -jar spring-boot-hello-1.0.0.jar >/dev/null 2>&1 &
定制化JVM启动参数
# nohup java -Xms1024m -Xmx1024m -Xss1024K -XX:PermSize=64m -XX:MaxPermSize=128m -jar spring-boot-hello-1.0.0.jar >/dev/null 2>&1 &
8.Tomcat下运行
其实完全没必要再到tomcat下再去运行了,如果真的还需要这样可以打war包即可。
spring-boot-hello
1.0.0
jar
spring-boot-hello
1.0.0
war
需要注意的是jdk需要1.8以上版本,Tomcat需要8.0以上版本
9.Spring Boot配置
如果你需要修改配置,可以在resources文件夹下创建一个application.properties或者application.yml文件,这个文件会被发布到classpath。
比如修改默认的tomcat端口为80
application.properties
server.port: 80
server.tomcat.uri-encoding: UTF-8
server:
port: 80
tomcat:
uri-encoding: UTF-8
更多配置参考:http://docs.spring.io/spring-boot/docs/current/reference/html/common-application-properties.html
另外:推荐一本书《深入实践Spring Boot》
10.spring boot多环境配置
一般会有开发环境,测试环境,正式环境,甚至于预发布环境。
配置文件不管理好,如果这个靠手工去做非常不靠谱,很容易出错。
Spring boot可以配置多个配置文件,自动切换。
application-online.properties
server.port: 80
server.tomcat.uri-encoding: UTF-8
server.port: 8080
server.tomcat.uri-encoding: UTF-8
spring.profiles.active=test
也可以通过命令行方式启动
将程序打包之后 通过 java -jar xx.jar --spring.profiles.active=dev的方式启动参考: SpringBoot学习笔记(2) Spring Boot的一些配置