Spring Boot
简化Spring应用开辟的一个框架;
整个Spring技术栈的一个大整合;
J2EE开辟的一站式办理方案;
优点:快速创建独立运行的spring项目以及与主流框架集成
使用嵌入式的Servlet容器,应用无需打成war包,内嵌Tomcat
Starters主动依赖和版本控制
大量的主动装配,简化开辟,也可以修改默认值(靠注解)
无需设置XML无代码生成开箱即用
准生产情况的运行时应用监控
与云计算的天然集成
Spring Cloud微服务管理方案
2014,martin fowler
Servlet,ssh,ssm,单体,SOA,springCloud
微服务:架构风格(服务微化)
微服务是指开辟单个小型的但有业务功能的服务,每个服务都有自己处理和轻量通讯机制,可以部署在单个或多个服务器上。微服务也指一种种松耦合的有肯定的有界上下文的面向服务架构。
一个应用应该是一组小型服务;可以通过HTTP的方式举行互通;
单体应用:ALL IN ONE
微服务:每一个功能元素终极都是一个可独立替换和独立升级的软件单位;
微服务文档https://martinfowler.com/articles/microservices.html#MicroservicesAndSoa
微服务优点:
每一个微服务都很小,这样能聚焦一个指定的业务功能或业务需求。
微服务能够被小团队单独开辟,这个小团队是2到5人的开辟职员构成。
微服务是松耦合的,是有功能意义的服务,无论是开辟阶段或是部署阶段都是独立的。
微服务能够使用不同的语言开辟。
微服务允许容易且灵活的方式集成主动部署,通过持续集成工具,一个团队的新成员能够更快投入生产。
微服务易于被一个开辟职员理解,修改和维护,这样小团队能够更关注自己的工作结果,
微服务能够即时被要求扩展。
微服务能够部署中低端设置的服务。
易于和第三方集成。
每个微服务都有自己的存储能力,可以有自己的数据库,也可以有同一的数据库。
微服务缺点:
微服务架构大概带来过多的操作
大概双倍的努力
分布式体系大概复杂难以管理
因为分布部署跟踪标题难
当服务量增加,管理复杂性增加
情况约束
–jdk1.8:Spring Boot 推荐jdk1.7及以上;java version "1.8.0_112"
–maven3.x:maven 3.3以上版本;Apache Maven 3.3.9
–IntelliJIDEA2017:IntelliJ IDEA 2017.3.3 x64、STS
–SpringBoot 2.0.2.RELEASE:同一情况; spring5
不要求版本 单一springboot项目 版本冲突
SpringCloud微服务管理的时候
给maven 的settings.xml设置文件的profiles标签添加
<profile>
<id>jdk‐1.8</id>
<activation>
<activeByDefault>true</activeByDefault>
<jdk>1.8</jdk>
</activation>
<properties>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
<maven.compiler.compilerVersion>1.8</maven.compiler.compilerVersion>
</properties>
</profile>
|
(maven项目改变成springboot项目)
浏览器发送hello请求,服务器接受请求并处理,相应Hello World字符串;
- 创建一个maven工程;(jar)
- 导入spring boot相关的依赖
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring‐boot‐starter‐parent</artifactId>
<version>1.5.9.RELEASE</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring‐boot‐starter‐web</artifactId>
</dependency>
</dependencies>
|
/**
* @SpringBootApplication 来标注一个主程序类,说明这是一个Spring Boot应用
*/
@SpringBootApplication
public class HelloWorldMainApplication {
public static void main(String[] args) {
// Spring应用启动起来
SpringApplication.run(HelloWorldMainApplication.class,args);
}
}
| @Controller
public class HelloController {
@ResponseBody
@RequestMapping("/hello")
public String hello(){
return "Hello World!";
}
}
| <
!‐‐ 这个插件,可以将应用打包成一个可实验的jar包;‐‐>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring‐boot‐maven‐plugin</artifactId>
</plugin>
</plugins>
</build>
| 将这个应用打成jar包,直接使用java -jar的下令举行实验;
POM文件
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring‐boot‐starter‐parent</artifactId>
<version>1.5.9.RELEASE</version>
</parent>
他的父项目是
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring‐boot‐dependencies</artifactId>
<version>1.5.9.RELEASE</version>
<relativePath>../../spring‐boot‐dependencies</relativePath>
</parent>
他来真正管理Spring Boot应用里面的所有依赖版本;
Spring Boot的版本仲裁中心;
以后我们导入依赖默认是不需要写版本;(没有在dependencies里面管理的
依赖天然需要声明版本号)
| <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring‐boot‐starter‐web</artifactId>
</dependency>
| spring-boot-starter-web:
spring-boot-starter:spring-boot场景启动器;帮我们导入了web模块正常运行所依赖的组件;
Spring Boot将所有的功能场景都抽取出来,做成一个个的starters(启动器),只需要在项目里面引入这些starter
相关场景的所有依赖都会导入进来。要用什么功能就导入什么场景的启动器
/**
* @SpringBootApplication 来标注一个主程序类,说明这是一个Spring Boot应用
*/
@SpringBootApplication
public class HelloWorldMainApplication {
public static void main(String[] args) {
// Spring应用启动起来
SpringApplication.run(HelloWorldMainApplication.class,args);
}
}
| Spring Boot应用标注在某个类上说明这个类是SpringBoot的主设置类,SpringBoot
就应该运行这个类的main方法来启动SpringBoot应用;
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan(excludeFilters = {
@Filter(type = FilterType.CUSTOM, classes = TypeExcludeFilter.class),
@Filter(type = FilterType.CUSTOM, classes = AutoConfigurationExcludeFilter.class) })
public @interface SpringBootApplication {
|
- @SpringBootConfiguration:Spring Boot的设置类;
- 标注在某个类上,表示这是一个Spring Boot的设置类;
- @Configuration:设置类上来标注这个注解;
- 设置类 ----- 设置文件;设置类也是容器中的一个组件;@Component
- @EnableAutoConfiguration:开启主动设置功能;
- 以前我们需要设置的东西,Spring Boot帮我们主动设置;@EnableAutoConfiguration告诉SpringBoot开启主动设置功能;这样主动设置才能见效;
@AutoConfigurationPackage
@Import(EnableAutoConfigurationImportSelector.class)
public @interface EnableAutoConfiguration {
|
- @AutoConfigurationPackage:主动设置包
- @Import(AutoConfigurationPackages.Registrar.class):
- Spring的底层注解@Import,给容器中导入一个组件;导入的组件由AutoConfigurationPackages.Registrar.class;将主设置类(@SpringBootApplication标注的类)的地点包及下面所有子包里面的所有组件扫描到Spring容器;
- @Import(EnableAutoConfigurationImportSelector.class);
- 给容器中导入组件?EnableAutoConfigurationImportSelector:导入哪些组件的选择器;
- 将所有需要导入的组件以全类名的方式返回中;会给容器中导;这些组件就会被添加到容器入非常多的主动设置类(xxxAutoConfiguration);就是给容器中导入这个场景需要的所有组件,
- 并设置好这些组件;
有了主动设置类,免去了我们手动编写设置注入功能组件等的工作;SpringFactoriesLoader.loadFactoryNames(EnableAutoConfiguration.class,classLoader);
Spring Boot在启动的时候从类路径下的META-INF/spring.factories中获取EnableAutoConfiguration指定的值,将这些值作为主动设置类导入到容器中,主动设置类就见效,帮我们举行主动设置工作;以前我们需要自己设置的东西,主动设置类都帮我们;
J2EE的团体整合办理方案和主动设置都在spring-boot-autoconfigure-1.5.9.RELEASE.jar;
- 使用Spring Initializer快速创建Spring Boot项目
IDEA:使用 Spring Initializer快速创建项目
IDE都支持使用Spring的项目创建向导快速创建一个Spring Boot项目;
选择我们需要的模块;向导会联网创建Spring Boot项目;
默认生成的Spring Boot项目;
主程序已经生成好了,我们只需要我们自己的逻辑
resources文件夹中目录布局
static:保存所有的静态资源; js css images;
templates:保存所有的模板页面;(Spring Boot默认jar包使用嵌入式的Tomcat,默认不支持JSP页面);可以使用模板引擎(freemarker、thymeleaf);
application.properties:Spring Boot应用的设置文件;可以修改一些默认设置;
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |