Java操作redis
Java操作redis很简单。创建一个普通的Java工程。然后导入redis依赖的jar包。jar包我已经上传了。
1.入门级的demo
package com.bjsxt.test; import redis.clients.jedis.Jedis; public class RedisDemo { public static Jedis getJedis(){ Jedis jedis = null; jedis = new Jedis(FinalCollention.IP, 6379); //redis服务器的ip和端口 jedis.auth(FinalCollention.PASSWORD); //连接redis的密码 return jedis; } public void test(){ Jedis jedis = null; try{ jedis = getJedis(); jedis.incr("test"); long dbsize = jedis.dbSize(); System.out.println("数据库大小:"+dbsize); System.out.println("测试test的值:"+jedis.get("test")); }catch(Exception e){ e.printStackTrace(); }finally{ if(jedis != null){ jedis.disconnect(); } } } public static void main(String[] args) { RedisDemo demo = new RedisDemo(); demo.test(); } }
如果出现Java无法连接redis的异常,主要有三个方面的问题:
1.Java运行的主机ping一下redis服务器所在主机,看能否ping通
2.关闭redis服务器所在主机的防火墙
3.打开redis安装目录下的redis.conf文件。注释掉:bind 127.0.0.1这句话
# Accept connections on the specified port, default is 6379. # If port 0 is specified Redis will not listen on a TCP socket. port 6379 # If you want you can bind a single interface, if the bind option is not # specified all the interfaces will listen for incoming connections. # # bind 127.0.0.1 "redis.conf" 597L, 25667C written
特别说明:后面的实例,我就不使用try--catch了,但是自己写时一定要记着关闭连接
2.Java操作redis的各种数据结构
package com.bjsxt.test; import java.util.HashMap; import java.util.List; import java.util.Map; import redis.clients.jedis.Jedis; public class RedisDataTypeDemo { public static Jedis getJedis(){ Jedis jedis = null; jedis = new Jedis(FinalCollention.IP, 6379); //redis服务器的ip和端口 jedis.auth(FinalCollention.PASSWORD); //连接redis的密码 return jedis; } /** * * @title demoKey * @description 测试Key * @author hadoop */ public void demoKey(){ Jedis jedis = RedisDataTypeDemo.getJedis(); System.out.println("查看键为aa的是否存在:"+jedis.exists("aa")); System.out.println("查看键为aa的类型:"+jedis.type("aa")); System.out.println("随机获得一个key:"+jedis.randomKey()); System.out.println("将aa重命名为bb:"+jedis.rename("aa", "bb")); System.out.println("删除bb:"+jedis.del("bb")); //从上面的方法可以看出,redis提供的接口方法名和redis-cli客户端提供的方法名是一样的,所以,只要对redis客户端的命令熟悉,那么Java操作redis就不是问题 } /** * * @title demoString * @description 测试String * @author hadoop */ public void demoString(){ Jedis jedis = RedisDataTypeDemo.getJedis(); System.out.println("设置name:"+jedis.set("name", "小花")); System.out.println("设置name1:"+jedis.set("name1", "小花1")); System.out.println("设置那么2:"+jedis.set("name2", "小花2")); System.out.println("设置name,如果存在返回0:"+jedis.setnx("name", "小花哈哈")); System.out.println("获取key为name和name1的value值:"+jedis.mget("name","name1")); System.out.println("自增1:"+jedis.incr("index")); System.out.println("自增1:"+jedis.incr("index")); System.out.println("自增2:"+jedis.incrBy("count", 2)); System.out.println("自增2:"+jedis.incrBy("count", 2)); System.out.println("递减1:"+jedis.decr("count")); System.out.println("递减2:"+jedis.decrBy("index",2)); System.out.println("在name后面添加String:"+jedis.append("name", ",我爱你")); System.out.println("获取key为name的值:"+jedis.get("name")); } /** * * @title demoList * @description 测试list数据类型 * @author hadoop */ public void demoList(){ Jedis jedis = RedisDataTypeDemo.getJedis(); //在头添加 jedis.lpush("list", "hadoop","hbase","hive","pig","zookeeper"); //在末尾添加 jedis.rpush("list", "java","struts"); //返回长度 jedis.llen("list"); //取值 List<String> list = jedis.lrange("list", 0, -1); for (String string : list) { System.out.println(string); } } /** * * @title demoSet * @description 测试set数据类型 * @author hadoop */ public void demoSet(){ Jedis jedis = RedisDataTypeDemo.getJedis(); jedis.sadd("city", "北京","上海","重启","武汉"); System.out.println("取出最上面的:"+jedis.spop("city")); System.out.println("随机取出一个值"+jedis.srandmember("city")); jedis.sadd("city2", "北京","武汉","河北","张家界","辽林"); System.out.println("交集:"+jedis.sinter("city","city1")); System.out.println("并集:"+jedis.sunion("city","city1")); System.out.println("差集:"+jedis.sdiff("city","city1")); } /** * * @title demoMap * @description 测试map数据类型 * @author hadoop */ public void demoMap(){ Jedis jedis = RedisDataTypeDemo.getJedis(); jedis.hset("Mcity", "c1", "北京"); System.out.println("取值:"+jedis.hget("city", "c1")); Map<String,String> mcity = new HashMap<String, String>(); mcity.put("c1", "桂林"); mcity.put("c2", "天津"); mcity.put("c3", "合肥"); jedis.hmset("Mcity2", mcity); List<String> list = jedis.hmget("Mcity2", "c1","c2","c3"); for (String string : list) { System.out.println(string); } System.out.println(jedis.hlen("Mcity2")); } //测试 public static void main(String[] args) { RedisDataTypeDemo rdr = new RedisDataTypeDemo(); rdr.demoKey(); rdr.demoList(); rdr.demoMap(); rdr.demoSet(); rdr.demoString(); } }
3.Java操作redis的管道
package com.bjsxt.test; import redis.clients.jedis.Jedis; import redis.clients.jedis.Pipeline; public class RedisPipelineDemo { public static Jedis getJedis(){ Jedis jedis = null; jedis = new Jedis(FinalCollention.IP, 6379); //redis服务器的ip和端口 jedis.auth(FinalCollention.PASSWORD); //连接redis的密码 return jedis; } public void hasPipeline(){ Jedis jedis = RedisPipelineDemo.getJedis(); System.out.println("开始:"+System.currentTimeMillis()); Pipeline pl = jedis.pipelined(); for(int i = 0 ; i < 1000 ; i++){ pl.incr("testPL"); } pl.sync(); System.out.println("开始:"+System.currentTimeMillis()); } public void noPipeline(){ Jedis jedis = RedisPipelineDemo.getJedis(); System.out.println("开始:"+System.currentTimeMillis()); for(int i = 0 ; i < 1000 ; i++){ jedis.incr("testPL"); } System.out.println("开始:"+System.currentTimeMillis()); } }
4.redis事务
package com.bjsxt.test; import java.util.List; import redis.clients.jedis.Jedis; import redis.clients.jedis.Transaction; public class RedisTXDemo { public static Jedis getJedis(){ Jedis jedis = null; jedis = new Jedis(FinalCollention.IP, 6379); //redis服务器的ip和端口 jedis.auth(FinalCollention.PASSWORD); //连接redis的密码 return jedis; } /** * * @title txDemo * @description 没有异常的事务 * @author hadoop */ public void txDemo(){ Jedis jedis = getJedis(); //开启事务 Transaction tx = jedis.multi(); tx.set("txcity", "beijin"); tx.sadd("hi", "abc"); tx.get("txcity"); List<Object> objs = tx.exec(); for (Object object : objs) { System.out.println(object.toString()); } } /** * * @title txHasExDemo * @description 含有异常的事务 * @author hadoop */ public void txHasExDemo(){ Jedis jedis = getJedis(); //开启事务 Transaction tx = jedis.multi(); tx.set("txcity1", "beijin"); tx.sadd("hi1", "abc"); int i = 1/0; tx.get("txcity1"); List<Object> objs = tx.exec(); for (Object object : objs) { System.out.println(object.toString()); } } public static void main(String[] args) { RedisTXDemo redisTXDemo = new RedisTXDemo(); redisTXDemo.txDemo(); redisTXDemo.txHasExDemo(); } }
从上面的方法可以看出,redis提供的接口方法名和redis-cli客户端提供的方法名是一样的,所以,只要对redis客户端的命令熟悉,那么Java操作redis就不是问题
相关推荐
Redis,典型的NoSQL数据库服务器,和BerkeleyDB相比,它可以作为服务程序独立运行于自己的服务器主机。在很多时候,人们只是将Redis视为Key/Value数据库服务器,然而事实并非如此,在目前的版本中,Redis除了Key/...
这个`redis.jar`包含了Java客户端驱动,使得Java应用程序能够方便地连接到Redis服务器并执行各种操作。 在给定的`redis相关jar包.rar`中,包含的`redis.jar`文件是用于Java编程的Redis客户端库。这个库提供了丰富的...
3. 数据类型操作:Java Redis案例可能涉及的操作包括设置、获取、删除键值对,以及操作列表、集合、哈希等数据结构。例如,`jedis.lpush(key, value1, value2)`将值推送到列表的头部,`jedis.smembers(setKey)`获取...
spring_redis集成,通过jedis作为redis的客户端。 只提供集成方式,具体api,参照jedis API
这些信息可以通过XML配置文件或Java代码设置。 4. **设置Session ID策略**:Tomcat需要知道如何在Redis中查找和更新Session,这通常涉及到Session ID的生成和管理。确保配置正确的Session ID生成算法和重用策略。 ...
4. **线程安全与并发控制**:考虑到多线程或多进程环境,Easy_redis_mq可能实现了线程安全机制,确保多个消费者或生产者可以并行操作而不会引发数据冲突。 5. **错误处理与重试策略**:为了提高系统的健壮性,Easy_...
4. **安装和配置Jedis库**:Tomcat需要与Redis通信,因此需要引入Jedis这个Java客户端库。将Jedis的JAR文件放入Tomcat的`lib`目录下,或者通过Maven或Gradle将其添加为依赖。 5. **测试和调整**:启动Tomcat,访问...
RedisUtils 是一个 Java 实现的 Redis 操作工具类,它为开发者提供了简洁、方便的 API 来与 Redis 数据库存储系统进行交互。Redis 是一款高效、高性能的键值存储服务,广泛应用于缓存、分布式锁、消息队列等多个场景...
redis链接
14_Java高级_redis持久化
redis分布式锁
SpringBoot以其简洁、快速的特性,成为了现代Java开发中的首选框架,而Redis作为高性能的键值对数据存储系统,常被用于缓存、消息中间件等场景。下面我们将详细探讨这两个技术的结合及其应用。 一、SpringBoot与...
本项目"springboot_SpringDataRedis_redis.zip"正是关于如何在Spring Boot应用中集成Redis,并利用Spring Data Redis库进行数据操作的示例。 首先,让我们深入理解Spring Boot与Redis的集成。Spring Boot通过其...
在这个案例中,我们可能找到Redis客户端库(如Jedis或Lettuce)作为项目依赖,以便于在Java代码中连接和操作Redis。 3. "src" - 这通常是源代码目录,意味着我们将在这里找到实现Redis操作的代码。 在这个入门案例...
Fewyit Redis工具类是为了简化Redis操作而设计的Java库,它封装了各种常见的Redis操作,使得在开发过程中能够更加便捷地与Redis进行交互。下面将详细介绍这个工具类的主要功能及其使用方法。 1. **连接管理** - `...
对于`Redis`,则需要了解其命令行接口(CLI)或Java客户端API,如Jedis,以进行数据的存取操作。例如,你可以使用`Jedis`的`set`方法将解析后的JSON对象存入`Redis`的键值对,使用`get`方法读取并返回给Java应用,再...
2. `src/` - 源代码目录,包含Java、Python、C++或其他语言实现的Redis客户端或服务端代码。 3. `redis-7.x/` - Redis 7.x版本的源码或者配置文件。 4. `redis-6.x/` - Redis 6.x版本的源码或者配置文件。 5. `...
为了模拟LRU算法,你可以编写一个简单的Java程序,使用LinkedList和HashMap作为基础数据结构,实现插入、访问和淘汰操作。在实际编程中,可以考虑使用Java的LinkedHashMap,它内置了LRU特性,能简化实现。 总结来说...
在"RedisDemo1_redis_noonsdg_"这个项目中,我们将深入探讨 Redis 的基础数据类型以及如何通过 Java 进行连接配置。以下是关于这些主题的详细讲解: 1. **Redis 基础数据类型**: - **String**:Redis 最基本的...