簡單的工程
RedisJavaDemo使用maven來構建項目,pom配置
<!-- https://mvnrepository.com/artifact/redis.clients/jedis -->
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>2.9.0</version>
</dependency>
代碼如下:
package com.sima.redis;
import redis.clients.jedis.Jedis;
import java.util.Iterator;
import java.util.Set;
/**
* Hello world!
*
*/
public class App
{
public static void main( String[] args )
{
System.out.println( "Hello World!" );
//連接本地的 Redis 服務
Jedis jedis = new Jedis("225.100.212.123");
//設置密碼
jedis.auth("123123");
//查看服務是否運行
System.out.println("服務正在運行: "+jedis.ping());
//設置 redis 字符串數據
jedis.set("foo", "Hello World!");
// 獲取存儲的數據并輸出
System.out.println("redis 存儲的字符串為: "+ jedis.get("foo"));
}
}
運行結果
補充
- List存儲
//存儲數據到列表中
jedis.lpush("mylist", "maple1");
jedis.lpush("mylist", "maple2");
jedis.lpush("mylist", "maple3");
// 獲取存儲的數據并輸出
List<String> list = jedis.lrange("site-list", 0 ,2);
for(int i=0; i<list.size(); i++) {
System.out.println("列表項為: "+list.get(i));
}
- 獲取所有的key
// 獲取數據并輸出
Set<String> keys = jedis.keys("*");
Iterator<String> it=keys.iterator() ;
while(it.hasNext()){
String key = it.next();
System.out.println(key);
}
Redis連接池
package com.sima.redis;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
/**
* Created by maple on 2017-08-10.
*/
public class RedisUtils {
//Redis服務器IP
private static String ADDR = "225.100.212.123";
//Redis的端口號
private static int PORT = 6379;
//訪問密碼
private static String AUTH = "123123";
//可用連接實例的最大數目,默認值為8;
//如果賦值為-1,則表示不限制;如果pool已經分配了maxActive個jedis實例,則此時pool的狀態為exhausted(耗盡)。
private static int MAX_TOTAL = 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 {
JedisPoolConfig config = new JedisPoolConfig();
config.setMaxTotal(MAX_TOTAL);
config.setMaxIdle(MAX_IDLE);
config.setMaxWaitMillis(MAX_WAIT);
config.setTestOnBorrow(TEST_ON_BORROW);
jedisPool = new JedisPool(config, ADDR, PORT, TIMEOUT, AUTH);
}
/**
* 獲取Jedis實例
*/
public synchronized static Jedis getJedis(){
if (jedisPool != null){
Jedis jedis = jedisPool.getResource();
return jedis;
}else {
return null;
}
}
/**
* 釋放Jedis資源
*/
public static void close(Jedis jedis){
if (jedis != null){
jedis.close();
}
}
}
package com.sima.redis;
import redis.clients.jedis.Jedis;
/**
* Created by maple on 2017-08-10.
*/
public class AppByUtil {
public static void main( String[] args ){
Jedis jedis = RedisUtils.getJedis();
System.out.println("redis 存儲的字符串為: " + jedis.get("foo"));
RedisUtils.close(jedis);
}
}
注意點
在實際項目運用中,發下Jedis的方法調用失敗后,在控制臺并沒有報異常錯誤,所有需要代碼try-catch一下。