Java中使用Jedis操作Redis

來源:互聯網
上載者:User

Java中使用Jedis操作Redis

使用Java操作Redis需要jedis-2.1.0.jar,如果需要使用Redis串連池的話,還需commons-pool-1.5.4.jar,這兩個檔案到幫客之家資來源站點下載:

------------------------------------------分割線------------------------------------------

免費在 http://linux.bkjia.com/

使用者名稱與密碼都是www.bkjia.com

具體下載目錄在 /2016年資料/4月/8日/Java中使用Jedis操作Redis/

下載方法見

------------------------------------------分割線------------------------------------------

package com.test;

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

import org.junit.Before;
import org.junit.Test;

import redis.clients.jedis.Jedis;

public class TestRedis {
    private Jedis jedis;
   
    @Before
    public void setup() {
        //串連redis伺服器,192.168.0.100:6379
        jedis = new Jedis("192.168.0.100", 6379);
        //許可權認證
        jedis.auth("admin"); 
    }
   
    /**
    * redis儲存字串
    */
    @Test
    public void testString() {
        //-----添加資料---------- 
        jedis.set("name","xinxin");//向key-->name中放入了value-->xinxin 
        System.out.println(jedis.get("name"));//執行結果:xinxin 
       
        jedis.append("name", " is my lover"); //拼接
        System.out.println(jedis.get("name"));
       
        jedis.del("name");  //刪除某個鍵
        System.out.println(jedis.get("name"));
        //設定多個索引值對
        jedis.mset("name","liuling","age","23","qq","476777XXX");
        jedis.incr("age"); //進行加1操作
        System.out.println(jedis.get("name") + "-" + jedis.get("age") + "-" + jedis.get("qq"));
       
    }
   
    /**
    * redis操作Map
    */
    @Test
    public void testMap() {
        //-----添加資料---------- 
        Map<String, String> map = new HashMap<String, String>();
        map.put("name", "xinxin");
        map.put("age", "22");
        map.put("qq", "123456");
        jedis.hmset("user",map);
        //取出user中的name,執行結果:[minxr]-->注意結果是一個泛型的List 
        //第一個參數是存入redis中map對象的key,後面跟的是放入map中的對象的key,後面的key可以跟多個,是可變參數 
        List<String> rsmap = jedis.hmget("user", "name", "age", "qq");
        System.out.println(rsmap); 
 
        //刪除map中的某個索引值 
        jedis.hdel("user","age");
        System.out.println(jedis.hmget("user", "age")); //因為刪除了,所以返回的是null 
        System.out.println(jedis.hlen("user")); //返回key為user的鍵中存放的值的個數2
        System.out.println(jedis.exists("user"));//是否存在key為user的記錄 返回true 
        System.out.println(jedis.hkeys("user"));//返回map對象中的所有key 
        System.out.println(jedis.hvals("user"));//返回map對象中的所有value
 
        Iterator<String> iter=jedis.hkeys("user").iterator(); 
        while (iter.hasNext()){ 
            String key = iter.next(); 
            System.out.println(key+":"+jedis.hmget("user",key)); 
        } 
    }
   
    /**
    * jedis操作List
    */ 
    @Test 
    public void testList(){ 
        //開始前,先移除所有的內容 
        jedis.del("java framework"); 
        System.out.println(jedis.lrange("java framework",0,-1)); 
        //先向key java framework中存放三條資料 
        jedis.lpush("java framework","spring"); 
        jedis.lpush("java framework","struts"); 
        jedis.lpush("java framework","hibernate"); 
        //再取出所有資料jedis.lrange是按範圍取出, 
        // 第一個是key,第二個是起始位置,第三個是結束位置,jedis.llen擷取長度 -1表示取得所有 
        System.out.println(jedis.lrange("java framework",0,-1)); 
       
        jedis.del("java framework");
        jedis.rpush("java framework","spring"); 
        jedis.rpush("java framework","struts"); 
        jedis.rpush("java framework","hibernate");
        System.out.println(jedis.lrange("java framework",0,-1));
    } 
   
    /**
    * jedis操作Set
    */ 
    @Test 
    public void testSet(){ 
        //添加 
        jedis.sadd("user","liuling"); 
        jedis.sadd("user","xinxin"); 
        jedis.sadd("user","ling"); 
        jedis.sadd("user","zhangxinxin");
        jedis.sadd("user","who"); 
        //移除noname 
        jedis.srem("user","who"); 
        System.out.println(jedis.smembers("user"));//擷取所有加入的value 
        System.out.println(jedis.sismember("user", "who"));//判斷 who 是否是user集合的元素 
        System.out.println(jedis.srandmember("user")); 
        System.out.println(jedis.scard("user"));//返回集合的元素個數 
    } 
 
    @Test 
    public void test() throws InterruptedException { 
        //jedis 排序 
        //注意,此處的rpush和lpush是List的操作。是一個雙向鏈表(但從表現來看的) 
        jedis.del("a");//先清除資料,再加入資料進行測試 
        jedis.rpush("a", "1"); 
        jedis.lpush("a","6"); 
        jedis.lpush("a","3"); 
        jedis.lpush("a","9"); 
        System.out.println(jedis.lrange("a",0,-1));// [9, 3, 6, 1] 
        System.out.println(jedis.sort("a")); //[1, 3, 6, 9]  //輸入排序後結果 
        System.out.println(jedis.lrange("a",0,-1)); 
    } 
   
    @Test
    public void testRedisPool() {
        RedisUtil.getJedis().set("newname", "中文測試");
        System.out.println(RedisUtil.getJedis().get("newname"));
    }
}

Redis串連池:

package com.test;

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

public final class RedisUtil {
   
    //Redis伺服器IP
    private static String ADDR = "192.168.0.100";
   
    //Redis的連接埠號碼
    private static int PORT = 6379;
   
    //訪問密碼
    private static String AUTH = "admin";
   
    //可用串連執行個體的最大數目,預設值為8;
    //如果賦值為-1,則表示不限制;如果pool已經分配了maxActive個jedis執行個體,則此時pool的狀態為exhausted(耗盡)。
    private static int MAX_ACTIVE = 1024;
   
    //控制一個pool最多有多少個狀態為idle(閒置)的jedis執行個體,預設值也是8。
    private static int MAX_IDLE = 200;
   
    //等待可用串連的最大時間,單位毫秒,預設值為-1,表示永不逾時。如果超過等待時間,則直接拋出JedisConnectionException;
    private static int MAX_WAIT = 10000;
   
    private static int 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();
            config.setMaxActive(MAX_ACTIVE);
            config.setMaxIdle(MAX_IDLE);
            config.setMaxWait(MAX_WAIT);
            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 resource = jedisPool.getResource();
                return resource;
            } else {
                return null;
            }
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }
   
    /**
    * 釋放jedis資源
    * @param jedis
    */
    public static void returnResource(final Jedis jedis) {
        if (jedis != null) {
            jedisPool.returnResource(jedis);
        }
    }
}

下面關於Redis的文章您也可能喜歡,不妨參考下:

Ubuntu 14.04下Redis安裝及簡單測試

Redis主從複製基本配置

Redis叢集明細文檔

Ubuntu 12.10下安裝Redis(圖文詳解)+ Jedis串連Redis

Redis系列-安裝部署維護篇

CentOS 6.3安裝Redis

Redis安裝部署學習筆記

Redis設定檔redis.conf 詳解

Redis 的詳細介紹:請點這裡
Redis 的:請點這裡

本文永久更新連結地址:

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.