Spring Boot 简介

 

1. 什么是 SpringBoot

1.1 使用spring boot可以非常方便、快速搭建项目,不用考虑框架的兼容性或版本问题,集中式的配置,仅仅添加一个配置就可以了,所以使用sping boot非常适合构建微服务。

1.2 Spring Boot可以以jar包的形式进行独立的运行,使用:java -jar xx.jar 就可以成功的运行项目,或者在应用项目的主程序中运行main函数即可。

 

2. SpringCloud

2.1 Spring Cloud是一个基于Spring Boot实现的云应用开发工具,微服务架构里面这些服务都是独立部署的,这些服务都有自己的数据,这是微服务架构

 

3. SpringBoot 优点

3.1 去除了大量的xml配置文件

3.2 简化复杂的依赖管理

3.3 配合各种starter使用,基本上可以做到自动化配置

3.4 快速启动容器,创建独立Spring应用程序,嵌入式Tomcat,Jetty容器,无需部署WAR包,简化Maven及Gradle配置(spring boot项目的入口是一个main方法,运行该方法即可)(如需打包,可直接打成 jar 包,java -jar ***.jar 即可运行)

 

总结

使编码变得简单:
  spring boot采用java config的方式,对spring进行配置,并且提供了大量的注解,极大地提高了工作效率。
使配置变得简单:
  spring boot提供许多默认配置,当然也提供自定义配置。但是所有spring boot的项目都只有一个配置文件:application.properties/application.yml。用了spring boot,再也不用担心配置出错找不到问题所在了。
使部署变得简单:
  spring boot内置了三种servlet容器:tomcat,jetty,undertow。
使监控变得简单:

spring boot部署架构图 spring boot架构搭建_runtime

 

常用注解的使用

@WebServlet(name="servlet", urlPatterns="/helloServlet") 声明该类是Servlet类(类需继承HttpServlet)
@WebFilter(filterName="helloFilter", urlPatterns="/helloServlet") 声明filter过滤器(类需实现servlet的Filter),urlPatterns执行需要拦截的方法名
@WebListener
以上三个注解都可通过@ServletComponentScan扫描到,也可以用下面手动注册Bean的方式实现:



// 注册Servlet程序
@Bean
public ServletRegistrationBean getServlet(){
    ServletRegistrationBean bean = new ServletRegistrationBean(new HelloServlet());
    // 设置访问路径
    bean.addUrlMappings("/*");
    return bean;
}
// 注册Filter程序
@Bean
public FilterRegistrationBean getFilter(){
    FilterRegistrationBean bean = new FilterRegistrationBean(new HelloFilter());
    bean.addUrlPatterns("/*");
    return bean;
}
// 注册Listener程序
@Bean
public ServletListenerRegistrationBean<HelloListener> getListener(){
    ServletListenerRegistrationBean<HelloListener> bean = new ServletListenerRegistrationBean<HelloListener>(new HelloListener());
    return bean;
}


@SpringBootApplication(exclude={DataSourceAutoConfiguration.class,HibernateJpaAutoConfiguration.class}) //移除自动注入数据源
@Bean(name="sysMenu",initMethod="start",destroyMethod="cleanUp") 可指定初始化及销毁方法
@Scope("prototype"):默认是singleton,可设置为原型作用域
@ComponentScan(basePackages = "com.dxz.model.configuration") 可指定扫描路径
@MapperScan("com.individual.mapper")必须指定mapper包路径

@SpringBootApplication:程序启动的注解 @Configuration + @EnableAutoConfiguration + @ComponentScan
@Configuration:标注在类上,相当于把该类作为spring的xml配置文件中的<beans>,作用为:配置spring容器(应用上下文)
@EnableAutoConfiguration:能够自动配置spring的上下文,试图猜测和配置你想要的bean类,通常会自动根据你的类路径和你的bean定义自动配置
@ComponentScan:会自动扫描指定包下的全部标有@Component的类,并注册成bean,当然包括@Component下的子注解@Service,@Repository,@Controller
@RestController:这是一个组合注解,相当于@ResponseBody + @Controller
@Component:添加注册bean的注解

@interface:可自定义注解,是jdk1.5之后加入的,java没有给它新的关键字,所以就用@interface这么个东西表示了
@Retention(RetentionPolicy.RUNTIME) // 注解将会由虚拟机保留,以便它可以在运行时通过反射读取
@Documented:注解表明这个注解应该被 javadoc工具记录. 默认情况下,javadoc是不包括注解的. 但如果声明注解时指定了 @Documented,则它会被 javadoc 之类的工具处理, 所以注解类型信息也会被包括在生成的文档中



@Target 注解的作用目标
@Target:(ElementType.TYPE)    接口、类、枚举、注解
@Target:(ElementType.FIELD)    字段、枚举的常量
@Target:(ElementType.METHOD)    方法
@Target:(ElementType.PARAMETER)    方法参数
@Target:(ElementType.CONSTRUCTOR)    构造函数
@Target:(ElementType.LOCAL_VARIABLE)    局部变量
@Target:(ElementType.ANNOTATION_TYPE)    注解
@Target:(ElementType.PACKAGE)    包



 

Spring Boot 搭建

我们都知道,在一般的项目中是需要引入很多包和很多配置文件的,最坑的是在以前的项目中可不是仅仅引入包就可以的,还要避免版本冲突等问题,总体来说还是比较头疼的。那么在SpringBoot中就不需要再担心包版本或者缺包的问题了,只需一段配置 SpringBoot就会帮我们全部搞定。我们来看一下,只引入了一个核心依赖与web支持 SpringBoot 会帮我们导入哪些包吧!(以下就是本demo引入的所有依赖了)

 

1. pom.xml配置



<!-- SpringBoot 核心依赖 -->
<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.0.2.RELEASE</version>
</parent>

<!-- web 支持 -->
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
        <version>1.5.9.RELEASE</version>
    </dependency>
</dependencies>


 

spring boot部署架构图 spring boot架构搭建_runtime_02

 

2. 程序启动入口(直接运行main方法即可)

@SpringBootApplication
public class Application {
    
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

为了方便测试,我们在这里添加一个Controller、Entity

import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

import com.firstboot.lpx.entity.Person;

@RestController
public class MyController {
    
    @RequestMapping(value="/getPerson/{age}", method=RequestMethod.GET, produces=MediaType.APPLICATION_JSON_VALUE)
    public Person getPerson(@PathVariable int age){
        Person p = new Person();
        p.setName("小李");
        p.setAge(age);
        return p;
    }

}

public class Person {
    
    private String name;
    private int age;
    
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }

}


 

3. 启动SpringBoot程序 并 访问getPerson接口

spring boot部署架构图 spring boot架构搭建_java_03

spring boot部署架构图 spring boot架构搭建_runtime_04

 

 

OK,以上就是 SpringBoot 的小 demo。