Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者。
简单的说将java的各大流行框架通过页面配置整合起来,省去了项目初建花费大量时间去组装调试的过程,从而简化了项目框架搭建流程。内置了tomcat,jetty等容器,无需再通过tomcat部署war包的方式部署项目。目前在微服务架构中应用很广泛。
下面就简单介绍下使用流程:
1.配置下载项目
访问网站http://start.spring.io/,根据自己的情况选择maven或gradle和spring boot版本
点击“Switch to the full version”配置自己项目说明
在创建项目的下方可以根据自己的需求选择合适框架依赖。
选择好后点击“Generate Project”下载项目工程。
也可以通过安装ide插件支持,如eclipse安装spring tools tips,新建spring starter project项目
2.项目结构
和maven项目一样这里就不多少了,有一个*Application类的主程序,运行即可启动程序。
@SpringBootApplication
public class HelloworldApplication{
public static void main(String[] args) {
SpringApplication.run(HelloworldApplication.class, args);
}
}
3.编写demo代码
1.Controller编写
@RestController
@RequestMapping("/user")
public class UserController {
@Autowired
private UserServie userServie;
@RequestMapping(value="/sayHello/{id}",method = RequestMethod.GET)
public String sayHello(@PathVariable Long id){
return userServie.sayHello(id);
}
@RequestMapping(value="",method = RequestMethod.POST)
public Long save(@RequestBody User user){
return userServie.addUser(user);
}
@RequestMapping(value="/list",method = RequestMethod.GET)
public List<User> list(){
return userServie.findList();
}
}
spring boot默认的包扫描是从Application同级包路径自上而下扫描注入。
2.单元测试
使用RestTemplate进行Controller接口测试,
添加测试包依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
@RunWith(SpringRunner.class)
@SpringBootTest(webEnvironment = WebEnvironment.RANDOM_PORT)
public class HelloworldApplicationTests {
@Autowired
private TestRestTemplate restTemplate;
@Test
public void testSayHello() throws Exception {
HttpHeaders requestHeaders = new HttpHeaders();
requestHeaders.setContentType(MediaType.APPLICATION_JSON);
requestHeaders.setAccept(Collections.singletonList(MediaType.APPLICATION_JSON));
User user = new User();
user.setAge(30);
user.setBirthday(new Date());
user.setName("tom");
HttpEntity<User> request = new HttpEntity<User>(user, requestHeaders);
Long id = restTemplate.postForObject("/user", request, Long.class);
Assert.assertEquals(restTemplate.getForEntity("/user/sayHello/{id}", String.class, id).getBody(), "hello tom");;
}
@Test
public void testSayHelloNoFound() throws Exception {
Assert.assertEquals(restTemplate.getForEntity("/user/sayHello/{id}", String.class, -1).getBody(), "not found");;
}
@Test
public void testsave() throws Exception {
HttpHeaders requestHeaders = new HttpHeaders();
requestHeaders.setContentType(MediaType.APPLICATION_JSON);
requestHeaders.setAccept(Collections.singletonList(MediaType.APPLICATION_JSON));
User user = new User();
user.setAge(30);
user.setBirthday(new Date());
user.setName("jetty");
HttpEntity<User> request = new HttpEntity<User>(user, requestHeaders);
Assert.assertNotNull(restTemplate.postForEntity("/user", request, Long.class).getBody());
}
@Test
public void testList() throws Exception {
Assert.assertTrue(restTemplate.getForEntity("/user/list", List.class).getBody().size() > 0);
}
}
TestRestTemplate是对RestTemplate进行了包装.
3.server启动配置
1)配置文件配置,如:application.properties
server.port=8000
server.context-path=/helloworld
可以安装spring tools tips插件,配置参数可以提示
2)实现接口EmbeddedServletContainerCustomizer
@Override
public void customize(ConfigurableEmbeddedServletContainer container) {
container.setPort(8000);
container.setContextPath("/helloworld");
}
3)命令行启动参数配置
java -jar -Dserver.port=8000 helloworld.jar
4.部署方式
1.集成tomcat或jetty通过命令启动
spring boot默认集成了tomcat,如果使用jetty修改pom,排除tomcat依赖,增加jetty依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jetty</artifactId>
</dependency>
在使用maven打成jar使用java命令启动
2.部署到JavaEE容器
1)改启动类,继承 SpringBootServletInitializer 并重写 configure 方法
public class HelloworldApplication extends SpringBootServletInitializer{
private static final Logger logger = LoggerFactory.getLogger(SpringBootSampleApplication.class);
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
return builder.sources(this.getClass());
}
}
修改pom文件中jar 为 war
<packaging>war</packaging>
修改pom,排除tomcat插件,同上。打包部署到容器启动即可。
5.开发调试
springBoot对调试支持很好,使用热启动,修改之后可以实时生效,需要修改以下的配置:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
...
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<fork>true</fork>
</configuration>
</plugin>
</plugins>
该模块在完整的打包环境下运行的时候会被禁用。
6.使用Linux服务的方式启动、停止、重启
1.首先在 pom.xml 中配置插件
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<executable>true</executable>
</configuration>
</plugin>
</plugins>
</build>
2.上传jar包到服务器,假设部署路径为 /var/apps/myapp.jar ,使用命令做一个软连接到 /etc/init.d 目录,命令:
ln -s /var/apps/myapp.jar /etc/init.d/myapp
3.给jar文件授予可执行权限,命令:
chmod +x myapp.jar
4.我们可以使用service myapp start|stop|restart 来对应用进行启停了
执行命令后将得到形如 Started|Stopped [PID] 的结果反馈。
默认PID文件路径:/var/run/appname/appname.pid
默认日志文件路径:/var/log/appname.log
实
5.使用自定义的.conf文件来变更默认配置,方法如下:
在jar包相同路径下创建一个.conf文件,名称应该与.jar的名称相同,如myapp.conf,其内容配置可以如下:
JAVA_HOME=/usr/local/jdk
JAVA_OPTS=-Xmx1024M
LOG_FOLDER=/data/logs/myapp