zoukankan      html  css  js  c++  java
  • Java 之 Jedis

    一、客户端 Jedis

      1、Jedis

        Jedis 是一款java操作 redis 数据库的工具。

      2、使用步骤

        (1)下载 Jedis 的 jar 包

        (2)使用:

    1  //1. 获取连接
    2 Jedis jedis = new Jedis("localhost",6379);  // 可以使用空参构造,默认值"localhost",6379端口
    3 
    4 //2. 操作
    5  jedis.set("username","zhangsan");
    6 
    7 //3. 关闭连接
    8  jedis.close();

    二、Jedis 操作各种 redis 中的数据结构

      1、操作字符串类型 String

        使用的方法同 redis 里面的方法。

        Demo:

     1         //1. 获取连接
     2         Jedis jedis = new Jedis(); 3         //2. 操作
     4         //存储
     5         jedis.set("username","zhangsan");
     6         //获取
     7         String username = jedis.get("username");
     8         System.out.println(username);
     9 
    10         //可以使用setex()方法存储可以指定过期时间的 key value
    11         jedis.setex("activecode",20,"asdf");//将activecode:asdf键值对存入redis,并且20秒后自动删除该键值对
    12 
    13         //3. 关闭连接
    14         jedis.close();

      2、操作哈希类型 hash:map格式

        使用的方法:hset、hget、hgetall

        Demo:

     1     //1. 获取连接
     2         Jedis jedis = new Jedis(); 3         //2. 操作
     4         // 存储hash
     5         jedis.hset("user","name","lisi");
     6         jedis.hset("user","age","23");
     7         jedis.hset("user","sex","man");
     8 
     9         // 获取hash
    10         String name = jedis.hget("user", "name");
    11         System.out.println(name);
    12 
    13 
    14         // 获取hash的所有map中的数据
    15         Map<String, String> user = jedis.hgetAll("user");
    16 
    17         // keyset
    18         Set<String> keySet = user.keySet();
    19         for (String key : keySet) {
    20             //获取value
    21             String value = user.get(key);
    22             System.out.println(key + ":" + value);
    23         }
    24 
    25         //3. 关闭连接
    26         jedis.close();

      3、操作列表类型 list:linkedlist 格式。支持重复元素。

        常用方法:lpush、lpush、lpop、rpop、lrange start end。

        Demo:

     1      //1. 获取连接
     2         Jedis jedis = new Jedis(); 3         //2. 操作
     4         // list 存储
     5         jedis.lpush("mylist","a","b","c");//从左边存
     6         jedis.rpush("mylist","a","b","c");//从右边存
     7 
     8         // list 范围获取
     9         List<String> mylist = jedis.lrange("mylist", 0, -1);
    10         System.out.println(mylist);
    11         
    12         // list 弹出
    13         String element1 = jedis.lpop("mylist");//c
    14         System.out.println(element1);
    15 
    16         String element2 = jedis.rpop("mylist");//c
    17         System.out.println(element2);
    18 
    19         // list 范围获取
    20         List<String> mylist2 = jedis.lrange("mylist", 0, -1);
    21         System.out.println(mylist2);
    22 
    23         //3. 关闭连接
    24         jedis.close();

      4、操作集合类型 set:不允许重复元素

        常用方法:sadd、smembers。

        Demo:

     1      //1. 获取连接
     2         Jedis jedis = new Jedis();
     3 
     4         //2. 操作
     5         // set 存储
     6         jedis.sadd("myset","java","php","c++");
     7 
     8         // set 获取
     9         Set<String> myset = jedis.smembers("myset");
    10         System.out.println(myset);
    11 
    12         //3. 关闭连接
    13         jedis.close();

      5、操作有序集合类型 sortedset:不允许重复元素,且元素有序。

        常用方法:zadd、zrange。

       Demo:

     1      //1. 获取连接
     2         Jedis jedis = new Jedis();
     3         //2. 操作
     4         // sortedset 存储
     5         jedis.zadd("mysortedset",3,"亚瑟");
     6         jedis.zadd("mysortedset",30,"后裔");
     7         jedis.zadd("mysortedset",55,"孙悟空");
     8 
     9         // sortedset 获取
    10         Set<String> mysortedset = jedis.zrange("mysortedset", 0, -1);
    11 
    12         System.out.println(mysortedset);
    13 
    14 
    15         //3. 关闭连接
    16         jedis.close();

    三、Jedis 连接池:JedisPool

      1、使用步骤

        (1)创建一个配置对象

        (2)创建一个 JedisPool 连接池对象

        (3)调用方法 getResource() 方法获取 Jedis 连接

        (4)使用连接

        (5)关闭连接,把连接归还到连接池中

      2、代码实现

       代码实现:

     1         //1.创建一个配置对象
     2         JedisPoolConfig config = new JedisPoolConfig();
     3         config.setMaxTotal(50); // 设置最大连接数
     4         config.setMaxIdle(10);  // 设置最大空闲数
     5 
     6         //2.创建Jedis连接池对象
     7         JedisPool jedisPool = new JedisPool(config,"localhost",6379);
     8 
     9         //3.获取连接
    10         Jedis jedis = jedisPool.getResource();
    11         //4. 使用
    12         jedis.set("hehe","heihei");
    13 
    14 
    15         //5. 关闭 归还到连接池中
    16         jedis.close();;

    四、连接池工具类

      在上面的代码中,将一些配置信息放入了代码中,但是这样并不有利于配置信息的修改,可以将配置信息单独放入一个文件中,然后读取该文件的内容即可。

      jedis 详细配置说明:

     1 #最大活动对象数     
     2 redis.pool.maxTotal=1000    
     3 #最大能够保持idel状态的对象数      
     4 redis.pool.maxIdle=100  
     5 #最小能够保持idel状态的对象数   
     6 redis.pool.minIdle=50    
     7 #当池内没有返回对象时,最大等待时间    
     8 redis.pool.maxWaitMillis=10000    
     9 #当调用borrow Object方法时,是否进行有效性检查    
    10 redis.pool.testOnBorrow=true    
    11 #当调用return Object方法时,是否进行有效性检查    
    12 redis.pool.testOnReturn=true  
    13 #“空闲链接”检测线程,检测的周期,毫秒数。如果为负值,表示不运行“检测线程”。默认为-1.  
    14 redis.pool.timeBetweenEvictionRunsMillis=30000  
    15 #向调用者输出“链接”对象时,是否检测它的空闲超时;  
    16 redis.pool.testWhileIdle=true  
    17 # 对于“空闲链接”检测线程而言,每次检测的链接资源的个数。默认为3.  
    18 redis.pool.numTestsPerEvictionRun=50  
    19 #redis服务器的IP    
    20 redis.ip=xxxxxx  
    21 #redis服务器的Port    
    22 redis1.port=6379   

      jedis.properties 文件

    1 host=127.0.0.1
    2 port=6379
    3 maxTotal=50
    4 maxIdle=10

      jedis 连接池工具类

     1 import redis.clients.jedis.Jedis;
     2 import redis.clients.jedis.JedisPool;
     3 import redis.clients.jedis.JedisPoolConfig;
     4 
     5 import java.io.IOException;
     6 import java.io.InputStream;
     7 import java.util.Properties;
     8 
     9 /**
    10  JedisPool工具类
    11     加载配置文件,配置连接池的参数
    12     提供获取连接的方法
    13 
    14  */
    15 public class JedisPoolUtils {
    16 
    17     private static JedisPool jedisPool;
    18 
    19     static{
    20         //读取配置文件
    21         InputStream is = JedisPoolUtils.class.getClassLoader().getResourceAsStream("jedis.properties");
    22         //创建Properties对象
    23         Properties pro = new Properties();
    24         //关联文件
    25         try {
    26             pro.load(is);
    27         } catch (IOException e) {
    28             e.printStackTrace();
    29         }
    30         //获取数据,设置到JedisPoolConfig中
    31         JedisPoolConfig config = new JedisPoolConfig();
    32         config.setMaxTotal(Integer.parseInt(pro.getProperty("maxTotal")));
    33         config.setMaxIdle(Integer.parseInt(pro.getProperty("maxIdle")));
    34 
    35         //初始化JedisPool
    36         jedisPool = new JedisPool(config,pro.getProperty("host"),Integer.parseInt(pro.getProperty("port")));
    37 
    38 
    39     }
    40 
    41 
    42     /**
    43      * 获取连接方法
    44      */
    45     public static Jedis getJedis(){
    46         return jedisPool.getResource();
    47     }
    48 }
  • 相关阅读:
    algorithm
    jstl
    jsp
    cookie
    变量和方法调用过程中会出现的参数传递
    http请求
    weblogic 的安全域问题
    web service
    行业充电
    客户端生成web service
  • 原文地址:https://www.cnblogs.com/niujifei/p/11647683.html
Copyright © 2011-2022 走看看