1.Redis

这就不必哆嗦了,Redis 支持丰富的数据类型,String ,List,Sets ,Sorted Sets,Hashes,这就可以看出Java 操作Redis就要针对各种类型都有自己的操作。这里自己学习的是Spring-data-redis 中基于Jedis connection的不过在RedisTemplate 中 可不管这些,全部都是 connect 的操作,所以 我想说,记得引Jedis的Jar包,而且还要是2.0以上的哦

2.安装Redis

这也不罗嗦了,这里简单说下Redis cli 中的简单操作

(1) String

SET NAME ZHANG

GET NAME

INCR ,APPEND GETRANGE,MSET,STRLENGTH.

(2) LIST

LPUSH name zhang

LPUSH name hao ni zhen shi yi ge SB

LLEN name

LREM name xx

(3)SETS

SADD name zhang

SADD name zhang

SADD name hao

SMEMBERS name

(4) Sorted Sets

ZADD name 1 zhang

ZADD name 2 hao

ZRANGE

(5)HASHes

HSET name:1 name zhang

HSET name:1 last     hao

HGET name:1 name

HGETALL name:1

3.简单的用Spring-data-redis

当然 关联的Jar 包用Maven 来搞,(前段时间Maven不好使,生不如死呀,各种看错误来加Jar包),然后就是在Spring  applicationContext,xml中配置了

首先:Jedis 的连接池:redis.clients.jedis.JedisPoolConfig 见仁见智

  1. <!-- 配置Jedis的 缓冲池 -->
  2. <bean id="JedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig"
  3. p:maxActive="32"
  4. p:maxIdle="6"
  5. p:maxWait="15000"
  6. p:minEvictableIdleTimeMillis="300000"
  7. p:numTestsPerEvictionRun="3"
  8. p:timeBetweenEvictionRunsMillis="60000"
  9. p:whenExhaustedAction="1">
  10. </bean>

第二,创建ConnectionFactory

  1. <!-- 配置Jedis connection -->
  2. <bean id="connectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"
  3. p:poolConfig-ref="JedisPoolConfig"
  4. p:hostName="192.168.137.100"
  5. p:port="6379"
  6. p:usePool="true"
  7. >
  8. </bean>

第三:创建RedisTemplate

  1. <!-- 配置 redisTemplate 利用Stringserializer -->
  2. <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate"
  3. p:connectionFactory-ref="connectionFactory"
  4. >
  5. <property name="defaultSerializer">
  6. <bean class="org.springframework.data.redis.serializer.StringRedisSerializer"/>
  7. </property>
  8. </bean>

由于redis中存储的数据必须是经过序列化的,所以Spring-data-redis中采取了几种序列化模式,有自带的JDKblablabla,还有StringRedisSerializer,

但是Json 和XML也都是基于String类型的所以就在默认文件中使用String类型的序列化,而默认是JdkSerializationRedisSerializer.

  1. public class RedisTemplate<K, V> extends RedisAccessor implements RedisOperations<K, V> {
  2. private boolean exposeConnection = false;
  3. private boolean initialized = false;
  4. private boolean enableDefaultSerializer = true;
  5. private RedisSerializer<?> defaultSerializer = new JdkSerializationRedisSerializer();

先不管那么多了,来做点简单的实验。

1.String

  1. RedisTemplate rt = (RedisTemplate) context.getBean("redisTemplate");
  2. rt.opsForValue().set("zhang", "hao");
  3. System.out.println(rt.opsForValue().get("zhang"));

2.List

说到List  Redis 提供了类似于消息队列的操作,先看下接口,从名字上就可以看到这些操作的意义,我就简单实例一下。

  1. public interface ListOperations<K, V> {
  2. List<V> range(K key, long start, long end);
  3. void trim(K key, long start, long end);
  4. Long size(K key);
  5. Long leftPush(K key, V value);
  6. Long leftPushAll(K key, V... values);
  7. Long leftPushIfPresent(K key, V value);
  8. Long leftPush(K key, V pivot, V value);
  9. Long rightPush(K key, V value);
  10. Long rightPushAll(K key, V... values);
  11. Long rightPushIfPresent(K key, V value);
  12. Long rightPush(K key, V pivot, V value);
  13. void set(K key, long index, V value);
  14. Long remove(K key, long i, Object value);
  15. V index(K key, long index);
  16. V leftPop(K key);
  17. V leftPop(K key, long timeout, TimeUnit unit);
  18. V rightPop(K key);
  19. V rightPop(K key, long timeout, TimeUnit unit);
  20. V rightPopAndLeftPush(K sourceKey, K destinationKey);
  21. V rightPopAndLeftPush(K sourceKey, K destinationKey, long timeout, TimeUnit unit);
  22. RedisOperations<K, V> getOperations();

PS.我上面贴的源码是 github上面的最新源码。我自己用的还是1.01  泪千行,我说找了半天rightpushAll 竟然找不到。所以 记得用最新的版本。

  1. String KEYS="LIST:";
  2. rt.opsForList().rightPush(KEYS, "zhang");
  3. rt.opsForList().leftPush(KEYS, "HAO");
  4. // sort : HAO zhang
  5. for(int i=0;i<=rt.opsForList().size(KEYS);i++){
  6. System.out.println(rt.opsForList().rightPop(KEYS));
  7. }

3 Hashes (SETS 自己看看吧。。)

  1. String KEYS="HASH:";
  2. rt.opsForHash().put(KEYS, "name", "zhang");
  3. rt.opsForHash().put(KEYS, "last", "hao");
  4. rt.opsForHash().put(KEYS, "wo", "ni");
  5. rt.opsForHash().put(KEYS, "name", "sb");
  6. System.out.println(rt.opsForHash().get(KEYS, "name"));

可以看到key name 被覆盖了,其中有个BooleanputIfAbsent(Hkey,HKhashKey,HVvalue) 方法,这个具体细节就自己看看吧。下面把Hashoperations 里面的方法贴下:

  1. public interface HashOperations<H, HK, HV> {
  2. void delete(H key, Object... hashKeys);
  3. Boolean hasKey(H key, Object hashKey);
  4. HV get(H key, Object hashKey);
  5. List<HV> multiGet(H key, Collection<HK> hashKeys);
  6. Long increment(H key, HK hashKey, long delta);
  7. Double increment(H key, HK hashKey, double delta);
  8. Set<HK> keys(H key);
  9. Long size(H key);
  10. void putAll(H key, Map<? extends HK, ? extends HV> m);
  11. void put(H key, HK hashKey, HV value);
  12. Boolean putIfAbsent(H key, HK hashKey, HV value);
  13. List<HV> values(H key);
  14. Map<HK, HV> entries(H key);
  15. RedisOperations<H, ?> getOperations();
  16. }

今天就先到这里,Redis 还有很多东西,比如cache transcation 等等 看下目录结构

还有比较多东西,明天继续 再接再厉!

最新文章

  1. .NET跨平台:在CentOS上编译dnx并运行ASP.NET 5示例程序
  2. 面向对象(五)super
  3. jquey知识点整理
  4. 1104关于优化mysql服务器几个参数和思路
  5. Express开发实例(2) —— Jade模板引擎
  6. ahjesus约束方法或属性的调用方
  7. High Performance Django
  8. Cadence仿真利器,Cadence SI / PI Analysis – Sigrity安装及破解指南
  9. ElasticSearch 概念解析
  10. 【HDOJ】1716 排列2
  11. mySQL优化 my.ini 配置说明
  12. 你好,C++(23) 4.4.2 工资程序成长记:用数组处理批量数据,用循环结构执行重复动作
  13. Android 图片加载框架Glide4.0源码完全解析(一)
  14. 跟着弦哥学人工智能2—HAND-CRAFTED RULES实现的人工智能及其缺陷
  15. nyoj水池数目
  16. JS文件中获取contextPath的方法
  17. 禁用 Chrome 的黑色模式/Dark Mode
  18. 【问题】VS问题集合,不用也要收藏防止以后使用找不到
  19. 20175311 2018-2019-2 《Java程序设计》第7周学习总结
  20. Unity做AR

热门文章

  1. oracle查看执行计划以及使用场景
  2. 剑指offer-数组中只出现一次的数字-数组-python
  3. 第四篇 jQuery中的事件与应用
  4. jQuery操作选中select下拉框的值
  5. CSDN添加文章目录
  6. HTML5的新变化
  7. DES加密解密 MD5加密解密
  8. 问题:com.alibaba.dubbo.rpc.RpcException: Failed to invoke ......
  9. Windows常用快捷键与常用命令
  10. Cocos Creator 热更新文件MD5计算和需要注意的问题