本人,对于以前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增删改操作的更多相关文章

  1. Redis和Spring整合

    Redis和Spring整合 Redis在这篇里就不做介绍了~以后系统的学学,然后整理写出来. 首先是环境的搭建 通过自己引包的方式,将redis和spring-redis的包引到自己的项目中,我项目 ...

  2. redis与spring整合实例

    1)首先是redis的配置. 使用的是maven工程,引入redis与spring整合的相关jar包 <!-- redis服务 start--> <dependency> &l ...

  3. 分布式缓存技术redis学习系列(五)——redis实战(redis与spring整合,分布式锁实现)

    本文是redis学习系列的第五篇,点击下面链接可回看系列文章 <redis简介以及linux上的安装> <详细讲解redis数据结构(内存模型)以及常用命令> <redi ...

  4. 分布式缓存技术redis系列(五)——redis实战(redis与spring整合,分布式锁实现)

    本文是redis学习系列的第五篇,点击下面链接可回看系列文章 <redis简介以及linux上的安装> <详细讲解redis数据结构(内存模型)以及常用命令> <redi ...

  5. redis系列之5----redis实战(redis与spring整合,分布式锁实现)

    本文是redis学习系列的第五篇,点击下面链接可回看系列文章 <redis简介以及linux上的安装> <详细讲解redis数据结构(内存模型)以及常用命令> <redi ...

  6. Redis跟Spring整合,sentinel模式

    普通模式整合 一.在pom.xml中引入redis的依赖 <dependency> <groupId>org.springframework.data</groupId& ...

  7. redis和spring整合使用

    第一步,在项目中加入redis的pom代码: <dependency> <groupId>redis.clients</groupId> <artifactI ...

  8. Redis + Jedis + Spring整合遇到的异常(转)

    项目中需要用到缓存,经过比较后,选择了redis,客户端使用jedis连接,也使用到了spring提供的spring-data-redis.配置正确后启动tomcat,发现如下异常: Caused b ...

  9. redis与spring整合·

    单机版: 配置spring配置文件applicationContext.xml <?xml version="1.0" encoding="UTF-8"? ...

随机推荐

  1. 应用C#和SQLCLR编写SQL Server用户定义函数

    摘要: 文档阐述使用C#和SQLCLR为SQL Server编写用户定义函数,并演示用户定义函数在T-SQL中的应用.文档中实现的 Base64 编码解码函数和正则表达式函数属于标量值函数,字符串分割 ...

  2. 使用weave管理docker网络

    weave简介 Weave creates a virtual network that connects Docker containers deployed across multiple hos ...

  3. uml和模式01

    // */ // ]]> uml和模式01 1. UML 2. 用例图 3. 用例和类的关系 4. 类图 1 UML 模型语言(Modeling Language 检查ML)是一种设计语言,人们 ...

  4. pjax技术的应用

    一.什么是PJAX? 现在有一些网站(apicloud,  github)支持这样一种浏览方式,当你点击站内的一个连接的时候,不是传统的跳转到另外一个连接,而是类似ajax的局部刷新改变页面内容,但是 ...

  5. 安装lua和openresty

    #### ubuntu 16.04 64bit 安装Lua luajit 及openresty 1 安装lua ,因为luajit 支持lua5.1较好.貌似不支持5.2和5.3作为学习,我就安装5. ...

  6. git usage:常用git命令

    最近在改TV media相关的测试用例,需要在git上维护相关的脚本,把常用命令总结如下,方便以后使用. 1. 从已有git服务器上clone到本地, 首先进入用户根目录: cd ~ 然后进行clon ...

  7. Flasky学习笔记(一)

    1. app.run(debug=True,host='10.0.2.15',port=8000)自定义host及port;

  8. QT总结第3篇:如何在QT中添加.lib,.dll还有.h文件

    因为我在工作的过程中,使用的是第三方提供的库,但是如何将这些库添加到QT的工程中,是个问题,让我恼火了很久,怎么弄都是错的. 下面,我会对这个问题,进行叙述,希望其他人第一次遇到这种问题的时候,可以轻 ...

  9. mac 10.9 安装 gevent

    安装步骤: Gevent依赖libevent和greenlet,需要分别安装. 1,安装 macport (如已安装,可以跳过) 2,通过终端 键入: sudo port install libeve ...

  10. c 语言 运算符 优先级

    C 语言 运算法优先级 从高 到 低 优先级 运算符 功能 适用范围 结合性 15 () [] . -> 括号 下标 存取成员 存取成员 表达式 数组 结构联合 结构联合 → (左→右) 14 ...