diff --git a/java/springboot系列/数据库/springboot整合mybatis(xml和注解).md b/java/springboot系列/数据库/1.springboot整合mybatis(xml和注解).md
similarity index 100%
rename from java/springboot系列/数据库/springboot整合mybatis(xml和注解).md
rename to java/springboot系列/数据库/1.springboot整合mybatis(xml和注解).md
diff --git a/java/springboot系列/数据库/2.springboot整合redis缓存.md b/java/springboot系列/数据库/2.springboot整合redis缓存.md
new file mode 100644
index 0000000..149ee53
--- /dev/null
+++ b/java/springboot系列/数据库/2.springboot整合redis缓存.md
@@ -0,0 +1,243 @@
+---
+id: '2019-02-22-14-59'
+date: '2019/02/22 14:59:00'
+title: 'springboot整合redis'
+tag: ['java', 'spring-boot', 'redis', 'nosql', '缓存']
+categories:
+  - 'java'
+  - 'spring boot学习'
+---
+
+![薄暮传说](https://raw.githubusercontent.com/FleyX/files/master/blogImg/20190311141056.png)
+
+**本篇原创发布于:**[springboot整合redis](http://www.tapme.top/blog/detail/2019-02-22-14-59)
+
+**项目源码:**:[github](https://github.com/FleyX/demo-project/tree/master/1.SSO%E5%8D%95%E7%82%B9%E7%99%BB%E5%BD%95/sso)
+
+​  redis 作为一个高性能的内存数据库,如果不会用就太落伍了,之前在 node.js 中用过 redis,本篇记录如何将 redis 集成到 spring boot 中。提供 redis 操作类,和注解使用 redis 两种方式。主要内容如下:
+
+- docker 安装 redis
+- springboot 集成 redis
+- 编写 redis 操作类
+- 通过注解使用 redis
+
+# 安装 redis
+
+  通过 docker 安装,docker compose 编排文件如下:
+
+```yml
+# docker-compose.yml
+version: '2'
+services:
+  redis:
+    container_name: redis
+    image: redis:3.2.10
+    ports:
+      - '6379:6379'
+```
+
+  然后在`docker-compose.yml`所在目录使用`docker-compose up -d`命令,启动 redis。
+
+<!-- readmore -->
+
+# 集成 springboot
+
+&emsp;&emsp;说明:springboot 版本为 2.1.3
+
+## 添加 maven 依赖
+
+&emsp;&emsp;只需添加`spring-boot-starter-data-redis`依赖即可
+
+```xml
+<dependency>
+    <groupId>org.springframework.boot</groupId>
+    <artifactId>spring-boot-starter-data-redis</artifactId>
+</dependency>
+```
+
+## 编写 springboot 配置文件
+
+&emsp;&emsp;配置文件如下:
+
+```yaml
+server:
+  port: 8081
+  servlet:
+    context-path: /sso
+spring:
+  application:
+    name: SSO
+  cache:
+    type: redis
+  redis:
+    database: 0
+    host: 192.168.226.5
+    port: 6379
+    # 有密码填密码,没有密码不填
+    password:
+    # 连接超时时间(ms)
+    timeout: 1000ms
+    # 高版本springboot中使用jedis或者lettuce
+    jedis:
+      pool:
+        # 连接池最大连接数(负值表示无限制)
+        max-active: 8
+        # 连接池最大阻塞等待时间(负值无限制)
+        max-wait: 5000ms
+        # 最大空闲链接数
+        max-idle: 8
+        # 最小空闲链接数
+        min-idle: 0
+```
+
+## 编写配置类
+
+&emsp;&emsp;配置类代码如下:
+
+```java
+@EnableCaching//开启缓存
+@Configuration
+public class RedisConfig extends CachingConfigurerSupport {
+
+    /**
+     * 设置缓存管理器,这里可以配置默认过期时间等
+     *
+     * @param connectionFactory 连接池
+     * @return
+     */
+    @Bean
+    public CacheManager cacheManager(RedisConnectionFactory connectionFactory) {
+        RedisCacheConfiguration redisCacheConfiguration = RedisCacheConfiguration
+                .defaultCacheConfig()
+                .entryTtl(Duration.ofSeconds(60));
+        //注意:请勿使用先new 配置对象,然后在调用entryTtl方法的方式来操作
+        //会导致配置不生效,原因是调用.entryTtl方法会返回一个新的配置对象,而不是在原来的配置对象上修改
+
+        RedisCacheWriter redisCacheWriter = RedisCacheWriter.nonLockingRedisCacheWriter(connectionFactory);
+        RedisCacheManager manager = new RedisCacheManager(redisCacheWriter, redisCacheConfiguration);
+        return manager;
+    }
+
+    @SuppressWarnings("all")
+    @Bean
+    public RedisTemplate<String, String> redisTemplate(RedisConnectionFactory factory) {
+        StringRedisTemplate template = new StringRedisTemplate(factory);
+        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
+        ObjectMapper om = new ObjectMapper();
+        om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
+        om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
+        jackson2JsonRedisSerializer.setObjectMapper(om);
+        RedisSerializer stringSerializer = new StringRedisSerializer();
+        template.setKeySerializer(stringSerializer);
+        template.setValueSerializer(jackson2JsonRedisSerializer);
+        template.setHashKeySerializer(stringSerializer);
+        template.setHashValueSerializer(jackson2JsonRedisSerializer);
+        template.afterPropertiesSet();
+        return template;
+    }
+}
+```
+
+## 使用方法
+
+&emsp;&emsp;有两种方法来进行缓存操作,一种是在方法上添加缓存注解实现各种操作,一种是手动控制。个人比较喜欢手动控制,觉得这样都在自己的掌控中。
+
+### 通过注解使用
+
+&emsp;&emsp;主要有以下 5 个注解:
+
+- `@CacheConfig`: 类级别缓存,设置缓存 key 前缀之类的
+- `@Cacheable`: 触发缓存入口
+- `@CacheEvict`: 触发移除缓存
+- `@CachePut`: 更新缓存
+- `@Caching`: 组合缓存
+
+#### @CacheConfig
+
+&emsp;&emsp;该注解可以将缓存分类,它是类级别注解,主要用于给某个类的缓存全局配置,例子如下:
+
+```java
+@CacheConfig(cacheNames = "redis_test")
+@Service
+public class RedisService {
+  //....
+}
+```
+
+上面 CacheConfig 会给类下通过注解生成的 key 加上 redis_test 的前缀。
+
+#### @Cacheable
+
+&emsp;&emsp;方法级别注解,根据 key 查询缓存:
+
+- 如果 key 不存在,将方法返回值缓存到 redis 中
+- 如果 key 存在,直接从缓存中取值
+  例子如下:
+
+```java
+    /**
+     * 缓存时间,首次查询后会缓存结果,key中的值可使用表达式计算.
+     * 如不提供key,将使用默认key构造方法生成一个key
+     * @return long
+     */
+    @Cacheable(key = "'currentTime'")
+    public long getTime() {
+        return System.currentTimeMillis();
+    }
+```
+
+多次调用此段代码会发现每次返回的值都是一样的。
+
+#### CachePut
+
+&emsp;&emsp;用于更新缓存,每次调用都会想 db 请求,缓存数据
+
+- 如果 key 存在,更新内容
+- 如果 key 不存在,插入内容
+
+代码如下:
+
+```java
+/**
+     * 一般用于更新查插入操作,每次都会请求db
+     */
+    @CachePut(key = "'currentTime'+#id")
+    public long updateTime(String id) {
+        return System.currentTimeMillis();
+    }
+```
+
+每次调用此方法都会根据 key 刷新 redis 中的缓存数据。
+
+#### @CacheEvict
+
+&emsp;&emsp;根据 key 删除缓存中的数据。allEntries=true 表示删除缓存中所有数据。
+代码如下:
+
+```java
+    @CacheEvict(key = "'currentTime'+#id",allEntries=false)
+    public void deleteTime(String id) {
+    }
+```
+
+#### @Caching
+
+&emsp;&emsp;本注解可将其他注解组合起来使用。比如下面的例子:
+
+```java
+    //value属性为key指定前缀
+    @Caching(put = {@CachePut(value = "user", key = "'name_'+#user.name"),
+            @CachePut(value = "user", key = "'pass_'+#user.password")})
+    public User testCaching(User user) {
+        return user;
+    }
+```
+上面的代码执行后将在redis中插入两条记录。使用`keys *`将看到如下结果:
+
+![结果](https://raw.githubusercontent.com/FleyX/files/master/blogImg/20190311140300.png)
+
+### 手动控制
+
+&emsp;&emsp;手动控制就相当于mybatis的手写sql语句,需要调用`redisTemplate`中的各种方法来进行缓存查询,缓存更新,缓存删除等操作。
+
+&emsp;&emsp;使用方法参见util/RedisUtil中的方法。`redisTemplate`基本可以实现所有的redis操作。
diff --git a/java/springboot系列/数据库/springboot整合redis.md b/java/springboot系列/数据库/springboot整合redis.md
deleted file mode 100644
index df2d22f..0000000
--- a/java/springboot系列/数据库/springboot整合redis.md
+++ /dev/null
@@ -1,36 +0,0 @@
----
-id: "2019-02-22-14-59"
-date: "2019/02/22 14:59:00"
-title: "springboot整合redis"
-tag: ["java","spring-boot","redis","nosql"]
-categories: 
-- "java"
-- "spring boot学习"
----
-
-&emsp;&emsp;项目源代码在 github,地址为:[https://github.com/FleyX/demo-project/tree/master/mybatis-test](https://github.com/FleyX/demo-project/tree/master/mybatis-test),有需要的自取。
-
-​&emsp;&emsp;redis作为一个高性能的内存数据库,如果不会用就太落伍了,之前在node.js中用过redis,本篇记录如何将redis集成到spring boot中。提供redis操作类,和注解使用redis两种方式。主要内容如下:
-
-- docker安装redis
-- springboot 集成redis
-- 编写redis操作类
-- 通过注解使用redis
-
-# 安装redis
-
-&emsp;&emsp;通过docker安装,docker compose编排文件如下:
-```yml
-# docker-compose.yml
-version: "3"
-services:
-  redis:
-    container_name: redis
-    image: redis:3.2.10
-    ports:
-      - "6379:6379"
-```
-
-&emsp;&emsp;然后在`docker-compose.yml`所在目录使用`docker-compose up -d`命令,启动redis。
-
-# 集成springboot
\ No newline at end of file
diff --git a/其他各种/docker部署hexo博客.md b/其他各种/docker部署hexo博客.md
index f45da62..50abc93 100644
--- a/其他各种/docker部署hexo博客.md
+++ b/其他各种/docker部署hexo博客.md
@@ -1,20 +1,20 @@
 ---
-id: "2019-03-03-15-42"
-date: "2019-03-03-15-42"
-title: "docker实现hexo博客自动部署,实时更新"
-tags: ["docker", "hexo", "next", "webhook"]
+id: '2019-03-03-15-42'
+date: '2019-03-03-15-42'
+title: 'docker实现hexo博客自动部署,实时更新'
+tags: ['docker', 'hexo', 'next', 'webhook']
 categories:
-  - "其他"
+  - '其他'
 ---
 
 ## 一、背景
 
-&emsp;&emsp;你是否有过想要搭建一个hexo博客,但是看着那冗长的教程,唉声叹气?
+&emsp;&emsp;你是否有过想要搭建一个 hexo 博客,但是看着那冗长的教程,唉声叹气?
 &emsp;&emsp;你是否因为每次发布新的博文,都要重新构建,部署而逐渐放弃写博客?
 
-&emsp;&emsp;现在解决有了完美的解决办法了,一键构建,无需进行复杂的配置,开箱即用。同时支持github的webhook来实现实时构建,只需就行一次push操作,便能自动重新构建发布,无需手动操作。
+&emsp;&emsp;现在解决有了完美的解决办法了,一键构建,无需进行复杂的配置,开箱即用。同时支持 github 的 webhook 来实现实时构建,只需就行一次 push 操作,便能自动重新构建发布,无需手动操作。
 
-&emsp;&emsp;详见[hexoBlog自动构建](https://github.com/FleyX/hexoBlog)
+&emsp;&emsp;详见[hexoBlog 自动构建](https://github.com/FleyX/hexoBlog)
 
 使用方法:
 
@@ -30,16 +30,16 @@ git clone git@github.com:FleyX/hexoBlog.git
 
 ![docker-compose文件修改](https://raw.githubusercontent.com/FleyX/files/master/blog/20190303145035.png)
 
-**github配置webhock步骤如下:**
+**github 配置 webhock 步骤如下:**
 &emsp;&emsp;以我的博文仓库(technology-note)为例:
 
-- 新增一个webhook
-![](https://raw.githubusercontent.com/FleyX/files/master/blog/20190303161438.png)
+- 新增一个 webhook
+  ![](https://raw.githubusercontent.com/FleyX/files/master/blog/20190303161438.png)
 
-- 配置webhook
-![](https://raw.githubusercontent.com/FleyX/files/master/blog/20190303161713.png)
+- 配置 webhook
+  ![](https://raw.githubusercontent.com/FleyX/files/master/blog/20190303161713.png)
 
-&emsp;&emsp;将url的地址换为你的服务器地址,然后设置secret密钥,就OK了。再将密钥设置到docker-compose.yml中即可。
+&emsp;&emsp;将 url 的地址换为你的服务器地址,然后设置 secret 密钥,就 OK 了。再将密钥设置到 docker-compose.yml 中即可。
 
 2. 博文 markdown 文件编写规范,详情参见[分布式事务.md](https://raw.githubusercontent.com/FleyX/technology-note/master/%E6%95%B0%E6%8D%AE%E5%BA%93/%E5%88%86%E5%B8%83%E5%BC%8F/%E5%88%86%E5%B8%83%E5%BC%8F%E4%BA%8B%E5%8A%A1.md):
 
@@ -47,13 +47,13 @@ git clone git@github.com:FleyX/hexoBlog.git
 
 ```yaml
 ---
-id: "2018-10-03-10-58"
-date: "2018/10/03 10:58"
-title: "分布式事务"
-tags: ["分布式", "sql", "2PC", "TCC", "异步补偿"]
+id: '2018-10-03-10-58'
+date: '2018/10/03 10:58'
+title: '分布式事务'
+tags: ['分布式', 'sql', '2PC', 'TCC', '异步补偿']
 categories:
-  - "数据库"
-  - "分布式事务"
+  - '数据库'
+  - '分布式事务'
 ---
 
 ```
@@ -93,7 +93,7 @@ categories:
 title: Hexo
 subtitle: To strive, to seek, to find, and not to yield.
 description: To strive, to seek, to find, and not to yield.
-keywords: ["java", "node", "html", "javascript"]
+keywords: ['java', 'node', 'html', 'javascript']
 author: fleyX
 ```
 
@@ -101,26 +101,26 @@ author: fleyX
 
 ### 设置社交信息
 
-&emsp;&emsp;编辑第178行social下项目:
+&emsp;&emsp;编辑第 178 行 social 下项目:
 
 ![](https://raw.githubusercontent.com/FleyX/files/master/blog/20190303151851.png)
 
 ### 设置打赏
 
-&emsp;&emsp;编辑327行reward下属性,设置支付宝/微信收款图片,可将图片放到`hexo/source/static/img`目录下。
+&emsp;&emsp;编辑 327 行 reward 下属性,设置支付宝/微信收款图片,可将图片放到`hexo/source/static/img`目录下。
 
 ![](https://raw.githubusercontent.com/FleyX/files/master/blog/20190303152128.png)
 
-### 集成gitment评价
+### 集成 gitalk 评论
 
-&emsp;&emsp;建议百度如何配置gitment,这里默认你已经会完毕,拥有id和secret。编辑570行,设置enable为true,然后加入你的信息:
+&emsp;&emsp;建议百度如何在 github 中配置 gitalk,这里默认你已经配置完毕,拥有 id 和 secret。编辑 570 行,设置 enable 为 true,然后加入你的信息:
 
 ![](https://raw.githubusercontent.com/FleyX/files/master/blog/20190303152638.png)
 
-### 集成cnzz统计
+### 集成 cnzz 统计
 
-&emsp;&emsp;设置635行,cnzz id即可
+&emsp;&emsp;设置 635 行,cnzz id 即可
 
 ![](https://raw.githubusercontent.com/FleyX/files/master/blog/20190303152519.png)
 
-其他更加详细配置参看官方文档。
\ No newline at end of file
+其他更加详细配置参看官方文档。