redisson整合spring
转:
redisson整合spring
转:
原文:http://blog.csdn.net/wang_keng/article/details/73549274
首先讲下什么是Redisson:Redisson是一个在Redis的基础上实现的Java驻内存数据网格(In-Memory Data Grid)。它不仅提供了一系列的分布式的Java常用对象,还提供了许多分布式服务。(摘自redisson的wiki:wiki地址)
redisson提供的api均以面向对象的操作方式,将key-value封装成我们熟悉的集合或者对象,我们可以通过封装的api更方便的操作数据。同时它提供了多个实现了java.util.corrurnent接口的集合类,让我们能在线程安全的环境下操作数据。
其中redis的官网也将它纳入推荐使用的工具中,可见redisson已经逐渐上位。
废话不多说,现在开始讲下怎么整合redisson到spring:
首先引入redisson的包:(如果你还在用手动加jar包的方式,那建议你赶紧学一下maven,用上后会让你有种便秘一星期后突然通便的清爽)
- <dependency>
- <groupId>org.redisson</groupId>
- <artifactId>redisson</artifactId>
- <version>2.8.2</version>
- </dependency> </span>
接下来新建redisson.xml文件:(可参考wiki:redisson配置教程)
- <?xml version="1.0" encoding="UTF-8"?>
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns:context="http://www.springframework.org/schema/context"
- xmlns:redisson="http://redisson.org/schema/redisson"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans.xsd
- http://www.springframework.org/schema/context
- http://www.springframework.org/schema/context/spring-context.xsd
- http://redisson.org/schema/redisson
- http://redisson.org/schema/redisson/redisson.xsd">
- <!--
- 单台redis机器配置
- <redisson:client id="redissonClient">
- <redisson:single-server address="192.168.2.100:7000" connection-pool-size="30"/>
- </redisson:client>
- -->
- <!-- redis集群配置 -->
- <redisson:client id="redissonClient" >
- <redisson:cluster-servers scan-interval="10000"> <!-- //scan-interval:集群状态扫描间隔时间,单位是毫秒 -->
- <redisson:node-address value="192.168.2.100:7000"></redisson:node-address>
- <redisson:node-address value="192.168.2.100:7001"></redisson:node-address>
- <redisson:node-address value="192.168.2.100:7002"></redisson:node-address>
- <redisson:node-address value="192.168.2.100:7003"></redisson:node-address>
- <redisson:node-address value="192.168.2.100:7004"></redisson:node-address>
- <redisson:node-address value="192.168.2.100:7005"></redisson:node-address>
- </redisson:cluster-servers>
- </redisson:client>
- </beans>
然后在Application.xml中引入redisson.xml:<import resource="classpath:/spring/redisson.xml" /> (路径记得自己改哦~)
至此我们redisson的环境就配置好了。接下来就是怎么操作它来操作redis:
首先新建一个工具类RedissonUtils:
package com.basic.common.utils.redis;
- import java.util.Map;
- import org.redisson.api.RAtomicLong;
- import org.redisson.api.RBucket;
- import org.redisson.api.RCountDownLatch;
- import org.redisson.api.RDeque;
- import org.redisson.api.RList;
- import org.redisson.api.RLock;
- import org.redisson.api.RMap;
- import org.redisson.api.RQueue;
- import org.redisson.api.RSet;
- import org.redisson.api.RSortedSet;
- import org.redisson.api.RTopic;
- import org.redisson.api.RedissonClient;
- import org.springframework.stereotype.Service;
- import com.basic.common.utils.generator.CollectionObjectConvert;
- @Service
- public class RedissonUtils{
- /**
- * 获取字符串对象
- * @param redisson
- * @param t
- * @param objectName
- * @return
- */
- public static <T> RBucket<T> getRBucket(RedissonClient redissonClient,String objectName){
- RBucket<T> bucket=redissonClient.getBucket(objectName);
- return bucket;
- }
- /**
- * 获取Map对象
- * @param redisson
- * @param objectName
- * @return
- */
- public static <K,V> RMap<K, V> getRMap(RedissonClient redissonClient,String objectName){
- RMap<K, V> map=redissonClient.getMap(objectName);
- return map;
- }
- /**
- * 获取有序集合
- * @param redisson
- * @param objectName
- * @return
- */
- public static <V> RSortedSet<V> getRSortedSet(RedissonClient redissonClient,String objectName){
- RSortedSet<V> sortedSet=redissonClient.getSortedSet(objectName);
- return sortedSet;
- }
- /**
- * 获取集合
- * @param redisson
- * @param objectName
- * @return
- */
- public static <V> RSet<V> getRSet(RedissonClient redissonClient,String objectName){
- RSet<V> rSet=redissonClient.getSet(objectName);
- return rSet;
- }
- /**
- * 获取列表
- * @param redisson
- * @param objectName
- * @return
- */
- public static <V> RList<V> getRList(RedissonClient redissonClient,String objectName){
- RList<V> rList=redissonClient.getList(objectName);
- return rList;
- }
- /**
- * 获取队列
- * @param redisson
- * @param objectName
- * @return
- */
- public static <V> RQueue<V> getRQueue(RedissonClient redissonClient,String objectName){
- RQueue<V> rQueue=redissonClient.getQueue(objectName);
- return rQueue;
- }
- /**
- * 获取双端队列
- * @param redisson
- * @param objectName
- * @return
- */
- public static <V> RDeque<V> getRDeque(RedissonClient redissonClient,String objectName){
- RDeque<V> rDeque=redissonClient.getDeque(objectName);
- return rDeque;
- }
- /**
- * 此方法不可用在Redisson 1.2 中
- * 在1.2.2版本中 可用
- * @param redisson
- * @param objectName
- * @return
- */
- /**
- public <V> RBlockingQueue<V> getRBlockingQueue(Redisson redisson,String objectName){
- RBlockingQueue rb=redisson.getBlockingQueue(objectName);
- return rb;
- }*/
- /**
- * 获取锁
- * @param redisson
- * @param objectName
- * @return
- */
- public static RLock getRLock(RedissonClient redissonClient,String objectName){
- RLock rLock=redissonClient.getLock(objectName);
- return rLock;
- }
- /**
- * 获取原子数
- * @param redisson
- * @param objectName
- * @return
- */
- public static RAtomicLong getRAtomicLong(RedissonClient redissonClient,String objectName){
- RAtomicLong rAtomicLong=redissonClient.getAtomicLong(objectName);
- return rAtomicLong;
- }
- /**
- * 获取记数锁
- * @param redisson
- * @param objectName
- * @return
- */
- public static RCountDownLatch getRCountDownLatch(RedissonClient redissonClient,String objectName){
- RCountDownLatch rCountDownLatch=redissonClient.getCountDownLatch(objectName);
- return rCountDownLatch;
- }
- /**
- * 获取消息的Topic
- * @param redisson
- * @param objectName
- * @return
- */
- public static <M> RTopic<M> getRTopic(RedissonClient redissonClient,String objectName){
- RTopic<M> rTopic=redissonClient.getTopic(objectName);
- return rTopic;
- }
- }
然后我们需要在调用RedissonUtils的类中依赖进RedissonClient
@Autowired
private RedissonClient redisson;
只后便可以对redis进行操作啦
RMap<String, Object> map = RedissonUtils.getRMap(redisson,key);
map.put("key","value"); 调用到这个语句的同时就已经对redis中的数据进行了修改。
注意!redis最好是3.0以上的,官方发布的版本,不然会出现莫名其妙的错误
redisson整合spring的更多相关文章
- 【Java EE 学习 81】【CXF框架】【CXF整合Spring】
一.CXF简介 CXF是Apache公司下的项目,CXF=Celtix+Xfire:它支持soap1.1.soap1.2,而且能够和spring进行快速无缝整合. 另外jax-ws是Sun公司发布的一 ...
- Mybatis整合Spring
根据官方的说法,在ibatis3,也就是Mybatis3问世之前,Spring3的开发工作就已经完成了,所以Spring3中还是没有对Mybatis3的支持.因此由Mybatis社区自己开发了一个My ...
- mybatis入门_一对多,多对多映射以及整合spring框架
一.一对多映射. 1.1 一对多映射之根据多的一方关联查询一的一方 示例:查询出具体的订单信息,同时也查询出来订单的用户信息. 引入的订单表如下所示: 框选出来的为具体的外键. 订单的Pojo类如下所 ...
- 《SSM框架搭建》三.整合spring web
感谢学习http://blog.csdn.net/zhshulin/article/details/37956105#,还是修改了spring到最新的版本和接口开发示例 根据前一篇日志,已经有了myb ...
- Maven 整合 spring profile实现多环境自动切换
Maven 整合 spring profile实现多环境自动切换 时间:2014-03-19 15:32来源:Internet 作者:Internet 点击:525次 profile主要用在项目多环境 ...
- TinyFrame续篇:整合Spring IOC实现依赖注入
上一篇主要讲解了如何搭建基于CodeFirst的ORM,并且在章节末我们获取了上下文对象的实例:BookContext.这节主要承接上一篇,来讲解如何整合Spring IOC容器实现控制反转,依赖注入 ...
- Ehcache 整合Spring 使用页面、对象缓存
Ehcache 整合Spring 使用页面.对象缓存 Ehcache在很多项目中都出现过,用法也比较简单.一 般的加些配置就可以了,而且Ehcache可以对页面.对象.数据进行缓存,同时支持集群/分布 ...
- webservice 服务端例子+客户端例子+CXF整合spring服务端测试+生成wsdl文件 +cxf客户端代码自动生成
首先到CXF官网及spring官网下载相关jar架包,这个不多说.webservice是干嘛用的也不多说. 入门例子 模拟新增一个用户,并返回新增结果,成功还是失败. 大概的目录如上,很简单. Res ...
- (转)Ehcache 整合Spring 使用页面、对象缓存
Ehcache在很多项目中都出现过,用法也比较简单.一般的加些配置就可以了,而且Ehcache可以对页面.对象.数据进行缓存,同时支持集群/分布式缓存.如果整合Spring.Hibernate也非常的 ...
随机推荐
- selenium-测试框架搭建(十三)
思路 分离业务代码和测试数据,提高代码可维护性,实现自动化,减少重复劳动. 一个测试框架大概由配置文件,测试数据,测试用例,相关文件(发送邮件等),测试日志,断言和测试报告等模块组成. 结构 以页面为 ...
- redis -hash(哈希.对象)
hash 用于储存对象,对象的结构为属性.值 值的类型string 增加.修改: 设置单个属性: hset 键 field 值 例如: 设置键 user 的属性name 为 python hset u ...
- mssql server for docker on MacOs
1. install 1.下载镜像 docker pull microsoft/mssql-server-linux 使用该命令就可以把数据库的docker镜像下载下来. 2.创建并运行容器 dock ...
- windows10安装mysql-8.0.13(zip安装)
安装环境说明 系统版本:windows10 mysql版本:mysql-8.0.13-winx64.zip 下载地址:http://mirrors.163.com/mysql/Downloads/My ...
- 一个ELK日志检索实施案例
figure:first-child { margin-top: -20px; } #write ol, #write ul { position: relative; } img { max-wid ...
- 英语-TOEFL和GRE复习计划与资料
目录 一. TOEFL (1). 阅读: 60 minutes (2). 听力: 50 minutes (3). 口语: 20 minutes (4). 作文: 60 minutes 单词准备 其他资 ...
- 剑指offer:调整数组顺序使奇数位于偶数前面
题目 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分. 分析 事实上,这个题比较简单,很多种方式都可以实现,但是其时间复杂度或空间复 ...
- 转自阿里云邪-如何从小白成长为 Apache Committer?
http://wuchong.me/blog/2019/02/12/how-to-become-apache-committer/ 过去三年,我一直在为 Apache Flink 开源项目贡献,也在两 ...
- 使用FreeCookies 控制浏览器cookies及修改http响应内容
FreeCookies 插件安装 :您的计算机需要已经安装Fiddler (如未安装,请至官网下载安装 http://docs.telerik.com/fiddler/configure-fiddle ...
- 使用axios 的post请求下载文件,
axios({ method: 'post', data: param, responseType:'blob', url: _urls + '/Downloaddata' }).then(data= ...