开场知识:

spring 容器注入bean,时容器初始化的一些接口以及接口调用的时间先后顺序:

1)BeanFactoryPostProcessor

容器初始化的回调方法

* BeanFactoryPostProcessor在spring容器初始化之后触发,而且只会触发一次

* 触发的时机比BeanPostProcessor早

@Component

public class MyBeanFactoryPostProcessor implements BeanFactoryPostProcessor {

public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory)

throws BeansException {

System.out.println("=========BeanFactoryPostProcessor========"+ beanFactory.getBeanPostProcessorCount());

}

}

2)BeanDefinitionRegistryPostProcessor//动态的注入bean

例子:

这里的例子是一次性注入10个person的bean,并为这10个person的bean的name属性赋值了

BeanDefinitionRegistryPostProcessor

可以拿到ConfigurableListableBeanFactory和BeanDefinitionRegistry两个对象

@Component

public class MyBeanDefinitionRegistryPostProcessor implements

BeanDefinitionRegistryPostProcessor {

public void postProcessBeanFactory(

ConfigurableListableBeanFactory beanFactory) throws BeansException {

}

public void postProcessBeanDefinitionRegistry(

BeanDefinitionRegistry registry) throws BeansException {

for(int i=1;i<=10;i++){

BeanDefinitionBuilder bdb=BeanDefinitionBuilder.rootBeanDefinition(Person.class);//这个是构造beanDefinition的

bdb.addPropertyValue("name", "admin"+i);

registry.registerBeanDefinition("person"+i, bdb.getBeanDefinition());

}

}

}

3)BeanPostProcessor

里面有两个方法:

postProcessBeforeInitialization(Object bean, String name)//在bean注入spring容器之前可以写一些逻辑

postProcessAfterInitialization(Object bean, String name)//在bean注入spring容器之后可以写一些逻辑

  1. spring boot aop开发流程:
  2. spring-boot-starter-aop 加入依赖,默认就开启了AOP的支持
  3. 写一个Aspect 封装横切关注点(日志、监控等等),需要配置通知(前置通知,后置通知等等)和切入点(包的哪些类,哪些方法)
  4. 这个Aspect需要纳入spring容器中管理,并需要加入@Aspect注解
  5. spring.aop.auto配置项决定是否启用AOP,默认启用
  6. spring.aop.proxy-target-class=true 是启用cglib的动态代理,如果是false 则是启用jdk的动态代理,  jdk的动态代理是需要接口的,如果配置了false ,而类中没有接口,则依然使用cglib
  7. 注解:@EnableAspectJAutoProxy 意思就是启用aop,并且默认是启用jdk的动态代理  就相当于在application.properties文件中配置了spring.aop.auto=true

spring.aop.proxy-target-class=false

  • 14.
  • @EnableConfigurationProperties注解的应用:

/**

  1. 因为我们在装配RedisAutoConfiguration这个类的时候,是会用到RedisProperties这个类的host,port的属性值
  2. @ConditionalOnClass(Jedis.class) 这个注解的意思是,只有下面的Jedis(redis的java实现类)存在时才进行bean的装配
  3. @ConditionalOnMissingBean  这个注解是当被@bean标注的bean在spring容器中不存在时,才注入到spring容器

**/

下面这个类是把application.properties文件中的属性注入到了RedisProperties这个类中

@ConfigurationProperties(prefix=”redis”)

public class  RedisProperties{

private String host;

private Integer port;

//对应的get/set方法

}

15.从其他project中注入的bean如何引入到本project?

两种方法:

1):自己编写注解@EnableXXX  在这个注解中引入@Import(需要注入bean的.class)

然后在本project中,用到需要注入的地方的类上面加入@EnableXXX(1.中编写的注解)

这样就可以把不在同一个project的bean注入到其他prj里了

2):在resources文件夹下新建META-INF/spring.factories

在spring.factories文件中写入:

org.springframework.boot.autoconfigure.EnableAutoConfiguration=自己要注入的类的全称

16.开发一个starter的步骤:

1):新建一个maven项目

2):需要一个配置类,配置类里面需要装配好,需要提供出去的类

3):

(1)使用@EnableXXX  配合@Import导入需要装配的类

(2)或者META-INF/spring.factories  在org.springframework.boot.autoconfigure.EnableAutoConfiguration配置需要装入的

17.spring boot的日志

Spring boot默认的日志级别是INFO,可以通过logging.level.*=debug  *可以是包,也可以是类,最上面的是root

日志级别有TRace Debug,warn error,fatal,off(表示关闭日志输出)

日志的文件输出:logging.file=e:/temp/my.log

也可以指定路径:logging.path=e:/temp/logs  指定日志输出目录,此时的日志名字默认是spring.log

日志文件输出,文件大小10M之后就分割了

logging.pattern.console=

logging.file.console=

指定控制台和文件输出的格式

Logback  学习下logback.xml配置  log4j2.xml

Spring boot 默认支持logback 也就是说需要在classpath下放置logback.xml或者logback-spring.xml即可定制日志的输出

使用其他的日志组件步骤:

  1. 排除掉默认的日志组件spring-boot-logging
  2. 加入新的日志组件依赖
  3. 把相应的配置文件放在classpath下

18.spring boot的监控和度量

Pom.xml文件中需要引入依赖:spring-boot-actuator

actuator是spring boot提供的对应用系统的自省和监控的集成功能

学习actuator资料:https://segmentfault.com/a/1190000004318360?_ea=568366

监控就是可以在浏览器中查看一些beans等等,比如:http://localhost:8080/beans

浏览器最好安装JSONView插件(火狐)

http://localhost:8080/env 查看spring boot中的一些配置

http://localhost:8080/mappings 查看spring boot以及系统中的一些映射(包括一些controller)

http://localhost:8080/autoconfig 通过autoconfig配置到spring boot中的一些类,查看自动配置的使用情况

自定义实现健康状态监测,实现HealthIndiacator接口,并纳入到spring容器的管理之中

CounterService  用来计数的服务,可以直接使用

统计/user/home被访问的次数

在浏览器中输入:http://localhost:8080/metrics  查看user.home.request.count的属性值就可以知道这个url被访问的次数

19.spring boot的测试

需要在测试类上加上注解:@RunWith(SpringRunner.class) @SpringBootTest

Spring boot 测试步骤:

直接在测试类上加如下两个注解:

@RunWith(SpringRunner.class) @SpringBootTest

19.1 测试Dao的方法的步骤

19.2测试spring容器中是否有某个bean:

只在测试环境下注入某些bean的方法:(在测试环境下注入Runnable) 注意是@TestConfiguration,不能用@Configuration ,并且这个类只会在测试环境下有效,

19.3测试application.properties文件中的值的方法:

Spring boot中使用 Environment来获取文件中的属性值

在测试环境中,spring boot优先获取test resources下的配置文件application.properties,如果test resources下没有配置文件,那么它就会去 main resources文件夹下找配置文件

两种给配置加配置项的方法:

  1. 在@SpringBootTest注解中添加属性properties
  2. 利用@Before  和ConfigurableEnvironment.addEnvironment()

20.spring boot + mybatis环境搭建

<parent>

Spring-boot-starter-parent

</parent>

<properties>

<maven.compiler.source>1.8</maven.compiler.source>

<maven.compiler.target>1.8</maven.compiler.target>

</properties>

<dependeccies>

<dependency>

Spring-boot-starter-web

</dependency>

<dependency>

Spring-boot-starter-jdbc

</dependency>

<dependency>

mybatis

</dependency>

<dependency>

Mybatis-spring-boot-starter

</dependency>

<dependency>

Mysql-connector-java

</dependency>

</dependencies>

编写接口Mapper的时候需要在其上加入注解@Mapper

例如:

@Mapper

Public interface ProductMapper{

}

Mybatis 基于注解的方式:

其实这个Mapper上没有类似@Component注入到spring容器中,但它确实已经存在spring容器中了,所以可以通过ConfigurableApplicationContext.getBean(XXXMapper.class)获取,获取完之后就可以直接用这个获取的类调用接口中的增删改查,往数据进行数据读写等操作了,所以spring boot 与mybatis集成很方便

21.spring boot 的打包:

使用插件:这个插件介绍的地址是:

http://www.mojohaus.org/appassembler/appassembler-maven-plugin/

我们使用的是第一个:appassembler-assemble是指打包一个可执行的命令

需要在pom.xml文件中加入配置

<build>

<plugins>

<plugin>

<groupId>org.codehaus.mojo</groupId>

<artifactId>appassembler-maven-plugin</artifactId>

<version>1.10<version>

<configuration>

</configuration>

.......

<plugin>

</plugins>

</build>

注意上面的<mainClass></mainClass>是配置启动类,需要配置App.class那个的包名:

例如:<mainClass>com.zhangshitong.springboot.App</mainClass>

那么如何进行打包呢:

如果是windows平台,那么cmd命令切换到工程名的文件夹下,然后执行:

mvn clean package appassembler:assembler

接着就能看见平台进行打包,一段时间过后,在工程名的target文件夹下会生成打包生成的一些文件,那么我们的可执行文件就在bin文件夹下会生成.bat文件,然后在该目录下执行就是部署了项目

Linux平台下的运行,用windows平台打好包之后传到linux平台,首先给目标文件赋予权限chmod +x

然后执行bin文件夹下的linux平台下的执行文件./xxxx

spring boot学习笔记2的更多相关文章

  1. Spring Boot学习笔记2——基本使用之最佳实践[z]

    前言 在上一篇文章Spring Boot 学习笔记1——初体验之3分钟启动你的Web应用已经对Spring Boot的基本体系与基本使用进行了学习,本文主要目的是更加进一步的来说明对于Spring B ...

  2. Spring Boot 学习笔记(六) 整合 RESTful 参数传递

    Spring Boot 学习笔记 源码地址 Spring Boot 学习笔记(一) hello world Spring Boot 学习笔记(二) 整合 log4j2 Spring Boot 学习笔记 ...

  3. Spring Boot 学习笔记1——初体验之3分钟启动你的Web应用[z]

    前言 早在去年就简单的使用了一下Spring Boot,当时就被其便捷的功能所震惊.但是那是也没有深入的研究,随着其在业界被应用的越来越广泛,因此决定好好地深入学习一下,将自己的学习心得在此记录,本文 ...

  4. Spring Boot 学习笔记1---初体验之3分钟启动你的Web应用

    前言 早在去年就简单的使用了一下Spring Boot,当时就被其便捷的功能所震惊.但是那是也没有深入的研究,随着其在业界被应用的越来越广泛,因此决定好好地深入学习一下,将自己的学习心得在此记录,本文 ...

  5. Spring Boot 学习笔记--整合Thymeleaf

    1.新建Spring Boot项目 添加spring-boot-starter-thymeleaf依赖 <dependency> <groupId>org.springfram ...

  6. 我的第一个spring boot程序(spring boot 学习笔记之二)

    第一个spring boot程序 写在前面:鉴于spring注解以及springMVC的配置有大量细节和知识点,在学习理解之后,我们将直接进入spring boot的学习,在后续学习中用到注解及其他相 ...

  7. Java框架spring Boot学习笔记(六):Spring Boot事务管理

    SpringBoot和Java框架spring 学习笔记(十九):事务管理(注解管理)所讲的类似,使用@Transactional注解便可以轻松实现事务管理.

  8. Spring Boot学习笔记---Spring Boot 基础及使用idea搭建项目

    最近一段时间一直在学习Spring Boot,刚进的一家公司也正好有用到这个技术.虽然一直在学习,但是还没有好好的总结,今天周末先简单总结一下基础知识,等有时间再慢慢学习总结吧. Spring Boo ...

  9. Spring Boot学习笔记二

    Spring Boot入门第二篇 第一天的详见:https://www.cnblogs.com/LBJLAKERS/p/12001253.html 同样是新建一个pring Initializer快速 ...

随机推荐

  1. kvm介绍 转载

    KVM 介绍(1):简介及安装 学习 KVM 的系列文章: (1)介绍和安装 (2)CPU 和 内存虚拟化 (3)I/O QEMU 全虚拟化和准虚拟化(Para-virtulizaiton) (4)I ...

  2. POJ3678 Katu Puzzle

    原题链接 \(2-SAT\)模板题. 将\(AND,OR,XOR\)转换成\(2-SAT\)的命题形式连边,用\(tarjan\)求强连通分量并检验即可. #include<cstdio> ...

  3. Ubuntu12.04(64bit)下安装Qt4总结

    本文主要介绍linux系统Ubuntu12.04(64bit)下Qt4.8.5的安装,其中还涉及Fedora9下Qt4的安装. 1.下载软件:去Qt的官网下载Qt4.8.5和Qt Creator软件, ...

  4. robot framework测试驱动无法定位页面元素

    robot framework错误提示: [ WARN ] Keyword 'Capture Page Screenshot' could not be run on failure: NoSuchW ...

  5. Centos 装系统 配置网卡,校准时间

    Vclient -控制台: 1.编辑网卡,第一块为外网,第二块为内网 #vi /etc/sysconfig/network-scripts/ifcfg-ens160 TYPE=Ethernet NAM ...

  6. [ES]elasticsearch章2 ES查询过程解析

    es服务端是准确知道每个document分布在哪个shard上: search一个比较复杂的执行模式,因为我们不知道那些document会被匹配到,任何一个shard上都有可能,所以一个search请 ...

  7. vue中常用的指令

    1. v-textv-text主要用来更新textContent,可以等同于JS的text属性. <span v-text="msg"></span> 2. ...

  8. jsvascript null,undefined,undeclared的区别

    1.undefined表示"缺少值",就是此处应该有一个值,但是还没有定义,转为数值时为NaN.典型用法是: (1)变量被声明了,但没有赋值时,就等于undefined. (2) ...

  9. 【Web】前端文件上传,带进度条

    最近做项目发现,在文件上传的过程中,增加进度条,能大大改善用户体验.本例介绍带进度条的文件上传 环境搭建 参考:[Java]JavaWeb文件上传和下载. 原生ajax上传带进度条 <%@ pa ...

  10. [C#]WinForm动态删除控件 Controls.Remove()

    今天遇到一个奇怪的问题,在WinForm内动态添加Button后再动态的移除,发生稀奇古怪的现象,Button控件只被规律的移除,没有完全移除 foreach (Control c in this.C ...