您好,欢迎访问一九零五行业门户网

jedis和redistemplate区别

jedis是redis官方推荐的面向java的操作redis的客户端,而redistemplate是springdataredis中对jedisapi的高度封装。
使用原生jedis和spring的redistemplate调用连接池,发现差别巨大:                            (推荐学习:redis视频教程)
redis配置:
redis: database: 0 host: 127.0.0.1 port: 6379 password: 123456 timeout: 5000 lettuce: shutdown-timeout: 200 pool: max-active: 500 max-idle: 100 min-idle: 50 max-wait: 2000
jedis单元测试:
public void testjedis() throws ioexception { greexam greexam = new greexam(); greexam.setid(997); string greexamstr = jacksonutil.bean2json(greexam); long time = 0; for (int i = 0; i < 100; i++) { try (jedis jedis = jedispool.getresource()) { // 1、推送 long time1 = system.currenttimemillis(); jedis.lpush("jedis-mq", greexamstr); // 2、接收 string msg = jedis.brpoplpush("jedis-mq", "jedis-mq_bak", 0); jedis.lrem("jedis-mq_bak", 1, msg); long time2 = system.currenttimemillis(); time += time2 - time1; } catch (exception e) { e.printstacktrace(); } } system.out.println("总时间:" + time); }
redistemplate单元测试:
public void testredistemplate() throws ioexception { greexam greexam = new greexam(); greexam.setid(997); string greexamstr = jacksonutil.bean2json(greexam); long time = 0; for (int i = 0; i < 100; i++) { // 1、推送 long time1 = system.currenttimemillis(); redistemplate.opsforlist().leftpush("redistemplate-mq", greexamstr); // 2、接收 string msg = (string) redistemplate.opsforlist().rightpopandleftpush( "redistemplate-mq", "redistemplate-mq_bak", 1, timeunit.seconds); redistemplate.opsforlist().remove("redistemplate-mq_bak", 1, msg); long time2 = system.currenttimemillis(); time += time2 - time1; } system.out.println("总时间:" + time); }
时效对比:
结论:原生jedis效率优于redistemplate。另外,测试种发现,使用了100次请求,每次不进行业务操作,执行速度很快,redis只保持了几个连接,但是若是加上自己的业务处理或者休眠几秒,会发现redis持续保持了连接池的配置50+连接。
由于是单线程,上一个jedis执行完毕后,貌似没有关闭,而且下次调用也没有分派空闲连接,而是打开新连接,直到最小连接数饱和,才分配空空闲连接给下一个(按理说单线程应该保证新调用的时候,上一个已经完全空闲,所以不再开新连接),具体原因位置,保持疑问,可能和线程池的原理有关。
更多redis相关技术文章,请访问redis数据库使用入门教程栏目进行学习!
以上就是jedis和redistemplate区别的详细内容。
其它类似信息

推荐信息