redis 与 spring整合 hash 增删改操作 list增删改操作
本人,对于以前redis的学习是非常痛苦的!近期将以前的东西捡起来。以博客的形式存储,以便于以后快速捡起来,并和广大同胞一起分享!
1):简单介绍
redis 是基于C语言开发。
redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。
redis 是一个 缓存数据库(片面的理解) 既可以做缓存,也可以将数据持久化到磁盘中!
本人有通过redis的hash数据类型来做过购物车
spring配置文件 spring-redis.xml
<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
<property name="maxIdle" value="6"></property>
<property name="minEvictableIdleTimeMillis" value="300000"></property>
<property name="numTestsPerEvictionRun" value="3"></property>
<property name="timeBetweenEvictionRunsMillis" value="60000"></property>
</bean>
<bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory" destroy-method="destroy">
<property name="poolConfig" ref="jedisPoolConfig"></property>
<property name="hostName" value="***.***.**.**"></property> 《更改ip》
<property name="port" value="6379"></property> 《更改 端口号》
<property name="timeout" value="15000"></property>
<property name="usePool" value="true"></property>
</bean>
<bean id="jedisTemplate" class="org.springframework.data.redis.core.RedisTemplate">
<property name="connectionFactory" ref="jedisConnectionFactory"></property>
<property name="keySerializer">
<bean class="org.springframework.data.redis.serializer.StringRedisSerializer"/>
</property>
<property name="valueSerializer">
<bean class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer"/>
</property>
</bean>
hash数据结构图
简单介绍一下:
注入redis数据源:

hash的操作方法
(1):获得hash数据类型的模板
//获得redis缓存HASH数据类型(散列)
HashOperations opsForHash = redisTemplate.opsForHash();
(2):通过 会员id 和 商品 id 得到商品信息
//判断该用户(的商品)在缓存中有没有该数据 hkey需为string类型
Order cacheOrder = (Order) opsForHash.get(order.getMemberId() + "", order.getGoodsId());
(3):存入信息 ,
//根据会员ID 以及 商品 ID 将数据存入缓存中 【opsForHash.put(key, hashKey, value);】value为object类型
opsForHash.put(order.getMemberId() + "", order.getGoodsId(), goodsOrder);
(4):修改商品库存(修改的原则是先对 value 数值进行修改 在将修改后的数值存入缓存中 会覆盖原来的缓存信息 )
//判断该用户(的商品)在缓存中有没有该数据 【先修改数值】
Order cacheOrder = (Order) opsForHash.get(order.getMemberId() + "", order.getGoodsId());
//更新修改后的缓存数据
opsForHash.put(order.getMemberId() + "", order.getGoodsId(), cacheOrder);
(5):删除缓存数据 【不过一般不会直接删除,只会做逻辑删除】
opsForHash.delete(key, hashKeys);
简单演示一下list的几种方法:
(1):获得list数类型
//获得redis缓存list数据类型
ListOperations opsForList = redisTemplate.opsForList();
(2):根据键名获得长度
Long size = opsForList.size(order.getMemberId() + "");
(3):添加信息
//将购物信息添加到缓存中 rightPush 依次有右边添加 leftPush依次由左边添加
opsForList.rightPush(order.getMemberId() +"" ,cacheOrder);
(4):获得list集合 【 0 ,-1 代表所有值】
//获得所有当前可以的所有信息
List<Order> range = opsForList.range(order.getMemberId() +"”, 0, -1);
llist数据类型适合于消息队列的场景:比如12306并发量太高,而同一时间段内只能处理指定数量的订单!必须满足先进先出的原则,其余订单处于等待
redis事务 :原子性,即 要不全部成功 要不全部失败
redis持久化 :rdb aof
RDB方式:
RDB持久化默认生成的文件名为dump.rdb
Redis.conf中可以配置,默认配置如下:【默认是开启RDB方式的】
save 900 1
save 300 10
save 60 10000
以上表示的意思是,【 满足任一条件 , 都会进行持久化 】
900秒之内对服务进行了至少一次修改
300秒之内服务器进行了至少10次修改
60秒之内对服务器进行了至少10000次修改。
AOF方式:
appendonly yes #启用aof持久化方式
# appendfsync always #每次收到写命令就立即强制写入磁盘,最慢的,但是保证完全的持久化,不推荐使用
appendfsync everysec #每秒钟强制写入磁盘一次,在性能和持久化方面做了很好的折中,推荐
# appendfsync no #完全依赖os,性能最好,持久化没保证
本人在写博客的时候也借鉴了一些博友的资源!
redis 与 spring整合 hash 增删改操作 list增删改操作的更多相关文章
- Redis和Spring整合
Redis和Spring整合 Redis在这篇里就不做介绍了~以后系统的学学,然后整理写出来. 首先是环境的搭建 通过自己引包的方式,将redis和spring-redis的包引到自己的项目中,我项目 ...
- redis与spring整合实例
1)首先是redis的配置. 使用的是maven工程,引入redis与spring整合的相关jar包 <!-- redis服务 start--> <dependency> &l ...
- 分布式缓存技术redis学习系列(五)——redis实战(redis与spring整合,分布式锁实现)
本文是redis学习系列的第五篇,点击下面链接可回看系列文章 <redis简介以及linux上的安装> <详细讲解redis数据结构(内存模型)以及常用命令> <redi ...
- 分布式缓存技术redis系列(五)——redis实战(redis与spring整合,分布式锁实现)
本文是redis学习系列的第五篇,点击下面链接可回看系列文章 <redis简介以及linux上的安装> <详细讲解redis数据结构(内存模型)以及常用命令> <redi ...
- redis系列之5----redis实战(redis与spring整合,分布式锁实现)
本文是redis学习系列的第五篇,点击下面链接可回看系列文章 <redis简介以及linux上的安装> <详细讲解redis数据结构(内存模型)以及常用命令> <redi ...
- Redis跟Spring整合,sentinel模式
普通模式整合 一.在pom.xml中引入redis的依赖 <dependency> <groupId>org.springframework.data</groupId& ...
- redis和spring整合使用
第一步,在项目中加入redis的pom代码: <dependency> <groupId>redis.clients</groupId> <artifactI ...
- Redis + Jedis + Spring整合遇到的异常(转)
项目中需要用到缓存,经过比较后,选择了redis,客户端使用jedis连接,也使用到了spring提供的spring-data-redis.配置正确后启动tomcat,发现如下异常: Caused b ...
- redis与spring整合·
单机版: 配置spring配置文件applicationContext.xml <?xml version="1.0" encoding="UTF-8"? ...
随机推荐
- 控制HTML Input只能输入数字和小数点
本文介绍两种控制在<input type="text" name="name" value="0" />中只允许输入数字和小数点 ...
- day24:面向对象设计与面向对象编程、类和对象
一.三大编程范式: 面向过程: 面向函数: 面向对象: 二.程序的进化论: 1.编程最开始就是无组织无结构,从简单控制流中按步写指令 2.从上述的指令中提取重复的代码块或逻辑,组织到一起(比方说,你定 ...
- Android广播机制的深入学习
部分内容转载自http://www.cnblogs.com/lwbqqyumidi/p/4168017.html 1.Android广播机制概述 Android广播分为两个方面:广播发送者和广播接收者 ...
- rsync命令详解
介绍 rsync命令是一个远程数据同步工具,可通过LAN/WAN快速同步多台主机间的文件.rsync使用所谓的“rsync算法”来使本地和远程两个主机之间的文件达到同步,这个算法只传送两个文件的不同部 ...
- Eclipse IDE for Java EE Developers 与 Eclipse Classic(Eclipse Standard)区别
Eclipse下载官网:http://www.eclipse.org/downloads/ 版本: 1.Eclipse classic(Eclipse Standard):Eclipse的标准版; 2 ...
- 解决Android studio首次启动gradle无法下载jar包
换了个电脑,原来的配置都烂了,重新使用studio,发现界面就停留在gradle下载界面不动.原因估计你会懂得.. 网上流传的配置 Gradle Vm options 或是 配置build.gradl ...
- The project: project which is referenced by the classpath, does not exist.
有个java工程运行时报The project: project which is referenced by the classpath, does not exist.错误 上网查解决方案,说是将 ...
- eclipse NoClassDefFoundError错误
问题描述:eclipse中执行一个java web项目,代码中依赖都是正常的,发布到tomcat中调试就提示NoClassDefFoundError错误, 问题分析:首先确定工程中该类确实存在,因为代 ...
- oleDB 导入excel遇到的问题
本地测试一切ok. 到服务器上测试各种报错,先装了office2010,又装了AccessDatabaseEngine,之后报"Microsoft Excel 不能访问文件 可能的原因有: ...
- linux pxe+dhcp+nfs+tftp
yum -y install vsftpd dhcp xinetd tftp-server syslinux(安装"syslinux"才有pxelinux.0) tftp 服务(v ...