SpringBoot整合Redis、ApacheSolr和SpringSession

一、简介

  SpringBoot自从问世以来,以其方便的配置受到了广大开发者的青睐。它提供了各种starter简化很多繁琐的配置。SpringBoot整合Druid、Mybatis已经司空见惯,在这里就不详细介绍了。今天我们要介绍的是使用SpringBoot整合Redis、ApacheSolr和SpringSession。

二、SpringBoot整合Redis

  Redis是大家比较常用的缓存之一,一般Redis都会搭建高可用(HA),Cluster或者Sentinel。具体的搭建方法请参照Redis官方文档。我们这里已Sentinel举例,搭建RedisSentinel一般都是3个节点,Redis的端口一般是6379,Sentinel的端口一般是26379。

  我们要使用SpringBoot整合Redis,首先要把对应的Redis的starter加入到POM中:

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

  引入jar包以后,我们直接在application.properties文件中,添加RedisSentinel的配置即可完成整合。

spring.redis.sentinel.master=mymaster
spring.redis.sentinel.nodes=192.168.2.233:26379,192.168.2.234:26379,192.168.2.235:26379
spring.redis.pool.max-active=1024
spring.redis.pool.max-idle=200
spring.redis.pool.min-idle=100
spring.redis.pool.max-wait=10000

  sentinel.master是master的名称,我们搭建RedisSentinel时使用的默认的名称mymaster。

  sentinel.nodes是sentinel的节点,注意是sentinel的节点,不是redis的节点。用ip:端口的格式,多个节点用“,”隔开。

  下面则是一些连接池的信息:

    pool.max-active:最大活跃数

    pool.max-idle:最大空闲数

    pool.min-idle:最小空闲数

    pool.max-wait:最大等待时间

  在程序中,我们可以直接注入redisTemplate,对Redis进行操作

@Autowired
private StringRedisTemplate stringRedisTemplate;

  至此,Redis整合完了。

三、SpringBoot整合SpringSession

  SpringSession提供了集群Session的管理,无需通过容器。它可以接入不同的存储层,例如:数据库、Redis、MongoDB等。它可以和SpringBoot无缝结合。

  首先,我们将SpringSession引入到项目中,在POM中加入如下配置:

<dependency>
<groupId>org.springframework.session</groupId>
<artifactId>spring-session</artifactId>
</dependency>

  然后在application.properties中指定一下SpringSession的存储类型:

spring.session.store-type=redis

  这样就非常简单的整合了SpringSession,如果对cookie有特别的要求,可以在项目中新建cookie的Bean来代替SpringBoot自动创建的bean。具体如下:

        @Bean
public DefaultCookieSerializer cookieSerializer(){
DefaultCookieSerializer cookie = new DefaultCookieSerializer();
cookie.setCookieName("springboot_id");
return cookie;
}

  上述的例子,我们修改了cookie的名字。如需修改其他属性,请set相关的属性值。

四、SpringBoot整合Solr

  ApacheSolr是比较常见的搜索引擎,SpringBoot也可以非常方便的整合solr,方便大家的开发。具体的ApacheSolr的概念以及用法请自行查阅相关文档。在搭建solr时,我们一般都会借助zookeeper来搭建SolrCloud,以提高Solr的可用性。在这里我们整理SolrCloud。

  首先我们引入ApacheSolr的starter:

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-solr</artifactId>
</dependency>

  在application.properties中,添加zookeeper的信息,如下:

spring.data.solr.zk-host=192.168.2.233:2181,192.168.2.234:2181,192.168.2.235:2181

  多个zookeeper时,用“,”隔开。

  这样,SpringBoot整合ApacheSolr就完成了,非常方便吧。接下来我们就可以用Spring-data来访问solr了。

  1、编写自己的实体类对应solr返回的数据,具体代码如下:

@Setter@Getter
@SolrDocument(solrCoreName = "xy_company")
public class SolrCompany {
@Field("id")
private String id;
@Field("companyName_txt")
private String companyName;
}

  @Setter@Getter这两个注解大家比较常见,用于生成get、set方法。

  @SolrDocument(solrCoreName = "xy_company"),用于指定这个实体对应solr中的core或collection,core是单实例中的称呼,collection是SolrCloud中的称呼,意思大体一样。

  @Field("id"),用于指定对应solr中的字段。

  2、编写自己的存储层,继承SolrCrudRepository,如下:

public interface CompanyRepository extends SolrCrudRepository<SolrCompany,String> {
List<SolrCompany> findByCompanyName(String companyName);
}

  这样,这个存储层就可以访问solr了,如果多个存储层共用一个实体,可以写多个存储层,继承不同Repository,具体请查阅Spring-data。

  3、在自己的业务中,使用solr

 public List<SolrCompany> getCompanyByName(String companyName){
return companyRepository.findByCompanyName(companyName);
}

  至此,SpringBoot整合Solr就完成了,很简单吧。

接下来,我们还将介绍一些主流框架的整合,比如:MongoDB,Kafka等。本次的详细代码请参照我的GitHub:https://github.com/bigbugliu/spring-boot-demo。

  

SpringBoot整合Redis、ApachSolr和SpringSession的更多相关文章

  1. SpringBoot整合Redis及Redis工具类撰写

            SpringBoot整合Redis的博客很多,但是很多都不是我想要的结果.因为我只需要整合完成后,可以操作Redis就可以了,并不需要配合缓存相关的注解使用(如@Cacheable). ...

  2. SpringBoot 整合 Redis缓存

    在我们的日常项目开发过程中缓存是无处不在的,因为它可以极大的提高系统的访问速度,关于缓存的框架也种类繁多,今天主要介绍的是使用现在非常流行的NoSQL数据库(Redis)来实现我们的缓存需求. Spr ...

  3. SpringBoot系列十:SpringBoot整合Redis

    声明:本文来源于MLDN培训视频的课堂笔记,写在这里只是为了方便查阅. 1.概念:SpringBoot 整合 Redis 2.背景 Redis 的数据库的整合在 java 里面提供的官方工具包:jed ...

  4. springboot整合redis(注解形式)

    springboot整合redis(注解形式) 准备工作 springboot通常整合redis,采用的是RedisTemplate的形式,除了这种形式以外,还有另外一种形式去整合,即采用spring ...

  5. springboot整合redis(简单整理)

    Redis安装与开启 我这里是在windows上练习,所以这里的安装是指在windows上的安装,操作非常简单,点击https://github.com/MicrosoftArchive/redis/ ...

  6. SpringBoot整合redis哨兵主从服务

    前提环境: 主从配置 http://www.cnblogs.com/zwcry/p/9046207.html 哨兵配置 https://www.cnblogs.com/zwcry/p/9134721. ...

  7. springboot整合redis——redisTemplate的使用

    一.概述 相关redis的概述,参见Nosql章节 redisTemplate的介绍,参考:http://blog.csdn.net/ruby_one/article/details/79141940 ...

  8. 九、springboot整合redis二之缓冲配置

    1.创建Cache配置类 @Configuration @EnableCaching public class RedisCacheConfig extends CachingConfigurerSu ...

  9. 三:Springboot整合Redis

    一:springboot整合redis redis版本:3.0.0 运行环境:linux 1.安装redis 1.1安装gcc yum install gcc-c++ 1.2解压redis.3.0.0 ...

随机推荐

  1. True 和 False

    True 和 False是Python中的关键字. 'True' 和 'False'是Python中的字符串. true 和 false 是Python中的变量名,需要提前定义.

  2. 学习web前端技术的笔记,仅供自己查阅备忘,图片上传预览

    <!DOCTYPE html><html><head lang="en"> <meta charset="UTF-8" ...

  3. bzoj usaco 金组水题题解(1)

    UPD:我真不是想骗访问量TAT..一开始没注意总长度写着写着网页崩了王仓(其实中午的时候就时常开始卡了= =)....损失了2h(幸好长一点的都单独开了一篇)....吓得赶紧分成两坨....TAT. ...

  4. [国嵌攻略][106][Linux内存管理子系统]

    内存管理子系统 1.虚拟地址与物理地址的映射 2.物理内存的分配 Linux虚拟地址空间分布 设备最后访问的一定是物理地址,但Linux系统中使用的都是虚拟地址.虚拟地址简单的来说就是程序中使用的地址 ...

  5. C语言mktime()

    最近在调试stm32L151单片机,因为业务需要将从RTC获取的时间转换成时间戳.转换的时候发现获取的时间一直不对.一直被两个问题困扰. 1.从RTC获取出来的月份为什么比实际月份小1? 2.转换得来 ...

  6. 解决spring定时任务执行2次和tomcat部署缓慢的问题

    spring定时任务执行2次 问题重现和解析 最近使用quartz定时任务框架,结果发现开发环境执行无任何问题,部署到服务器上后,发现同一时间任务执行了多次.经过搜索发现是服务器上tomcat的配置文 ...

  7. NGINX 配置404错误页面转向

    什么是404页面 如果碰巧网站出了问题,或者用户试图访问一个并不存在的页面时,此时服务器会返回代码为404的错误信息,此时对应页面就是404页面.404页面的默认内容和具体的服务器有关.如果后台用的是 ...

  8. 《并行程序设计导论》——OpenMP

    OpenMP看着很好,实际上坑很多. 如果真的要求性能和利用率,还是专门写代码吧.而且MS的VS里只有2.X的版本.

  9. 引导图滤波(Guided Image Filtering)原理以及OpenCV实现

    引导图是一种自适应权重滤波器,能够在平滑图像的同时起到保持边界的作用,具体公式推导请查阅原文献<Guided Image Filtering>.这里只说一下自适应权重原理.C++实现灰度图 ...

  10. PowerDesigner设置null约束

    在PDM的表属性的字段列表中每行最后的P,F,M中的M(Mandatory)打勾就可以了,这样在生成的SQL中会变成not NULL Mandatory:强制的,不知道是不是可以理解为必须赋值的