Java中使用Jedis操作Redis

來源:互聯網
上載者:User

標籤:wait   als   元素   min   source   tac   disco   dmi   exist   

轉載:http://www.cnblogs.com/liuling/p/2014-4-19-04.html

使用Java操作Redis需要jedis-2.1.0.jar,:http://files.cnblogs.com/liuling/jedis-2.1.0.jar.zip

如果需要使用Redis串連池的話,還需commons-pool-1.5.4.jar,:http://files.cnblogs.com/liuling/commons-pool-1.5.4.jar.zip

  1 package com.test;  2   3 import java.util.HashMap;  4 import java.util.Iterator;  5 import java.util.List;  6 import java.util.Map;  7   8 import org.junit.Before;  9 import org.junit.Test; 10  11 import redis.clients.jedis.Jedis; 12  13 public class TestRedis { 14     private Jedis jedis;  15      16     @Before 17     public void setup() { 18         //串連redis伺服器,192.168.0.100:6379 19         jedis = new Jedis("192.168.0.100", 6379); 20         //許可權認證 21         jedis.auth("admin");   22     } 23      24     /** 25      * redis儲存字串 26      */ 27     @Test 28     public void testString() { 29         //-----添加資料----------   30         jedis.set("name","xinxin");//向key-->name中放入了value-->xinxin   31         System.out.println(jedis.get("name"));//執行結果:xinxin   32          33         jedis.append("name", " is my lover"); //拼接 34         System.out.println(jedis.get("name"));  35          36         jedis.del("name");  //刪除某個鍵 37         System.out.println(jedis.get("name")); 38         //設定多個索引值對 39         jedis.mset("name","liuling","age","23","qq","476777XXX"); 40         jedis.incr("age"); //進行加1操作 41         System.out.println(jedis.get("name") + "-" + jedis.get("age") + "-" + jedis.get("qq")); 42          43     } 44      45     /** 46      * redis操作Map 47      */ 48     @Test 49     public void testMap() { 50         //-----添加資料----------   51         Map<String, String> map = new HashMap<String, String>(); 52         map.put("name", "xinxin"); 53         map.put("age", "22"); 54         map.put("qq", "123456"); 55         jedis.hmset("user",map); 56         //取出user中的name,執行結果:[minxr]-->注意結果是一個泛型的List   57         //第一個參數是存入redis中map對象的key,後面跟的是放入map中的對象的key,後面的key可以跟多個,是可變參數   58         List<String> rsmap = jedis.hmget("user", "name", "age", "qq"); 59         System.out.println(rsmap);   60    61         //刪除map中的某個索引值   62         jedis.hdel("user","age"); 63         System.out.println(jedis.hmget("user", "age")); //因為刪除了,所以返回的是null   64         System.out.println(jedis.hlen("user")); //返回key為user的鍵中存放的值的個數2  65         System.out.println(jedis.exists("user"));//是否存在key為user的記錄 返回true   66         System.out.println(jedis.hkeys("user"));//返回map對象中的所有key   67         System.out.println(jedis.hvals("user"));//返回map對象中的所有value  68    69         Iterator<String> iter=jedis.hkeys("user").iterator();   70         while (iter.hasNext()){   71             String key = iter.next();   72             System.out.println(key+":"+jedis.hmget("user",key));   73         }   74     } 75      76     /**  77      * jedis操作List  78      */   79     @Test   80     public void testList(){   81         //開始前,先移除所有的內容   82         jedis.del("java framework");   83         System.out.println(jedis.lrange("java framework",0,-1));   84         //先向key java framework中存放三條資料   85         jedis.lpush("java framework","spring");   86         jedis.lpush("java framework","struts");   87         jedis.lpush("java framework","hibernate");   88         //再取出所有資料jedis.lrange是按範圍取出,   89         // 第一個是key,第二個是起始位置,第三個是結束位置,jedis.llen擷取長度 -1表示取得所有   90         System.out.println(jedis.lrange("java framework",0,-1));   91          92         jedis.del("java framework"); 93         jedis.rpush("java framework","spring");   94         jedis.rpush("java framework","struts");   95         jedis.rpush("java framework","hibernate");  96         System.out.println(jedis.lrange("java framework",0,-1)); 97     }   98      99     /** 100      * jedis操作Set 101      */  102     @Test  103     public void testSet(){  104         //添加  105         jedis.sadd("user","liuling");  106         jedis.sadd("user","xinxin");  107         jedis.sadd("user","ling");  108         jedis.sadd("user","zhangxinxin");109         jedis.sadd("user","who");  110         //移除noname  111         jedis.srem("user","who");  112         System.out.println(jedis.smembers("user"));//擷取所有加入的value  113         System.out.println(jedis.sismember("user", "who"));//判斷 who 是否是user集合的元素  114         System.out.println(jedis.srandmember("user"));  115         System.out.println(jedis.scard("user"));//返回集合的元素個數  116     }  117   118     @Test  119     public void test() throws InterruptedException {  120         //jedis 排序  121         //注意,此處的rpush和lpush是List的操作。是一個雙向鏈表(但從表現來看的)  122         jedis.del("a");//先清除資料,再加入資料進行測試  123         jedis.rpush("a", "1");  124         jedis.lpush("a","6");  125         jedis.lpush("a","3");  126         jedis.lpush("a","9");  127         System.out.println(jedis.lrange("a",0,-1));// [9, 3, 6, 1]  128         System.out.println(jedis.sort("a")); //[1, 3, 6, 9]  //輸入排序後結果  129         System.out.println(jedis.lrange("a",0,-1));  130     }  131     132     @Test133     public void testRedisPool() {134         RedisUtil.getJedis().set("newname", "中文測試");135         System.out.println(RedisUtil.getJedis().get("newname"));136     }137 }

 

Redis串連池:

 1 package com.test; 2  3 import redis.clients.jedis.Jedis; 4 import redis.clients.jedis.JedisPool; 5 import redis.clients.jedis.JedisPoolConfig; 6  7 public final class RedisUtil { 8      9     //Redis伺服器IP10     private static String ADDR = "192.168.0.100";11     12     //Redis的連接埠號碼13     private static int PORT = 6379;14     15     //訪問密碼16     private static String AUTH = "admin";17     18     //可用串連執行個體的最大數目,預設值為8;19     //如果賦值為-1,則表示不限制;如果pool已經分配了maxActive個jedis執行個體,則此時pool的狀態為exhausted(耗盡)。20     private static int MAX_ACTIVE = 1024;21     22     //控制一個pool最多有多少個狀態為idle(閒置)的jedis執行個體,預設值也是8。23     private static int MAX_IDLE = 200;24     25     //等待可用串連的最大時間,單位毫秒,預設值為-1,表示永不逾時。如果超過等待時間,則直接拋出JedisConnectionException;26     private static int MAX_WAIT = 10000;27     28     private static int TIMEOUT = 10000;29     30     //在borrow一個jedis執行個體時,是否提前進行validate操作;如果為true,則得到的jedis執行個體均是可用的;31     private static boolean TEST_ON_BORROW = true;32     33     private static JedisPool jedisPool = null;34     35     /**36      * 初始化Redis串連池37      */38     static {39         try {40             JedisPoolConfig config = new JedisPoolConfig();41             config.setMaxActive(MAX_ACTIVE);42             config.setMaxIdle(MAX_IDLE);43             config.setMaxWait(MAX_WAIT);44             config.setTestOnBorrow(TEST_ON_BORROW);45             jedisPool = new JedisPool(config, ADDR, PORT, TIMEOUT, AUTH);46         } catch (Exception e) {47             e.printStackTrace();48         }49     }50     51     /**52      * 擷取Jedis執行個體53      * @return54      */55     public synchronized static Jedis getJedis() {56         try {57             if (jedisPool != null) {58                 Jedis resource = jedisPool.getResource();59                 return resource;60             } else {61                 return null;62             }63         } catch (Exception e) {64             e.printStackTrace();65             return null;66         }67     }68     69     /**70      * 釋放jedis資源71      * @param jedis72      */73     public static void returnResource(final Jedis jedis) {74         if (jedis != null) {75             jedisPool.returnResource(jedis);76         }77     }78 }

 

Java中使用Jedis操作Redis

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

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.