Redis】Java中使用Jedis操做Redis(Maven導入包)、建立Redis鏈接池

若是咱們使用Java操做Redis, 須要確保已經安裝了 redis 服務及 Java redis 驅動。java

Maven項目能夠直接在pom.xml中加入jedis包驅動:redis

        <!-- https://mvnrepository.com/artifact/redis.clients/jedis -->
        <dependency>
            <groupId>redis.clients</groupId>
            <artifactId>jedis</artifactId>
            <version>2.9.0</version>
        </dependency>

Jedis中操做String,List,Set,Map,以及集合排序

package cn.hncu;

import org.junit.Before;
import org.junit.Test;
import redis.clients.jedis.Jedis;

import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

/**
 * Created with IntelliJ IDEA.
 * Explain:Java操做Redis測試
 */
public class TestRedis {

    private Jedis jedis;

    @Before
    public void setJedis() {
        //鏈接redis服務器(在這裏是鏈接本地的)
        jedis = new Jedis("127.0.0.1", 6379);
        //權限認證
        jedis.auth("chenhaoxiang");
        System.out.println("鏈接服務成功");
    }

    /**
     * Redis操做字符串
     */
    @Test
    public void testString() {
        //添加數據
        jedis.set("name", "chx"); //key爲name放入value值爲chx
        System.out.println("拼接前:" + jedis.get("name"));//讀取key爲name的值

        //向key爲name的值後面加上數據 ---拼接
        jedis.append("name", " is my name;");
        System.out.println("拼接後:" + jedis.get("name"));

        //刪除某個鍵值對
        jedis.del("name");
        System.out.println("刪除後:" + jedis.get("name"));

        //s設置多個鍵值對
        jedis.mset("name", "chenhaoxiang", "age", "20", "email", "chxpostbox@outlook.com");
        jedis.incr("age");//用於將鍵的整數值遞增1。若是鍵不存在,則在執行操做以前將其設置爲0。 若是鍵包含錯誤類型的值或包含沒法表示爲整數的字符串,則會返回錯誤。此操做限於64位有符號整數。
        System.out.println(jedis.get("name") + " " + jedis.get("age") + " " + jedis.get("email"));
    }

    @Test
    public void testMap() {
        //添加數據
        Map<String, String> map = new HashMap<String, String>();
        map.put("name", "chx");
        map.put("age", "100");
        map.put("email", "***@outlook.com");
        jedis.hmset("user", map);
        //取出user中的name,結果是一個泛型的List
        //第一個參數是存入redis中map對象的key,後面跟的是放入map中的對象的key,後面的key是可變參數
        List<String> list = jedis.hmget("user", "name", "age", "email");
        System.out.println(list);

        //刪除map中的某個鍵值
        jedis.hdel("user", "age");
        System.out.println("age:" + jedis.hmget("user", "age")); //由於刪除了,因此返回的是null
        System.out.println("user的鍵中存放的值的個數:" + jedis.hlen("user")); //返回key爲user的鍵中存放的值的個數2
        System.out.println("是否存在key爲user的記錄:" + jedis.exists("user"));//是否存在key爲user的記錄 返回true
        System.out.println("user對象中的全部key:" + jedis.hkeys("user"));//返回user對象中的全部key
        System.out.println("user對象中的全部value:" + jedis.hvals("user"));//返回map對象中的全部value

        //拿到key,再經過迭代器獲得值
        Iterator<String> iterator = jedis.hkeys("user").iterator();
        while (iterator.hasNext()) {
            String key = iterator.next();
            System.out.println(key + ":" + jedis.hmget("user", key));
        }
        jedis.del("user");
        System.out.println("刪除後是否存在key爲user的記錄:" + jedis.exists("user"));//是否存在key爲user的記錄

    }

    /**
     * jedis操做List
     */
    @Test
    public void testList(){
        //移除javaFramwork所全部內容
        jedis.del("javaFramwork");
        //存放數據
        jedis.lpush("javaFramework","spring");
        jedis.lpush("javaFramework","springMVC");
        jedis.lpush("javaFramework","mybatis");
        //取出全部數據,jedis.lrange是按範圍取出
        //第一個是key,第二個是起始位置,第三個是結束位置
        System.out.println("長度:"+jedis.llen("javaFramework"));
        //jedis.llen獲取長度,-1表示取得全部
        System.out.println("javaFramework:"+jedis.lrange("javaFramework",0,-1));

        jedis.del("javaFramework");
        System.out.println("刪除後長度:"+jedis.llen("javaFramework"));
        System.out.println(jedis.lrange("javaFramework",0,-1));
    }

    /**
     * jedis操做Set
     */
    @Test
    public void testSet(){
        //添加
        jedis.sadd("user","chenhaoxiang");
        jedis.sadd("user","hu");
        jedis.sadd("user","chen");
        jedis.sadd("user","xiyu");
        jedis.sadd("user","chx");
        jedis.sadd("user","are");
        //移除user集合中的元素are
        jedis.srem("user","are");
        System.out.println("user中的value:"+jedis.smembers("user"));//獲取全部加入user的value
        System.out.println("chx是不是user中的元素:"+jedis.sismember("user","chx"));//判斷chx是不是user集合中的元素
        System.out.println("集合中的一個隨機元素:"+jedis.srandmember("user"));//返回集合中的一個隨機元素
        System.out.println("user中元素的個數:"+jedis.scard("user"));
    }

    /**
     * 排序
     */
    @Test
    public void test(){
        jedis.del("number");//先刪除數據,再進行測試
        jedis.rpush("number","4");//將一個或多個值插入到列表的尾部(最右邊)
        jedis.rpush("number","5");
        jedis.rpush("number","3");

        jedis.lpush("number","9");//將一個或多個值插入到列表頭部
        jedis.lpush("number","1");
        jedis.lpush("number","2");
        System.out.println(jedis.lrange("number",0,jedis.llen("number")));
        System.out.println("排序:"+jedis.sort("number"));
        System.out.println(jedis.lrange("number",0,-1));//不改變原來的排序
        jedis.del("number");//測試完刪除數據
    }


}

Redis鏈接池

package cn.hncu;

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

/**
 * Created with IntelliJ IDEA.
 * Explain:Redis鏈接池
 */
public final class RedisPool {
    //Redis服務器IP
    private static String ADDR = "127.0.0.1";
    //Redis的端口號
    private static Integer PORT = 6379;
    //訪問密碼
    private static String AUTH = "chenhaoxiang";

    //可用鏈接實例的最大數目,默認爲8;
    //若是賦值爲-1,則表示不限制,若是pool已經分配了maxActive個jedis實例,則此時pool的狀態爲exhausted(耗盡)
    private static Integer MAX_TOTAL = 1024;
    //控制一個pool最多有多少個狀態爲idle(空閒)的jedis實例,默認值是8
    private static Integer MAX_IDLE = 200;
    //等待可用鏈接的最大時間,單位是毫秒,默認值爲-1,表示永不超時。
    //若是超過等待時間,則直接拋出JedisConnectionException
    private static Integer MAX_WAIT_MILLIS = 10000;
    private static Integer TIMEOUT = 10000;
    //在borrow(用)一個jedis實例時,是否提早進行validate(驗證)操做;
    //若是爲true,則獲得的jedis實例均是可用的
    private static Boolean TEST_ON_BORROW = true;
    private  static JedisPool jedisPool = null;

    /**
     * 靜態塊,初始化Redis鏈接池
     */
    static {
        try {
            JedisPoolConfig config = new JedisPoolConfig();
        /*注意:
            在高版本的jedis jar包,好比本版本2.9.0,JedisPoolConfig沒有setMaxActive和setMaxWait屬性了
            這是由於高版本中官方廢棄了此方法,用如下兩個屬性替換。
            maxActive  ==>  maxTotal
            maxWait==>  maxWaitMillis
         */
            config.setMaxTotal(MAX_TOTAL);
            config.setMaxIdle(MAX_IDLE);
            config.setMaxWaitMillis(MAX_WAIT_MILLIS);
            config.setTestOnBorrow(TEST_ON_BORROW);
            jedisPool = new JedisPool(config,ADDR,PORT,TIMEOUT,AUTH);
        } catch (Exception e) {
            e.printStackTrace();
        }

    }

    /**
     * 獲取Jedis實例
     * @return
     */
    public synchronized static Jedis getJedis(){
        try {
            if(jedisPool != null){
                Jedis jedis = jedisPool.getResource();
                return jedis;
            }else{
                return null;
            }
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }

    public static void returnResource(final Jedis jedis){
        //方法參數被聲明爲final,表示它是隻讀的。
        if(jedis!=null){
            jedisPool.returnResource(jedis);
            //jedis.close()取代jedisPool.returnResource(jedis)方法將3.0版本開始
            //jedis.close();
        }
    }
}

RedisJava測試鏈接池

package cn.hncu;

import redis.clients.jedis.Jedis;

/**
 * Created with IntelliJ IDEA.
 * Explain:測試RedisPool
 */
public class RedisJava {

    public static void main(String[] args) {
        RedisPool.getJedis().set("name","陳浩翔");
        System.out.println(RedisPool.getJedis().get("name"));
    }

}
相關文章
相關標籤/搜索