第一种,直连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的视频