Redis 的两种实现方式(三)

第一种,直连java

package com.tx;

import java.util.Iterator;
import java.util.List;
import java.util.Set;

import redis.clients.jedis.Jedis;

public class redisjava {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		
		   Jedis jedis = new Jedis("localhost");
		   
	        System.out.println("连接成功");
	    	jedis.auth("123456");
	        //查看服务是否运行
	        System.out.println("服务正在运行: "+jedis.ping());
		
	        
	        
	        // String 设置 redis 字符串数据
	        jedis.set("runoobkey", "www.runoob.com");
	        // 获取存储的数据并输出
	        System.out.println("redis 存储的字符串为: "+ jedis.get("runoobkey"));
	        
	        // List  存储数据到列表中
	        jedis.lpush("site-list", "Runoob");
	        jedis.lpush("site-list", "Google");
	        jedis.lpush("site-list", "Taobao");
	        // 获取存储的数据并输出
	        List<String> list = jedis.lrange("site-list", 0 ,2);
	        for(int i=0; i<list.size(); i++) {
	            System.out.println("列表项为: "+list.get(i));
	        }
	        
	     // 获取数据并输出
	        Set<String> keys = jedis.keys("*"); 
	        Iterator<String> it=keys.iterator() ;   
	        while(it.hasNext()){   
	            String key = it.next();   
	            System.out.println(key);   
	        }
		
		

	}

}

第二种:加一个连接池,提前准备好,效率更高

package com.tx;
 
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
 
 
/**
 * @ClassName: RedisPool
 * @Description: 单机RedisPool使用
 * @author sam
 * @date 2015-5-22 下午1:53:04
 * @version V1.0
 */
public class JRedisPoolTest {
	  /**
	   * 非切片链接池
	   */
	  private JedisPool jedisPool;
 
	  private String ip = "127.0.0.1";
 
	  private String pwd = "123456";
	  /**
	   * 构造函数
	   */
	  public JRedisPoolTest() {
	    initialPool();
	  }
 
	  private void initialPool() {
	    // 池基本配置
	    JedisPoolConfig config = new JedisPoolConfig();
 
	    //是否启用后进先出, 默认true
	    config.setLifo(true);
	    //最大空闲连接数, 默认8个
	    config.setMaxIdle(8);
	    //最大连接数, 默认8个
	    config.setMaxTotal(8);
	    //获取连接时的最大等待毫秒数(如果设置为阻塞时BlockWhenExhausted),如果超时就抛异常, 小于零:阻塞不确定的时间,  默认-1
	    config.setMaxWaitMillis(-1);
	    //逐出连接的最小空闲时间 默认1800000毫秒(30分钟)
	    config.setMinEvictableIdleTimeMillis(1800000);
	    //最小空闲连接数, 默认0
	    config.setMinIdle(0);
	    //每次逐出检查时 逐出的最大数目 如果为负数就是 : 1/abs(n), 默认3
	    config.setNumTestsPerEvictionRun(3);
	    //对象空闲多久后逐出, 当空闲时间>该值 且 空闲连接>最大空闲数 时直接逐出,不再根据MinEvictableIdleTimeMillis判断  (默认逐出策略)
	    config.setSoftMinEvictableIdleTimeMillis(1800000);
	    //在获取连接的时候检查有效性, 默认false
	    config.setTestOnBorrow(false);
	    //在空闲时检查有效性, 默认false
	    config.setTestWhileIdle(false);
 
 
	    jedisPool = new JedisPool(config, ip, 6379);
 
	  }
 
	  private Jedis getResource(){
		  Jedis jedis = jedisPool.getResource();
		  jedis.auth(pwd);
		  return jedis;
	  }
 
	  /**
	   * @Description: 关闭连接
	   * @param jedis
	   */
	  private void returnResource(Jedis jedis){
		  if (jedis!=null) {
			  jedisPool.returnBrokenResource(jedis);
		}
	  }
 
 
	  //test
	  public static void main(String[] args) {
		JRedisPoolTest pool = new JRedisPoolTest();
		JRedisTest test = new JRedisTest();
		Jedis jedis = pool.getResource();
		test.setJedis(jedis);
		test.testString();
		pool.returnResource(jedis);
	}
 
}

方式一的另外一个demo

package com.tx;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import redis.clients.jedis.Jedis;
 
 
/**
 * @ClassName: JedisTest
 * @Description: Redis单机测试
 * @author sam
 * @version V1.0
 */
public class JRedisTest {
private Jedis jedis;
public Jedis getJedis() {
return jedis;
}
public void setJedis(Jedis jedis) {
this.jedis = jedis;
}
 
public void setup() {
// 连接redis服务器,192.168.0.100:6379
jedis = new Jedis("127.0.0.1", 6379);
// 权限认证
jedis.auth("123456");
System.out.println("服务正在运行: "+jedis.ping());
}
 
//测试
public static void main(String[] args) {
try {
JRedisTest test = new JRedisTest();
test.setup();
System.out.println("连接成功!");

test.testString();
 test.testList();
test.testMap();
 test.testSet();
test.testSortedSet();
} catch (Exception e) {
e.printStackTrace();
}
}
 
/**
* redis存储字符串
*/
public void testString() {
// -----添加数据----------
System.out.println("-----添加数据---------String-");
jedis.set("name", "honghong");// 向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", "476777389");
jedis.incr("age"); // 进行加1操作
System.out.println(jedis.get("name") + "-" + jedis.get("age") + "-" + jedis.get("qq"));
 
}


/**
* jedis操作List
*/
public void testList() {
System.out.println("-----添加数据---------List-");
//开始前,先移除所有的内容
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));
}
 
 
/**
* redis操作Map
*/
public void testMap() {
// -----添加数据----------
System.out.println("-----添加数据---------Hash-");
Map<String, String> map = new HashMap<String, String>();
map.put("name", "xinxin");
map.put("age", "21");
map.put("qq", "12345");
 
map.put("name", "xinxin2");
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操作Set
*/
public void testSet() {
System.out.println("-----添加数据---------Set-");
// 添加
jedis.sadd("userSet", "moqingxiong");
jedis.sadd("userSet", "xinxin");
jedis.sadd("userSet", "ling");
jedis.sadd("userSet", "zhangxinxin");
jedis.sadd("userSet", "who");
// 移除noname
jedis.srem("userSet", "who");
System.out.println(jedis.smembers("userSet"));// 获取所有加入的value
System.out.println(jedis.sismember("userSet", "who"));// 判断 who
// 是否是user集合的元素
System.out.println(jedis.srandmember("userSet"));
System.out.println(jedis.scard("userSet"));// 返回集合的元素个数
}
 
 
/**
* jedis操作Sorted Set
*/
private void testSortedSet() {
// -----添加数据----------
System.out.println("-----添加数据---------Sorted Set-");
// 清空数据
System.out.println(jedis.flushDB());
// 添加数据
jedis.zadd("zset", 10.1, "hello");
jedis.zadd("zset", 10.0, ":");
jedis.zadd("zset", 9.0, "zset");
jedis.zadd("zset", 11.0, "zset!");
// 元素个数
System.out.println(jedis.zcard("zset"));
// 元素下标
System.out.println(jedis.zscore("zset", "zset"));
// 集合子集
System.out.println(jedis.zrange("zset", 0, -1));
// 删除元素
System.out.println(jedis.zrem("zset", "zset!"));
System.out.println(jedis.zcount("zset", 9.5, 10.5));
// 整个集合值
System.out.println(jedis.zrange("zset", 0, -1));
}
 
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));
}
 
}

四:项目结构如下:参考姚hp的视频

发布了149 篇原创文章 · 获赞 8 · 访问量 7万+

猜你喜欢

转载自blog.csdn.net/bluewelkin/article/details/102787984