redis在java中的使用(实例讲解)
程序员文章站
2024-02-15 09:32:40
1、首先下载jar包放到你的工程中
2、练习
package com.jianyuan.redistest;
import java.util.ite...
1、首先下载jar包放到你的工程中
2、练习
package com.jianyuan.redistest; import java.util.iterator; import java.util.list; import java.util.set; import redis.clients.jedis.jedis; public class redistest { public static void main(string[] args) { //连接本地的redis服务 jedis jedis = new jedis("127.0.0.1",6379); //权限认证 jedis.auth("wenhongyu66"); jedis.select(0); system.out.println("连接成功"); //查看服务是否运行 system.out.println(jedis.ping()); //设置 redis 字符串数据 jedis.set("runoobkey", "www.runoob.com"); // 获取存储的数据并输出 system.out.println("redis 存储的字符串为: "+ jedis.get("runoobkey")); //存储数据到列表中 jedis.lpush("site-list", "runoob"); jedis.lpush("site-list", "google"); jedis.lpush("site-list", "taobao"); system.out.println(jedis.llen("site-list")); // 获取存储的数据并输出 list<string> list = jedis.lrange("site-list", 0 ,jedis.llen("site-list")); for(int i=0; i<list.size(); i++) { system.out.println("列表项为: "+list.get(i)); } // 获取数据并输出 set<string> keys = jedis.keys("*"); iterator<string> it=keys.iterator() ; while(it.hasnext()){ string key = it.next(); system.out.println(key); } } }
总结:自己可以封装一些工具类方便使用,包括连接池的配置,jedis参数的配置等。
private static jedispool jedispool = null; private static jedis jedis; static { jedis = getjedispool().getresource(); } /** * 构建redis连接池 */ public static jedispool getjedispool() { if (jedispool == null) { jedispoolconfig config = new jedispoolconfig(); config.setmaxtotal(1024); // 可用连接实例的最大数目,如果赋值为-1,表示不限制. config.setmaxidle(5); // 控制一个pool最多有多少个状态为idle(空闲的)jedis实例,默认值也是8 config.setmaxwaitmillis(1000 * 100); // 等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时/如果超过等待时间,则直接抛出异常 config.settestonborrow(true); // 在borrow一个jedis实例时,是否提前进行validate操作,如果为true,则得到的jedis实例均是可用的 jedispool = new jedispool(config, "127.0.0.1", 6379); } return jedispool; } /** * 释放jedis资源 */ public static void returnresource(jedis jedis) { if (jedis != null) { jedis.close(); } } public static string get(string key) { string value = null; jedis jedis = null; try { jedispool pool = getjedispool(); jedis = pool.getresource(); value = jedis.get(key); } catch (exception e) { returnresource(jedis); e.printstacktrace(); } finally { returnresource(jedis); } return value; }
redistemplate封装了从jedispool中取jedis以及返回池中
public class redistemplate { private jedispool jedispool; public redistemplate(jedispool jedispool) { this.jedispool = jedispool; } public <t> t execute(rediscallback<t> callback) { jedis jedis = jedispool.getresource(); try { return callback.handle(jedis); } catch (exception e) { // throw your exception throw e; } finally { returnresource(jedis); } } private void returnresource(jedis jedis) { if (jedis != null) { jedis.close(); } } } public interface rediscallback<t> { public t handle(jedis jedis); }
以上这篇redis在java中的使用(实例讲解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
上一篇: java生成压缩文件示例代码
下一篇: 浅谈maven单元测试设置代理
推荐阅读
-
redis在java中的使用(实例讲解)
-
Java使用Jedis操作Redis服务器的实例代码
-
java堆栈类使用实例(java中stack的使用方法)
-
Java中的弱引用实例讲解
-
Java中break、continue、return在for循环中的使用
-
Java泛型-泛型作用+泛型在各种数据结构中的使用+自定义泛型
-
关于Java代码在应用层获取Android系统属性的使用实例
-
以实例全面讲解PHP中多进程编程的相关函数的使用
-
[JAVA IDEA]在使用maven项目中,无法读取resources文件夹中的配置文件的一种解决方案
-
python中如何django使用haystack:全文检索的框架的实例讲解