开发者社区> 微笑着生活> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

第三章:jedis的使用

简介: Jedis是什么? 那jedis就是集成了redis的一些命令操作,封装了redis的java客户端。提供了连接池管理。一般不直接使用jedis,而是在其上在封装一层,作为业务的使用。
+关注继续查看

Jedis是什么?

那jedis就是集成了redis的一些命令操作,封装了redis的java客户端。提供了连接池管理。一般不直接使用jedis,而是在其上在封装一层,作为业务的使用。如果用spring的话,可以看看spring 封装的 redis Spring Data Redis
·###Jedis基本使用

//生成一个Jedis对象,这个对象负责和指定Redis节点进行通信
Jedis jedis = new Jedis("127.0.0.1",6379);
//jedis执行set操作
jedis.set("hello","world");
//jedis执行get操作
String value = jedis.get("hello");
//incr key 自增1,如果key不存在,自增后get(key)=1
jedis.incr("counter");
//2.hash
jedis.hset("myhash","f1","v1");
jedis.hset("myhash","f2","v2");
//hash输出结果
jedis.hgetAll("myhash");
//3.list
jedis.rpush("mylist","1");
jedis.rpush("mylist","2");
jedis.rpush("mylist","3");
//输出结果[1,2,3]
jedis.lrange("mylist",0,-1);
//4.set
jedis.sadd("myset","a");
jedis.sadd("myset","b");
jedis.sadd("myset","c");
//输出结果
jedis.smembers("myset");
//5.zset
jedis.zadd("myzset",1,"jiao");
jedis.zadd("myzset",2,"fant");
jedis.zadd("myzset",3,"j");
//输出结果
jedis.zrangeWithScores("myzset",0,-1);

Jedis 连接池

  1. 直接连接
  • 优点:简单方便,适用于少量长期连接
  • 缺点:存在每次新建/关闭TCP开销;资源无法控制,存在连接泄露可能;线程不安全
  1. Jedis连接池
  • 优点:Jedis预先生成,降低开销使用;连接池的形式保护和控制资源的使用
  • 缺点:相对于直连,使用相对麻烦,尤其在资源的管理上需要很多参数来保证,一旦规划不合理也会出现问题。

Redis连接池工具类 RedisPool.java

package com.answer.admin.util.redis;

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

/**
 * Redis连接池工具
 * Created by Fant.J.
 * 2017/10/24 20:55
 */
public class RedisPool {

    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, "192.168.218.129", 6379);
        }
        return jedisPool;
    }
    /**
     * 释放redis资源
     */
    public static void returnResource(Jedis jedis){
        if(jedis != null){
            jedis.close();
        }
    }
}

使用

package com.answer.admin.util.redis;

import org.junit.Test;
import org.springframework.dao.DataAccessException;
import org.springframework.data.redis.connection.RedisConnection;
import org.springframework.data.redis.core.RedisCallback;
import org.springframework.data.redis.core.RedisTemplate;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;

/**
 * Created by Fant.J.
 * 2017/10/24 20:48
 */

public class RedisTest {
    /** 普通用法 */
    @Test
    public void redisLearn(){
        Jedis jedis = new Jedis("192.168.218.129",6379);
        String result = jedis.get("hello");
        System.out.println(result);
    }
    /** 连接池用法,切记操作结束要施放资源 */
    @Test
    public void redisPoolLearn(){
        String value = "hello";
        String result = null;
        Jedis jedis = null;
        try {
            JedisPool jedisPool = RedisPool.getJedisPool();
            jedis = jedisPool.getResource();
            result = jedis.get(value);
        }catch (Exception e){
            RedisPool.returnResource(jedis);//施放资源
            e.printStackTrace();
        }finally {
            RedisPool.returnResource(jedis);
        }
        System.out.println(result);
    }
}

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Jedis常用操作
Jedis常用操作
85 0
(分享shell脚本)jenkins自动部署Spring Cloud服务实战
概述 jenkins是一个自动构建工具,在jenkins的服务器上指定配置一些应用服务器后,可以实现自动从git拉取代码,然 后将项目部署和启动到应用。本文的目的是想详尽介绍,如何配置整个的部署环境。
3084 0
阿里开源 Dragonwell JDK 重磅发布 GA 版本:生产环境可用
今年 3 月份,阿里巴巴重磅开源 OpenJDK 长期支持版本 Alibaba Dragonwell 的消息,在很长一段时间内都是开发者的讨论焦点,该项目在 Github 上的 Star 数迅速突破 1400。
1973 0
Jedis连接池
项目实例代码已上传githubhttps://github.com/Wasabi1234/mmall 1. 什么是连接池 一般在程序中如果要和其他的系统创建连接进行交互并且连接的创建代价比较"昂贵"就需要用到连接池.
1542 0
sizeof的使用
 通过sizefo可以求出数据类型使用的字节数。 语法:1、sizeof(数据类型变量名称);  2、sizeof(数据类型); #include<stdio.h> void main() {    //字符类型    char charType ='c';    //可以通过siezeof数据类型的方式得到此
968 0
+关注
微笑着生活
快乐开发
文章
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载