springMVC整合jedis+redis
http://www.cnblogs.com/zhengbn/p/4140549.html
前两天写过 springMVC+memcached 的整合,我从这个基础上改造一下,把redis和springmvc整合到一起。
和memcached一样,redis也有java专用的客户端,官网推荐使用的是:jedis。
看了一部分资料,大家推荐使用 spring-data-redis (spring在jedis的基础上又包装了一层),但是实际中感觉写起来有点麻烦,不如原生态的jedis好用。
所以我利用spring的构造注入做了一个springmvc整合jedis的例子。
先了解下redis吧,这些资料袋都是从网上看到的:

Redis使用c语言编写,面向“键/值”对类型数据的分布式NoSql数据库系统。 目前提供五中数据类型 string(字符串) list(链表) Hash(哈希) set(集合) zset(sorted set 有序集合),有2中编码类型:ziplist,skiplist,当zset中数据较多时,将会被重构为skiplist。 默认端口6379先写一个Test类,测一下redis的基本数据类型和jedis的一些常用方法。以下的测试方法也都是从网上看到的,只不过为了验证是否准确以及jar包版本的问题,我自己亲自敲了一遍。
public class Test {
public static void main(String[] args) {// Jedis js = new Jedis("127.0.0.1", 6379);
// js.set("key001", "redis001");// String val = js.get("key001");// System.out.println(val);// js.del("key001");
/**************************测试Redis的数据类型**************************/
/** * list */// js.rpush("list1", "aaaaaaaaaaaaaaaaaaaaaa");// js.rpush("list1", "bbbbbbbbbbbbbbbbbbbbbb");// js.rpush("list1", "ccccccccccccccccccccc");// js.rpush("list1", "dddddddddddddd");// List<String> vals = js.lrange("list1", 0, -1);// for (int i = 0; i < vals.size(); i++) {// System.out.println(vals.get(i));// }
/** * set 无须唯一 */// js.sadd("s1", "顺序3");// js.sadd("s1", "a");// js.sadd("s1", "b");// js.sadd("s1", "1");// js.sadd("s1", "蛤蛤蛤");// js.sadd("s1", "2");// js.sadd("s1", "so waht?");// js.sadd("s1", "%^");// js.sadd("s1", "顺序1");// js.sadd("s1", "乱码吗?");// js.sadd("s1", "顺序2");// Set<String> s = js.smembers("s1");// for (String string : s) {// System.out.println(s);// }// js.srem("s1", "蛤蛤蛤");
/** * zset(sorted set 有序集合) * 有2中编码类型:ziplist,skiplist,当zset中数据较多时,将会被重构为skiplist */// js.zadd("zs", 92, "张三1");// js.zadd("zs", 93, "张三7");// js.zadd("zs", 94, "张三5");// js.zadd("zs", 87, "张三9");// js.zadd("zs", 66, "张三");// js.zadd("zs", 19, "张三0");// Set<String> sets = js.zrange("zs", 0, -1);// for (String string : sets) {// System.out.println(sets);// }
/** * Hash */// Map m = new HashMap();// m.put("1", "t");// m.put("2", "ttt");// m.put("username", "老王");// m.put("password", "123456");// m.put("age", "79");// m.put("sex", "man");// js.hmset("m", m); // List<String> v = js.hmget("m", new String[]{"username","age"});// List<String> v1 = js.hmget("m", "sex");// System.out.println(v);// System.out.println(v1);// js.hdel("m", "username");//删除map中的某一个键的键值对
/**************************事务控制**************************/
/** * 事务方式(Transactions) * 他主要目的是保障,一个client发起的事务中的命令可以连续的执行,而中间不会插入其他client的命令。 * * 我们调用jedis.watch(…)方法来监控key,如果调用后key值发生变化,则整个事务会执行失败。 * 另外,事务中某个操作失败,并不会回滚其他操作。这一点需要注意。 * 还有,我们可以使用discard()方法来取消事务。 */// Jedis js1 = new Jedis("127.0.0.1", 6379);// long s = System.currentTimeMillis();// Transaction tx = js1.multi();// for (int i = 0; i < 99999; i++) {// tx.set("keyttt"+i, "valttt"+i);// }// List<Object> res= tx.exec();// long e = System.currentTimeMillis();// System.out.println((e-s)/1000.0+"秒"); //System.out.println(res);// js1.disconnect();
/**************************管道**************************/ /** * 管道(Pipelining) * 有时,我们需要采用异步方式,一次发送多个指令,不同步等待其返回结果。 * 这样可以取得非常好的执行效率。这就是管道 */// Jedis js2 = new Jedis("127.0.0.1", 6379);// long s = System.currentTimeMillis();// Pipeline pe = js2.pipelined();// for (int i = 0; i < 9999; i++) {// pe.set("keya"+i, "valuea"+i);// }// List<Object> l = pe.syncAndReturnAll();// long e = System.currentTimeMillis();// System.out.println((e-s)/1000.0+"秒");// js2.disconnect();
/**************************管道中调用事务**************************/ /** * 管道中调用事务 * 在用法上看,管道中包含了事务 */
// Jedis js3 = new Jedis("127.0.0.1", 6379);// long s = System.currentTimeMillis();// Pipeline pe = js3.pipelined();// pe.multi();// for (int i = 0; i < 9999; i++) {// pe.set("keybb"+i, "valuebb"+i);// }// pe.exec();// List<Object> l = pe.syncAndReturnAll();// long e = System.currentTimeMillis();// System.out.println((e-s)/1000.0+"秒");// js3.disconnect();
/**************************分布式直连同步调用**************************/ /** * 分布式直连同步调用 * 线程不安全的,不建议在线程池中使用直连 */// List<JedisShardInfo> shards = Arrays.asList(// new JedisShardInfo("localhost",6379),// new JedisShardInfo("localhost",6380));// ShardedJedis sharding = new ShardedJedis(shards);// long start = System.currentTimeMillis();// for (int i = 0; i < 100000; i++) {// String result = sharding.set("sn" + i, "n" + i);// }// long end = System.currentTimeMillis();// System.out.println("Simple@Sharing SET: " + ((end - start)/1000.0) + " seconds");// sharding.disconnect();
/**************************分布式直连同步调用**************************/ /** * 分布式直连异步调用 * 线程不安全的,不建议在线程池中使用直连 */// List<JedisShardInfo> shards = Arrays.asList(// new JedisShardInfo("localhost",6379),// new JedisShardInfo("localhost",6380));// ShardedJedis sharding = new ShardedJedis(shards);// ShardedJedisPipeline pipeline = sharding.pipelined();// long start = System.currentTimeMillis();// for (int i = 0; i < 100000; i++) {// pipeline.set("sp" + i, "p" + i);// }// List<Object> results = pipeline.syncAndReturnAll();// long end = System.currentTimeMillis();// System.out.println("Pipelined@Sharing SET: " + ((end - start)/1000.0) + " seconds");// sharding.disconnect();
/**************************分布式连接池同步调用**************************/ /** * 同步方式 */// List<JedisShardInfo> shards = Arrays.asList(// new JedisShardInfo("localhost",6379),// new JedisShardInfo("localhost",6380));//// ShardedJedisPool pool = new ShardedJedisPool(new JedisPoolConfig(), shards);//// ShardedJedis one = pool.getResource();//// long start = System.currentTimeMillis();// for (int i = 0; i < 100000; i++) {// String result = one.set("spn" + i, "n" + i);// }// long end = System.currentTimeMillis();// pool.returnResource(one);// System.out.println("Simple@Pool SET: " + ((end - start)/1000.0) + " seconds");//// pool.destroy(); //
/**************************分布式连接池异步调用**************************/ /** * 异步方式 */// List<JedisShardInfo> shards = Arrays.asList(// new JedisShardInfo("localhost",6379),// new JedisShardInfo("localhost",6380));//// ShardedJedisPool pool = new ShardedJedisPool(new JedisPoolConfig(), shards);//// ShardedJedis one = pool.getResource();//// ShardedJedisPipeline pipeline = one.pipelined();//// long start = System.currentTimeMillis();// for (int i = 0; i < 100000; i++) {// pipeline.set("sppn" + i, "n" + i);// }// List<Object> results = pipeline.syncAndReturnAll();// long end = System.currentTimeMillis();// pool.returnResource(one);// System.out.println("Pipelined@Pool SET: " + ((end - start)/1000.0) + " seconds");// pool.destroy();
/**************************其他**************************/
/** * 清空所有 */// js.flushAll();
/** * 销毁链接 */// js.disconnect();
}
注意jedis是redis的一个客户端,是个jar包,不要搞混了……
springMVC整合jedis+redis的更多相关文章
- springMVC整合jedis+redis,以注解形式使用
前两天写过 springMVC+memcached 的整合,我从这个基础上改造一下,把redis和springmvc整合到一起. 和memcached一样,redis也有java专用的客户端,官网推荐 ...
- springmvc整合redis架构搭建实例
新换环境,又有新东西可以学习了,哈皮! 抽空学习之余看了一下redis,个人对Springmvc的爱是忠贞不渝,所以整理了一下Springmvc整合redis的环境搭建.分享学习. 第一步: 创建ma ...
- redis集群配置,spring整合jedis,缓存同步
前台的商品数据(图片等加载缓慢)查询,先从redis缓存查询数据. redis是一个nosql数据库,内存版数据库,读取速度11w/s.本身具有内存淘汰机制,是单线程服务器(分时操作系统),线程安全. ...
- springmvc+spring-security+mybatis +redis +solar框架抽取
参考文章:Spring MVC 3 深入总结: 第二章 Spring MVC入门 —— 跟开涛学SpringMVC 参考博客:http://www.cnblogs.com/liukemng/categ ...
- Redis-07.Spring Data整合Jedis
Spring整合Jedis 1.单实例(想节约时间的请直接拖到下面跳过1.2部分) step1:毫无疑问,首先需要在pom.xml中配置Jedis依赖 <dependency> <g ...
- 六:Dubbo与Zookeeper、SpringMvc整合和使用
DUBBO与ZOOKEEPER.SPRINGMVC整合和使用 互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,Dubbo是一个分布式服务框架 ...
- Mybatis整合(Redis、Ehcache)实现二级缓存
目的: Mybatis整合Ehcache实现二级缓存 Mybatis整合Redis实现二级缓存 Mybatis整合ehcache实现二级缓存 ssm中整合ehcache 在POM中导入相关依赖 < ...
- springMVC+Spring+Mybatis+Redis
SPRINGMVC+MYBATIS+SPRING+REDIS 只作参考,以防忘记使用! mybatis的配置文件: <?xml version="1.0" encoding= ...
- (转)Dubbo与Zookeeper、SpringMVC整合和使用
原文地址: https://my.oschina.net/zhengweishan/blog/693163 Dubbo与Zookeeper.SpringMVC整合和使用 osc码云托管地址:http: ...
随机推荐
- 绘图quartz之渐变
实现线性渐变 径向渐变 自己新建的view中有一个drawRect:(cgrect)rect方法 在这个方法里 可以通过画图 将内容显示在画板上(即最下边的view) 渐变的方式分两种 ...
- cocos2dx JAVA,C++互相调用函数
C++调用JAVA 例子 #if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID) #include "platform/android/jni/Jni ...
- linux 监控服务器脚本
#!/bin/bash ctime=`date +%x%T`monitor_dir=/home/jk/if [ ! -d $monitor_dir ]; then mkdir $monitor_ ...
- JQuery无法获取动态添加的图片宽度问题解决办法
$('.imgUl li,.v_img').click(function(){ var _left = 0; var _top = 0; $('body').append('<div class ...
- 响应式十日谈第一日:使用 rem 设置文字大小
上面回顾: 在序言中我们已经提到了响应式的一些基本理念,比如: 响应式网页不仅仅是响应不同类型的设备,而且需要响应不同的用户需求.响应式的初衷是为了让信息更好的传递交流,让所有人无障碍的获取信息,同时 ...
- 根据打开页面加载不同Js
根据打开页面加载不同Js //根据打开页面加载不同JS $(document).ready(function(){ var href = document.URL; /*获取当前页面的URL*/ if ...
- SVN版本回滚~
如果你在svn上对文件进行编辑作了修改,想撤销,那么有两种方法可以还原:1) svn revert <yourfile>2) 手动删除该文件,重新执行svn up(rm <yourf ...
- 转:gpio_request
今天再次学习SD卡驱动,遇到pgio_request这个函数,始终不知道其什么意思,看了几遍源代码才有了点感觉.现将其关键部分再此说明一下,以备自己以后复习,或是路客参考. 一般gpio_reques ...
- BZOJ 1016 最小生成树计数
Description 现在给出了一个简单无向加权图.你不满足于求出这个图的最小生成树,而希望知道这个图中有多少个不同的最小生成树.(如果两颗最小生成树中至少有一条边不同,则这两个最小生成树就是不同的 ...
- 45 Useful JavaScript Tips, Tricks and Best Practices(有用的JavaScript技巧,技巧和最佳实践)
As you know, JavaScript is the number one programming language in the world, the language of the web ...