- 浏览: 17630 次
- 性别:
文章分类
最新评论
(一)使用前准备
使用Java操作Redis需要jedis,本文使用的是jedis-2.1.0.jar
(二)代码实例
在不同的线程中使用相同的Jedis实例会发生奇怪的错误。但是创建太多的实现也不好因为这意味着会建立很多sokcet连接, 也会导致奇怪的错误发生。单一Jedis实例不是线程安全的。为了避免这些问题,可以使用JedisPool, JedisPool是一个线程安全的网络连接池。可以用JedisPool创建一些可靠Jedis实例,可以从池中拿到Jedis的实例。 这种方式可以解决那些问题并且会实现高效的性能
jeditPool工具类
package com.testredis; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; import redis.clients.jedis.JedisPoolConfig; /** * 在不同的线程中使用相同的Jedis实例会发生奇怪的错误。但是创建太多的实现也不好因为这意味着会建立很多sokcet连接, * 也会导致奇怪的错误发生。单一Jedis实例不是线程安全的。为了避免这些问题,可以使用JedisPool, * JedisPool是一个线程安全的网络连接池。可以用JedisPool创建一些可靠Jedis实例,可以从池中拿到Jedis的实例。 * 这种方式可以解决那些问题并且会实现高效的性能 */ public final class RedisUtil { //Redis服务器IP private static String ADDR = "127.0.0.1"; //Redis的端口号 private static int PORT = 6379; //访问密码 private static String AUTH = "test1104"; //可用连接实例的最大数目,默认值为8; //如果赋值为-1,则表示不限制;如果pool已经分配了maxActive个jedis实例,则此时pool的状态为exhausted(耗尽)。 private static int MAX_ACTIVE = 1024; //控制一个pool最多有多少个状态为idle(空闲的)的jedis实例,默认值也是8。 private static int MAX_IDLE = 200; //等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。如果超过等待时间,则直接抛出JedisConnectionException; private static int MAX_WAIT = 10000; private static int TIMEOUT = 10000; //在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的; private static boolean TEST_ON_BORROW = true; private static JedisPool jedisPool = null; /** * 初始化Redis连接池 */ static { try { JedisPoolConfig config = new JedisPoolConfig(); config.setMaxActive(MAX_ACTIVE); config.setMaxIdle(MAX_IDLE); config.setMaxWait(MAX_WAIT); config.setTestOnBorrow(TEST_ON_BORROW); jedisPool = new JedisPool(config, ADDR, PORT, TIMEOUT, AUTH); } catch (Exception e) { e.printStackTrace(); } } /** * 获取Jedis实例 * @return */ public synchronized static Jedis getJedis() { try { if (jedisPool != null) { Jedis resource = jedisPool.getResource(); return resource; } else { return null; } } catch (Exception e) { e.printStackTrace(); return null; } } /** * 释放jedis资源 * @param jedis */ public static void returnResource(final Jedis jedis) { if (jedis != null) { jedisPool.returnResource(jedis); } } }
Redis 操作例子
package com.testredis; import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.Map; import java.util.Set; import redis.clients.jedis.Jedis; public class TestRedis { private Jedis jedis; public void init() { jedis= RedisUtil.getJedis(); } /** * redis存储字符串 */ public void testString() { jedis.del("name"); //-----添加数据---------- jedis.set("name","xinxin");//向key-->name中放入了value-->xinxin System.out.println(jedis.get("name"));//执行结果:xinxin jedis.append("name", " is my lover"); //拼接 System.out.println(jedis.get("name")); jedis.del("name"); //删除某个键 System.out.println(jedis.get("name")); //设置多个键值对 jedis.mset("name","liuling","age","23","qq","476777XXX"); jedis.incr("age"); //进行加1操作 System.out.println(jedis.get("name") + "-" + jedis.get("age") + "-" + jedis.get("qq")); } /** * redis操作Map */ public void testMap() { jedis.del("userMap"); //-----添加数据---------- Map<String, String> map = new HashMap<String, String>(); map.put("name", "xinxin"); map.put("age", "22"); map.put("qq", "123456"); jedis.hmset("userMap",map); //取出userMap中的name,age,qq 执行结果:[xinxin, 22, 123456]-->注意结果是一个泛型的List //第一个参数是存入redis中map对象的key,后面跟的是放入map中的对象的key,后面的key可以跟多个,是可变参数 List<String> rsmap = jedis.hmget("userMap", "name", "age", "qq"); System.out.println("取出userMap中的name,age,qq :"+rsmap); //删除map中的某个键值 jedis.hdel("userMap","age"); System.out.println("删除了,所以返回的是null:"+jedis.hmget("userMap", "age")); //因为删除了,所以返回的是null System.out.println(jedis.hlen("userMap")); //返回key为user的键中存放的值的个数2 System.out.println(jedis.exists("userMap"));//是否存在key为userMap的记录 返回true System.out.println(jedis.hkeys("userMap"));//返回map对象中的所有key System.out.println(jedis.hvals("userMap"));//返回map对象中的所有value Iterator<String> iter=jedis.hkeys("userMap").iterator(); while (iter.hasNext()){ String key = iter.next(); System.out.println(key+":"+jedis.hmget("userMap",key)); } } /** * jedis操作List */ public void testList(){ //开始前,先移除所有的内容 jedis.del("java framework"); System.out.println(jedis.lrange("java framework",0,-1)); //先向key java framework中存放三条数据 jedis.lpush("java framework","spring"); jedis.lpush("java framework","struts"); jedis.lpush("java framework","hibernate"); jedis.lpush("java framework","ibatis"); //再取出所有数据jedis.lrange是按范围取出, // 第一个是key,第二个是起始位置,第三个是结束位置,jedis.llen获取长度 -1表示取得所有 System.out.println(jedis.lrange("java framework",0,-1)); //出栈,从最后加入的数据开始,先进后出的原则。 jedis.lpop("java framework"); System.out.println(jedis.lrange("java framework",0,-1)); //删除区间以外的数据,index=0表示排在最前面那条数据 jedis.ltrim("java framework", 0, 1); System.out.println(jedis.lrange("java framework",0,-1)); //获取指定下标的值 System.out.println(jedis.lindex("java framework",0)); //设置指定下标的值 jedis.lset("java framework", 0, "hibernate2.5"); System.out.println(jedis.lrange("java framework",0,-1)); } /** * jedis操作Set */ public void testSet(){ jedis.del("user1"); //添加 jedis.sadd("user1","liuling"); jedis.sadd("user1","xinxin"); jedis.sadd("user1","ling"); jedis.sadd("user1","zhangxinxin"); jedis.sadd("user1","who"); //移除who jedis.srem("user1","who"); System.out.println(jedis.smembers("user1"));//获取所有加入的value System.out.println(jedis.sismember("user1", "who"));//判断 who 是否是user1集合的元素 System.out.println(jedis.srandmember("user1")); //随机获得集合中的元素 System.out.println(jedis.scard("user1"));//返回集合的元素个数 jedis.del("user2"); //添加 user2 jedis.sadd("user2","liuling"); jedis.sadd("user2","zhangxinxin"); jedis.sadd("user2","liudehua"); jedis.sadd("user2","jiangxin"); System.out.println("查看user1集合中的所有元素:"+jedis.smembers("user1")); System.out.println("查看user2集合中的所有元素:"+jedis.smembers("user2")); //集合运算 System.out.println("user1和user2交集:"+jedis.sinter("user1", "user2"));//user1与user2中共有的元素 System.out.println("user1和user2并集:"+jedis.sunion("user1", "user2"));// 合并两个集合,合并后集合元素不重复 System.out.println("user1和user2差集:"+jedis.sdiff("user1", "user2"));//差集:user1中有,user2中没有的元素 } /**** * ZSet是个有序的集合 */ public void testZSet() { jedis.del("user3"); jedis.zadd("user3", 30, "黄晓明是个演员"); jedis.zadd("user3", 55, "冯小刚是个导演"); jedis.zadd("user3", 33, "张杰是个歌手"); jedis.zadd("user3", 31, "李小明是个快递"); jedis.zadd("user3", 32, "姚滨是个程序员"); System.out.println("所有元素:"+jedis.zrange("user3", 0, -1)); System.out.println("key=user3的集合中score列值在30-32中间的元素量:"+jedis.zcount("user3", 30, 32));//统计score列的值在最小与最大之间的元素数量 System.out.println("key=user3的集合中score列值在30-32中间的元素:"+jedis.zrangeByScore("user3", 30, 32)); System.out.println(jedis.zscore("user3", "张杰是个歌手")); } public void test() throws InterruptedException { //jedis 排序 //注意,此处的rpush和lpush是List的操作。是一个双向链表(但从表现来看的) jedis.del("a");//先清除数据,再加入数据进行测试 jedis.rpush("a", "1"); jedis.lpush("a","6"); jedis.lpush("a","3"); jedis.lpush("a","9"); System.out.println(jedis.lrange("a",0,-1));// [9, 3, 6, 1] System.out.println(jedis.sort("a")); //[1, 3, 6, 9] //输入排序后结果 System.out.println(jedis.lrange("a",0,-1)); } public void returnResource() { RedisUtil.returnResource(jedis); } public static void main(String[] args) { TestRedis test=new TestRedis(); //初始化Redis test.init(); try { test.testString(); test.testList(); test.test(); test.testMap(); test.testSet(); test.testZSet(); //释放资源 test.returnResource(); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
上一章我们介绍过一个Redis界面管理工具Redis Desktop Manage,启动它这时可以看到一些键值列表我们可以很方便的增加、删除、修改它
相关推荐
在Java操作方面,可以利用jedis库来进行各种数据类型的操作,同时也可以与SpringBoot框架进行整合。 Redis还支持主从复制和哨兵机制(Sentinel),前者可以实现数据的同步备份,后者则用于管理多个Redis服务器,...
本文是一篇关于Redis全套学习笔记的文章,主要介绍了Redis的基础知识、数据结构、持久化、集群、高可用、性能优化等方面的内容。通过本文的学习,读者可以全面掌握Redis的使用和应用,提高自己的技术水平和实践能力...
java整个redis学习笔记整理,个人整理的学习日记,有一定的参考性
《狂神说Redis笔记》是针对Redis这一高性能的键值数据库进行深入讲解的资料,它涵盖了Redis的基础概念、核心功能以及在实际应用中的各种策略。Redis作为一款内存数据存储系统,广泛应用于缓存、消息队列、分布式锁等...
通过这份Java Redis学习笔记,开发者可以深入了解如何在Springboot项目中高效地利用Redis进行数据存储和处理,提升系统的响应速度和稳定性。同时,配合Markdown格式,便于阅读和整理笔记,而PDF格式则方便离线查阅和...
Redis全套学习笔记 完整版pdf.rar set:添加键值对 get:获取值 apend:追价值 strlen:获取值的长度 setnx:key不存在时,设置key的值 incr:原子递增1 decr:原子递减1 incrby/decrby:递增或者递减指定的数字 ...
### Redis学习笔记整理 #### 一、Redis环境搭建 ##### 1.1 简介 Redis是一款开源的键值(Key-Value)型数据库系统,因其高性能和丰富的数据结构而广受欢迎。它不仅可以作为数据库使用,还可以作为一种数据结构服务器...
Redis以其高效的性能、丰富的数据结构和灵活的数据操作特性,在IT行业中备受青睐,尤其是在Java开发领域。 Redis支持多种数据类型,包括字符串(Strings)、哈希(Hashes)、列表(Lists)、集合(Sets)和有序集合(Sorted ...
本学习笔记将深入探讨Redis的核心概念、功能特性以及如何在Java环境中进行操作。 一、Redis概述 Redis全称Remote Dictionary Server,由意大利程序员Antonio Bertolli开发,它是一个开源的、基于键值对的数据存储...
Redis(Remote Dictionary Server ),即远程字典服务,是一个开源的使用ANSI C语言编写、...Redis 可以周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步
Redis学习笔记大全 Redis是当前使用最广泛的NoSQL数据库之一,具有高性能、低延迟和支持事务等特点。本文将对Redis的基本概念、安装、启动、关闭、基本命令、5大数据类型、发布和订阅、Bitmaps和HyperLoglog等进行...
在“狂神redis源码笔记”中,我们可以期待学习到Redis的源码分析、内部机制以及如何通过Java进行高效操作。源码分析是深入理解Redis工作原理的关键,有助于开发者优化使用方式或进行定制化开发。 Redis的核心知识点...
Jedis是较早的Redis客户端,拥有全面的Redis命令支持,但它是同步的,不支持异步操作,且单线程环境下使用。而Lettuce则是一个线程安全的客户端,提供同步、异步和反应式API,利用Netty NIO框架有效地管理多个连接,...
"总结.txt"可能是一个学习笔记或关键点的提炼,对Redis的特性和Java客户端的使用做了简洁总结。"参考资料redis"可能是一些外部链接或文档,提供了更全面的Redis学习资料。最后,"代码"目录下应包含实际的Java代码...
01 Redis快速入门 - Redis教程 02-Redis环境安装 - Redis教程 03-Redis 的安装配置介绍 04-Redis数据类型 - Redis教程 ...24-Redis Java连接操作 - Redis教程 。。。 27-redis-cluster研究和使用 。。。
在《狂神说Redis笔记》中,我们可以了解到Redis的各个方面,包括其入门基础、高级特性、配置详解、持久化机制、事务操作、订阅发布机制、主从复制、安装指南、哨兵模式以及与Java的集成等。同时,笔记还探讨了为什么...
### Redis详细笔记 #### 1. Redis介绍 Redis是一种高性能的键值对存储数据库,它使用C语言编写,能够提供非常高的读写速度。作为NoSQL数据库的一种,Redis旨在解决传统关系型数据库面临的高并发、高可扩展性、高...
《Redis 深度历险》学习笔记与实践(Java) 基础和应用 1-2.Redis应用 — Redis基本数据结构 1-3.Redis应用 — 分布式锁 1-4.Redis应用 — 延时队列 1-5.Redis应用 — 位图 1-6.Redis应用 — HyperLogLog 1-7.Redis...