您的位置:首页 > 数据库 > Redis

35. Spring Boot集成Redis实现缓存机制【从零开始学Spring Boot】

2016-08-20 21:52 1206 查看


 

【视频&交流平台】

à SpringBoot视频
http://study.163.com/course/introduction.htm?courseId=1004329008&utm_campaign=commission&utm_source=400000000155061&utm_medium=share
à SpringCloud视频
http://study.163.com/course/introduction.htm?courseId=1004638001&utm_campaign=commission&utm_source=400000000155061&utm_medium=share
à Spring
Boot源码
https://gitee.com/happyangellxq520/spring-boot
à Spring
Boot交流平台
http://412887952-qq-com.iteye.com/blog/2321532
 

 
 

【本文章是否对你有用以及是否有好的建议,请留言】

       本文章牵涉到的技术点比较多:Spring Data JPA、Redis、Spring MVC,Spirng Cache,所以在看这篇文章的时候,需要对以上这些技术点有一定的了解或者也可以先看看这篇文章,针对文章中实际的技术点在进一步了解(注意,您需要自己下载Redis Server到您的本地,所以确保您本地的Redis可用,这里还使用了MySql数据库,当然你也可以内存数据库进行测试)。这篇文章会提供对应的Eclipse代码示例,具体大体的分如下几个步骤:

(1)新建Java MavenProject;
(2)在pom.xml中添加相应的依赖包;
(3)编写Spring Boot启动类;
(4)配置application.properties;
(5)编写RedisCacheConfig配置类;
(6)编写DemoInfo测试实体类;
(7)编写DemoInfoRepository持久化类;
(8)编写DemoInfoService类;
(9)编写DemoInfoController类;
(10)测试代码是否正常运行了
(11)自定义缓存key;
 

       接下来我们看看具体每个步骤具体的操作吧。
(1)新建Java Maven Project;

       这个步骤就不细说,新建一个spring-boot-redis Java mavenproject;

 

(2)在pom.xml中添加相应的依赖包;

在Maven中添加相应的依赖包,主要有:springboot 父节点依赖;spring boot web支持;缓存服务spring-context-support;添加redis支持;JPA操作数据库;mysql 数据库驱动,具体pom.xml文件如下:

<projectxmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0http://maven.apache.org/xsd/maven-4.0.0.xsd">
 <modelVersion>4.0.0</modelVersion>
 
 <groupId>com.kfit</groupId>
 <artifactId>spring-boot-redis</artifactId>
 <version>0.0.1-SNAPSHOT</version>
 <packaging>jar</packaging>
 
 <name>spring-boot-redis</name>
 <url>http://maven.apache.org</url>
 
 <properties>
   <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
   <!--配置JDK编译版本. -->
      
<java.version>1.8</java.version>
 </properties>
 
 <!-- spring boot父节点依赖,
             引入这个之后相关的引入就不需要添加version配置,
               spring boot会自动选择最合适的版本进行添加。
       -->
      
<parent>
             
<groupId>org.springframework.boot</groupId>
             
<artifactId>spring-boot-starter-parent</artifactId>
             
<version>1.3.3.RELEASE</version>
      
</parent>
 
 
 <dependencies>
         
         
<dependency>
                    
<groupId>junit</groupId>
                    
<artifactId>junit</artifactId>
                    
<scope>test</scope>
             
</dependency>
 
             
<!-- springboot web支持:mvc,aop... -->
             
<dependency>
                    
<groupId>org.springframework.boot</groupId>
                    
<artifactId>spring-boot-starter-web</artifactId>
             
</dependency>
             
             
<!--
                    包含支持UI模版(Velocity,FreeMarker,JasperReports),
                    邮件服务,
                    脚本服务(JRuby),
                    缓存Cache(EHCache),
                    任务计划Scheduling(uartz)。
               -->
             
<dependency>
            
<groupId>org.springframework</groupId>
            
<artifactId>spring-context-support</artifactId>
          
</dependency>
 
             
<!-- 添加redis支持-->
             
<dependency>
           
<groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-starter-redis</artifactId>
       
</dependency>
             
             
<!-- JPA操作数据库. -->
             
<dependency>
            
<groupId>org.springframework.boot</groupId>
            
<artifactId>spring-boot-starter-data-jpa</artifactId>
          
</dependency>
             
             
<!-- mysql数据库驱动. -->
             
<dependency>
            
<groupId>mysql</groupId>
            
<artifactId>mysql-connector-java</artifactId>
          
</dependency>
          
          
<!-- 单元测试. -->
             
<dependency>
           
<groupId>org.springframework.boot</groupId>
           
<artifactId>spring-boot-starter-test</artifactId>
           
<scope>test</scope>
       
</dependency>
             
 </dependencies>
</project>
上面是完整的pom.xml文件,每个里面都进行了简单的注释。

 

(3)编写Spring Boot启动类(com.kfit.App);

package com.kfit;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
/**
 * Spring Boot启动类;
 *
 * @authorAngel(QQ:412887952)
 * @version v.0.1
 */
 
@SpringBootApplication
public class App {
       /**
        *-javaagent:.\lib\springloaded-1.2.4.RELEASE.jar -noverify
        * @param args
        */
       public static voidmain(String[] args) {
              SpringApplication.run(App.class,args);
       }
}
 

(4)配置application.properties;

这里主要是配置两个资源,第一就是数据库基本信息;第二就是redis配置;第三就是JPA的配置;

Src/main/resouces/application.properties:

########################################################
###datasource 配置MySQL数据源;
########################################################
spring.datasource.url=jdbc:mysql://localhost:3306/test
spring.datasource.username= root
spring.datasource.password= root
spring.datasource.driverClassName=com.mysql.jdbc.Driver
spring.datasource.max-active=20
spring.datasource.max-idle=8
spring.datasource.min-idle=8
spring.datasource.initial-size=10
 
 
 
########################################################
###REDIS (RedisProperties) redis基本配置;
########################################################
# database name
spring.redis.database=0
# server host1
spring.redis.host=127.0.0.1  
# server password
#spring.redis.password=
#connection port
spring.redis.port=6379
# pool settings ...
spring.redis.pool.max-idle=8
spring.redis.pool.min-idle=0
spring.redis.pool.max-active=8
spring.redis.pool.max-wait=-1
# name of Redis server
#spring.redis.sentinel.master=
# comma-separated list of host:portpairs
#spring.redis.sentinel.nodes=
 
 
########################################################
### Java Persistence Api自动进行建表
########################################################
# Specify the DBMS
spring.jpa.database= MYSQL
# Show or not log for each sqlquery
spring.jpa.show-sql= true
# Hibernate ddl auto (create,create-drop, update)
spring.jpa.hibernate.ddl-auto= update
# Naming strategy
spring.jpa.hibernate.naming-strategy=org.hibernate.cfg.ImprovedNamingStrategy
# stripped before adding them tothe entity manager)
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5Dialect
 
 

 

(5)编写RedisCacheConfig配置类;

       缓存主要有几个要实现的类:其一就是CacheManager缓存管理器;其二就是具体操作实现类;其三就是CacheManager工厂类(这个可以使用配置文件配置的进行注入,也可以通过编码的方式进行实现);其四就是缓存key生产策略(当然Spring自带生成策略,但是在Redis客户端进行查看的话是系列化的key,对于我们肉眼来说就是感觉是乱码了,这里我们先使用自带的缓存策略)。

com.kfit.config/RedisCacheConfig:

package com.kfit.config;
 
importorg.springframework.cache.CacheManager;
importorg.springframework.cache.annotation.CachingConfigurerSupport;
importorg.springframework.cache.annotation.EnableCaching;
importorg.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
importorg.springframework.data.redis.cache.RedisCacheManager;
importorg.springframework.data.redis.connection.RedisConnectionFactory;
importorg.springframework.data.redis.core.RedisTemplate;
 
/**
 *redis缓存配置;
 *
 *注意:RedisCacheConfig这里也可以不用继承 :CachingConfigurerSupport,也就是直接一个普通的Class就好了;
 *
 *这里主要我们之后要重新实现 key的生成策略,只要这里修改KeyGenerator,其它位置不用修改就生效了。
 *
 *普通使用普通类的方式的话,那么在使用@Cacheable的时候还需要指定KeyGenerator的名称;这样编码的时候比较麻烦。
 *
 *@author Angel(QQ:412887952)
 *@version v.0.1
 */
@Configuration
@EnableCaching//启用缓存,这个注解很重要;
publicclass RedisCacheConfigextendsCachingConfigurerSupport {
      
      
      
/**
        *缓存管理器.
        *@param redisTemplate
        *@return
        */
      
@Bean
       public CacheManagercacheManager(RedisTemplate<?,?>redisTemplate) {
              CacheManagercacheManager =newRedisCacheManager(redisTemplate);
              returncacheManager;
       }
 
      
      
/**
        *redis模板操作类,类似于jdbcTemplate的一个类;
        *
        *虽然CacheManager也能获取到Cache对象,但是操作起来没有那么灵活;
        *
        *这里在扩展下:RedisTemplate这个类不见得很好操作,我们可以在进行扩展一个我们
        *
        *自己的缓存类,比如:RedisStorage类;
        *
        *@param factory :通过Spring进行注入,参数在application.properties进行配置;
        *@return
        */
      
@Bean
       publicRedisTemplate<String, String> redisTemplate(RedisConnectionFactoryfactory) {
              RedisTemplate<String,String>redisTemplate =new RedisTemplate<String, String>();
             
redisTemplate.setConnectionFactory(factory);
             
             
//key序列化方式;(不然会出现乱码;),但是如果方法上有Long等非String类型的话,会报类型转换错误;
             
//所以在没有自己定义key生成策略的时候,以下这个代码建议不要这么写,可以不配置或者自己实现ObjectRedisSerializer
             
//或者JdkSerializationRedisSerializer序列化方式;
//           RedisSerializer<String>redisSerializer = new StringRedisSerializer();//Long类型不可以会出现异常信息;
//           redisTemplate.setKeySerializer(redisSerializer);
//           redisTemplate.setHashKeySerializer(redisSerializer);
             
              returnredisTemplate;
       }
 
}
在以上代码有很详细的注释,在这里还是在简单的提下:

RedisCacheConfig这里也可以不用继承:CachingConfigurerSupport,也就是直接一个普通的Class就好了;这里主要我们之后要重新实现 key的生成策略,只要这里修改KeyGenerator,其它位置不用修改就生效了。普通使用普通类的方式的话,那么在使用@Cacheable的时候还需要指定KeyGenerator的名称;这样编码的时候比较麻烦。

 

 

(6)编写DemoInfo测试实体类;

       编写一个测试实体类:com.kfit.bean.DemoInfo:

package com.kfit.bean;
 
import java.io.Serializable;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
/**
 *测试实体类,这个随便;
 *@author Angel(QQ:412887952)
 *@version v.0.1
 */
@Entity
publicclass DemoInfo implements Serializable{
       privatestaticfinallong
serialVersionUID
= 1L;
      
@Id @GeneratedValue
       privatelongid;
       private Stringname;
       private Stringpwd;
       publiclong getId() {
              returnid;
       }
       publicvoid setId(longid)
{
              this.id =id;
       }
       public StringgetName() {
              returnname;
       }
       publicvoid setName(Stringname) {
              this.name =name;
       }
       public String getPwd(){
              returnpwd;
       }
       publicvoid setPwd(Stringpwd) {
              this.pwd =pwd;
       }
      
      
@Override
       public StringtoString() {
              return"DemoInfo [id=" +id +
",name=" +name +
", pwd=" +pwd +
"]";
       }
}
 

(7)编写DemoInfoRepository持久化类;

       DemoInfoRepository使用Spirng DataJPA实现:

com.kfit.repository.DemoInfoRepository:

package com.kfit.repository;
 
import org.springframework.data.repository.CrudRepository;
 
import com.kfit.bean.DemoInfo;
 
/**
 * DemoInfo持久化类
 *@author Angel(QQ:412887952)
 *@version v.0.1
 */
publicinterfaceDemoInfoRepositoryextends CrudRepository<DemoInfo,Long>
{
 
}
 

(8)编写DemoInfoService类;

       编写DemoInfoService,这里有两个技术方面,第一就是使用Spring @Cacheable注解方式和RedisTemplate对象进行操作,具体代码如下:

com.kfit.service.DemoInfoService:

package com.kfit.service;
 
import com.kfit.bean.DemoInfo;
 
/**
 * demoInfo服务接口
 *@author Angel(QQ:412887952)
 *@version v.0.1
 */
publicinterface DemoInfoService{
      
       public DemoInfofindById(longid);
      
       publicvoiddeleteFromCache(longid);
 
       void test();
}
 

 

com.kfit.service.impl.DemoInfoServiceImpl:

package com.kfit.service.impl;
 
import javax.annotation.Resource;
 
importorg.springframework.cache.annotation.CacheEvict;
importorg.springframework.cache.annotation.Cacheable;
importorg.springframework.data.redis.core.RedisTemplate;
importorg.springframework.data.redis.core.ValueOperations;
importorg.springframework.stereotype.Service;
 
import com.kfit.bean.DemoInfo;
importcom.kfit.repository.DemoInfoRepository;
import com.kfit.service.DemoInfoService;
 
/**
 *
 *DemoInfo数据处理类
 *
 *@author Angel(QQ:412887952)
 *@version v.0.1
 */
@Service
publicclass DemoInfoServiceImplimplements DemoInfoService{
      
      
@Resource
       privateDemoInfoRepositorydemoInfoRepository;
      
      
@Resource
       privateRedisTemplate<String,String>redisTemplate;
      
      
@Override
       publicvoid test(){
              ValueOperations<String,String>valueOperations =redisTemplate.opsForValue();
             
valueOperations.set("mykey4",
"random1="+Math.random());
              System.out.println(valueOperations.get("mykey4"));
       }
      
      
//keyGenerator="myKeyGenerator"
      
@Cacheable(value="demoInfo")
//缓存,这里没有指定key.
      
@Override
       public DemoInfofindById(longid) {
              System.err.println("DemoInfoServiceImpl.findById()=========从数据库中进行获取的....id="+id);
              returndemoInfoRepository.findOne(id);
       }
      
      
@CacheEvict(value="demoInfo")
      
@Override
       publicvoid deleteFromCache(longid)
{
              System.out.println("DemoInfoServiceImpl.delete().从缓存中删除.");
       }
      
}
 

 

(9)编写DemoInfoController类;

package com.kfit.controller;
 
importorg.springframework.beans.factory.annotation.Autowired;
importorg.springframework.stereotype.Controller;
importorg.springframework.web.bind.annotation.RequestMapping;
importorg.springframework.web.bind.annotation.ResponseBody;
 
import com.kfit.bean.DemoInfo;
import com.kfit.service.DemoInfoService;
 
/**
 *测试类.
 *@author Angel(QQ:412887952)
 *@version v.0.1
 */
@Controller
publicclass DemoInfoController {
      
      
@Autowired
        DemoInfoService
demoInfoService;
        
      
      
@RequestMapping("/test")
       public@ResponseBody String test(){
           DemoInfo
loaded = demoInfoService.findById(1);
System.out.println("loaded="+loaded);
DemoInfo
cached = demoInfoService.findById(1);
           System.out.println("cached="+cached);
          
loaded = demoInfoService.findById(2);
           System.out.println("loaded2="+loaded);
           return"ok";
       }
      
      
      
@RequestMapping("/delete")
       public@ResponseBody String delete(longid){
          
demoInfoService.deleteFromCache(id);
           return"ok";
       }
      
      
@RequestMapping("/test1")
       public@ResponseBody String test1(){
          
demoInfoService.test();
           System.out.println("DemoInfoController.test1()");
           return"ok";
       }
      
}
 

(10)测试代码是否正常运行了

 

启动应用程序,访问地址:http://127.0.0.1:8080/test

查看控制台可以查看:

DemoInfoServiceImpl.findById()=========从数据库中进行获取的....id=1
loaded=DemoInfo [id=1, name=张三, pwd=123456]
cached=DemoInfo [id=1, name=张三, pwd=123456]
DemoInfoServiceImpl.findById()=========从数据库中进行获取的....id=2
loaded2=DemoInfo [id=2, name=张三, pwd=123456]
如果你看到以上的打印信息的话,那么说明缓存成功了。

 

访问地址:http://127.0.0.1:8080/test1

random1=0.9985031320746356
DemoInfoController.test1()
 

二次访问:http://127.0.0.1:8080/test

loaded=DemoInfo [id=1, name=张三, pwd=123456]
cached=DemoInfo [id=1, name=张三, pwd=123456]
loaded2=DemoInfo [id=2, name=张三, pwd=123456]
这时候所有的数据都是执行缓存的。

 

这时候执行删除动作:http://127.0.0.1:8080/delete?id=1

然后在访问:http://127.0.0.1:8080/test

DemoInfoServiceImpl.findById()=========从数据库中进行获取的....id=1
loaded=DemoInfo [id=1, name=张三, pwd=123456]
cached=DemoInfo [id=1, name=张三, pwd=123456]
loaded2=DemoInfo [id=2, name=张三, pwd=123456]
 

(11)自定义缓存key;

在com.kfit.config.RedisCacheConfig类中重写CachingConfigurerSupport中的keyGenerator ,具体实现代码如下:

 
/**
        *自定义key.
        *此方法将会根据类名+方法名+所有参数的值生成唯一的一个key,即使@Cacheable中的value属性一样,key也会不一样。
        */
      
@Override
       public KeyGeneratorkeyGenerator() {
              System.out.println("RedisCacheConfig.keyGenerator()");
              returnnew KeyGenerator(){
                    
@Override
                    
public
Objectgenerate(Object
o, Method method, Object...
objects) {
                           
// This willgenerate a unique key of the class name, the method name
                           
//and allmethod parameters appended.
                            StringBuildersb =newStringBuilder();
                           
sb.append(o.getClass().getName());
                           
sb.append(method.getName());
                           
for
(Object
obj : objects) {
                                  sb.append(obj.toString());
                            }
                            System.out.println("keyGenerator=" +sb.toString());
                           
return
sb.toString();
                     }
              };
       }
 
这时候在redis的客户端查看key的话还是序列化的肉眼看到就是乱码了,那么我改变key的序列方式,这个很简单,redis底层已经有具体的实现类了,我们只需要配置下:
//key序列化方式;(不然会出现乱码;),但是如果方法上有Long等非String类型的话,会报类型转换错误;
//所以在没有自己定义key生成策略的时候,以下这个代码建议不要这么写,可以不配置或者自己实现ObjectRedisSerializer
//或者JdkSerializationRedisSerializer序列化方式;
              RedisSerializer<String>redisSerializer =newStringRedisSerializer();//Long类型不可以会出现异常信息;
             
redisTemplate.setKeySerializer(redisSerializer);
              redisTemplate.setHashKeySerializer(redisSerializer);
综上以上分析:RedisCacheConfig类的方法调整为:

package com.kfit.config;
 
import java.lang.reflect.Method;
 
importorg.springframework.cache.CacheManager;
importorg.springframework.cache.annotation.CachingConfigurerSupport;
importorg.springframework.cache.annotation.EnableCaching;
importorg.springframework.cache.interceptor.KeyGenerator;
importorg.springframework.context.annotation.Bean;
importorg.springframework.context.annotation.Configuration;
importorg.springframework.data.redis.cache.RedisCacheManager;
importorg.springframework.data.redis.connection.RedisConnectionFactory;
importorg.springframework.data.redis.core.RedisTemplate;
importorg.springframework.data.redis.serializer.RedisSerializer;
importorg.springframework.data.redis.serializer.StringRedisSerializer;
 
/**
 *redis缓存配置;
 *
 *注意:RedisCacheConfig这里也可以不用继承 :CachingConfigurerSupport,也就是直接一个普通的Class就好了;
 *
 *这里主要我们之后要重新实现 key的生成策略,只要这里修改KeyGenerator,其它位置不用修改就生效了。
 *
 *普通使用普通类的方式的话,那么在使用@Cacheable的时候还需要指定KeyGenerator的名称;这样编码的时候比较麻烦。
 *
 *@author Angel(QQ:412887952)
 *@version v.0.1
 */
@Configuration
@EnableCaching//启用缓存,这个注解很重要;
publicclass RedisCacheConfigextendsCachingConfigurerSupport {
      
      
/**
        *缓存管理器.
        *@param redisTemplate
        *@return
        */
      
@Bean
       public CacheManagercacheManager(RedisTemplate<?,?>redisTemplate) {
              CacheManagercacheManager =newRedisCacheManager(redisTemplate);
              returncacheManager;
       }
 
      
      
/**
        * RedisTemplate缓存操作类,类似于jdbcTemplate的一个类;
        *
        *虽然CacheManager也能获取到Cache对象,但是操作起来没有那么灵活;
        *
        *这里在扩展下:RedisTemplate这个类不见得很好操作,我们可以在进行扩展一个我们
        *
        *自己的缓存类,比如:RedisStorage类;
        *
        *@param factory :通过Spring进行注入,参数在application.properties进行配置;
        *@return
        */
      
@Bean
       publicRedisTemplate<String, String> redisTemplate(RedisConnectionFactoryfactory) {
              RedisTemplate<String,String>redisTemplate =new RedisTemplate<String, String>();
             
redisTemplate.setConnectionFactory(factory);
             
             
//key序列化方式;(不然会出现乱码;),但是如果方法上有Long等非String类型的话,会报类型转换错误;
             
//所以在没有自己定义key生成策略的时候,以下这个代码建议不要这么写,可以不配置或者自己实现ObjectRedisSerializer
             
//或者JdkSerializationRedisSerializer序列化方式;
              RedisSerializer<String>redisSerializer =newStringRedisSerializer();//Long类型不可以会出现异常信息;
             
redisTemplate.setKeySerializer(redisSerializer);
             
redisTemplate.setHashKeySerializer(redisSerializer);
             
              returnredisTemplate;
       }
      
      
/**
        *自定义key.
        *此方法将会根据类名+方法名+所有参数的值生成唯一的一个key,即使@Cacheable中的value属性一样,key也会不一样。
        */
      
@Override
       public KeyGeneratorkeyGenerator() {
              System.out.println("RedisCacheConfig.keyGenerator()");
              returnnew KeyGenerator(){
                    
@Override
                    
public
Objectgenerate(Object
o, Method method, Object...
objects) {
                           
// This willgenerate a unique key of the class name, the method name
                           
//and allmethod parameters appended.
                            StringBuildersb =newStringBuilder();
                           
sb.append(o.getClass().getName());
                           
sb.append(method.getName());
                           
for
(Object
obj : objects) {
                                  sb.append(obj.toString());
                            }
                            System.out.println("keyGenerator=" +sb.toString());
                           
return
sb.toString();
                     }
              };
       }
 
}
 

这时候在访问地址:http://127.0.0.1:8080/test

这时候看到的Key就是:com.kfit.service.impl.DemoInfoServiceImplfindById1

在控制台打印信息是:

(1)keyGenerator=com.kfit.service.impl.DemoInfoServiceImplfindById1
(2)DemoInfoServiceImpl.findById()=========从数据库中进行获取的....id=1
(3)keyGenerator=com.kfit.service.impl.DemoInfoServiceImplfindById1
(4)loaded=DemoInfo[id=1, name=张三, pwd=123456]
(5)keyGenerator=com.kfit.service.impl.DemoInfoServiceImplfindById1
(6)cached=DemoInfo[id=1, name=张三, pwd=123456]
(7)keyGenerator=com.kfit.service.impl.DemoInfoServiceImplfindById2
(8)keyGenerator=com.kfit.service.impl.DemoInfoServiceImplfindById2
(10)DemoInfoServiceImpl.findById()=========从数据库中进行获取的....id=2
(11)loaded2=DemoInfo[id=2, name=张三, pwd=123456]
其中@Cacheable,@CacheEvict下节进行简单的介绍,这节的东西实在是太多了,到这里就打住吧,剩下的就需要靠你们自己进行扩展了。

【Spring Boot 系列视频】

视频&交流平台:

à Spring Boot网易云课堂视频
http://study.163.com/course/introduction.htm?courseId=1004329008
à Spring Boot交流平台
http://412887952-qq-com.iteye.com/blog/2321532
 

网易云课堂视频最新更新

第十一章 Spring Boot 日志

1、spring boot日志—理论

2、Spring Boot日志-logback

3、Spring Boot日志-log4j2

第十二章 Spring Boot 知识点2

1、spring boot 服务配置和部署

2、Spring Boot 定制URL匹配规则

 
 
历史章节:

 

第一章 快速开始

1、Spring Boot之Hello World

2、Spring Boot之Hello World访问404

 

第二章 Spring Boot之JSON

1、spring boot返回json数据

2、Spring Boot完美使用FastJson解析JSON数据

 

第三章 Spring Boot热部署

1、Spring Boot热部署(springloader)

2、springboot + devtools(热部署)

 

第四章 Spring Boot数据库

1、Spring Boot JPA/Hibernate/Spring Data概念

2、Spring Boot JPA-Hibernate

3、Spring Boot Spring Data JPA介绍

4、Spring Boot JdbcTemplate

5、Spring Boot集成MyBatis

 

第五章 web开发

1、全局异常捕捉

2、配置server信息

3、spring boot使用thymeleaf

4、Spring Boot 使用freemarker

5、Spring Boot添加JSP支持

 

第六章 定时任务

1、Spring Boot定时任务

2、Spring Boot 定时任务升级篇(动态修改cron参数)

3、Spring Boot 定时任务升级篇(动态添加修改删除定时任务)

4、Spring Boot 定时任务升级篇(集群/分布式下的定时任务说明)

5、Spring Boot Quartz介绍

6、Spring Boot Quartz在Java Project中使用

7、Spring Boot 集成Quartz普通使用

8、Spring Boot 集成Quartz升级版

9、Spring Boot 集成Quartz二次升级版

10、Spring Boot 集成Quartz-Job如何自动注入Spring容器托管的对象

 

第七章 Spring Boot MyBatis升级篇

1、Spring Boot MyBatis升级篇-注解

2、Spring Boot MyBatis升级篇-注解-自增ID

3、Spring Boot MyBatis升级篇-注解-增删改查

4、Spring Boot MyBatis升级篇-注解-分页查询

5、Spring Boot MyBatis升级篇-注解-分页PageHelper不生效

6、Spring Boot MyBatis升级篇-注解- mybatic insert异常:BindingException: Parameter 'name' not found

7、Spring Boot MyBatis升级篇-注解- #和$符号特别篇

8、Spring Boot MyBatis升级篇-注解-@Result

9、Spring Boot MyBatis升级篇-注解-动态SQL(if test)-方案一:<script>

10、Spring Boot MyBatis升级篇-注解-动态SQL(if test)-方案二:@Provider

11、Spring Boot MyBatis升级篇-注解-动态SQL-参数问题

12、Spring Boot MyBatis升级篇-注解-特别篇:@MapperScan和@Mapper

13、Spring Boot MyBatis升级篇-XML

14、Spring Boot MyBatis升级篇-XML-自增ID

15、Spring Boot MyBatis升级篇-XML-增删改查

16、Spring Boot MyBatis升级篇-XML-分页查询

17、Spring Boot MyBatis升级篇-XML-分页PageHelper不生效

18、Spring Boot MyBatis升级篇-XML-动态SQL(if test)

19、Spring Boot MyBatis升级篇-XML-注解-初尝试

20、Spring Boot MyBatis升级篇- pagehelper替换为pagehelper-spring-boot-starter

 

第八章 Spring Boot 知识点1

1、Spring Boot 拦截器HandlerInterceptor

2、Spring Boot启动加载数据CommandLineRunner

3、Spring Boot环境变量读取和属性对象的绑定

4、Spring Boot使用自定义的properties

5、Spring Boot使用自定义的properties

6、Spring Boot使用@SpringBootApplication

7、Spring Boot 监控和管理生产环境

 

第十章 Spring Boot 打包部署

1、Spring Boot打包部署((提供Linux的sh文件))

 

第十一章 Spring Boot 日志

1、spring boot日志—理论

2、Spring Boot日志-logback

 
3、Spring Boot日志-log4j2
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息