【java】Jedis的基本使用
- 1. Jedis的快速入门
- 2. Jedis操作各种redis中的数据结构
- 2.1 字符串类型 string
- 2.2 哈希类型 hash : map格式
- 2.3 列表类型 list : linkedlist格式。支持重复元素
- 2.4 集合类型 set : 不允许重复元素
- 2.5 有序集合类型 sortedset:不允许重复元素,且元素有顺序
- 3. jedis连接池: JedisPool
1. Jedis的快速入门
- Jedis: 一款java操作redis数据库的工具.
- 使用步骤:
- 下载jedis的jar包
- 使用
@Test
public void test1(){
Jedis jedis = new Jedis("127.0.0.1",6379);
jedis.set("username","123");
jedis.close();
}
2. Jedis操作各种redis中的数据结构
2.1 字符串类型 string
@Test
public void test2(){
Jedis jedis = new Jedis("127.0.0.1",6379);
jedis.set("username","123");
String username = jedis.get("username");
System.out.println(username);
jedis.setex("activecode",20,"hehe");
jedis.close();
}
2.2 哈希类型 hash : map格式
@Test
public void test3(){
Jedis jedis = new Jedis("127.0.0.1",6379);
jedis.hset("user","name","lisi");
jedis.hset("user","age","23");
jedis.hset("user","gender","male");
String name = jedis.hget("user", "name");
System.out.println(name);
Map<String, String> user = jedis.hgetAll("user");
Set<String> keySet = user.keySet();
for (String s : keySet) {
System.out.println(s+":"+user.get(s));
}
jedis.close();
}
2.3 列表类型 list : linkedlist格式。支持重复元素
@Test
public void test4(){
Jedis jedis = new Jedis();
jedis.lpush("mylist","a","b","c");
jedis.rpush("mylist","a","b","c");
List<String> mylist = jedis.lrange("mylist", 0, -1);
System.out.println(mylist);
String element1 = jedis.lpop("mylist");
System.out.println(element1);
String element2 = jedis.rpop("mylist");
System.out.println(element2);
List<String> mylist2 = jedis.lrange("mylist", 0, -1);
System.out.println(mylist2);
jedis.close();
}
2.4 集合类型 set : 不允许重复元素
@Test
public void test5(){
Jedis jedis = new Jedis("127.0.0.1",6379);
jedis.sadd("myset","java","php","C++");
Set<String> myset = jedis.smembers("myset");
System.out.println(myset);
jedis.close();
}
2.5 有序集合类型 sortedset:不允许重复元素,且元素有顺序
@Test
public void test6(){
Jedis jedis = new Jedis("127.0.0.1",6379);
jedis.zadd("mysortedset",99,"C++");
jedis.zadd("mysortedset",30,"java");
jedis.zadd("mysortedset",25,"php");
Set<String> mysortedset = jedis.zrange("mysortedset", 0, -1);
System.out.println(mysortedset);
jedis.close();
}
3. jedis连接池: JedisPool
- 使用:
1. 创建JedisPool连接池对象
2. 调用方法 getResource()方法获取Jedis连接
@Test
public void test7(){
JedisPoolConfig config = new JedisPoolConfig();
config.setMaxTotal(50);
config.setMaxIdle(10);
JedisPool jedisPool = new JedisPool(config,"localhost",6379);
Jedis jedis = jedisPool.getResource();
jedis.set("hehe","haha");
jedis.close();
}
3.1 连接池工具类
#最大活动对象数
redis.pool.maxTotal=1000
#最大能够保持idel状态的对象数
redis.pool.maxIdle=100
#最小能够保持idel状态的对象数
redis.pool.minIdle=50
#当池内没有返回对象时,最大等待时间
redis.pool.maxWaitMillis=10000
#当调用borrow Object方法时,是否进行有效性检查
redis.pool.testOnBorrow=true
#当调用return Object方法时,是否进行有效性检查
redis.pool.testOnReturn=true
#“空闲链接”检测线程,检测的周期,毫秒数。如果为负值,表示不运行“检测线程”。默认为-1.
redis.pool.timeBetweenEvictionRunsMillis=30000
#向调用者输出“链接”对象时,是否检测它的空闲超时;
redis.pool.testWhileIdle=true
# 对于“空闲链接”检测线程而言,每次检测的链接资源的个数。默认为3.
redis.pool.numTestsPerEvictionRun=50
#redis服务器的IP
redis.ip=xxxxxx
#redis服务器的Port
redis1.port=6379
package cn.siyi.jedis.util;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;
public class JedisPoolUtils {
private static JedisPool jedisPool;
static{
InputStream is = JedisPoolUtils.class.getClassLoader().getResourceAsStream("jedis.properties");
Properties pro = new Properties();
try {
pro.load(is);
} catch (IOException e) {
e.printStackTrace();
}
JedisPoolConfig config = new JedisPoolConfig();
config.setMaxTotal(Integer.parseInt(pro.getProperty("maxTotal")));
config.setMaxTotal(Integer.parseInt(pro.getProperty("maxIdle")));
jedisPool = new JedisPool(config,pro.getProperty("host"),Integer.parseInt(pro.getProperty("port")));
}
public static Jedis getJedis(){
return jedisPool.getResource();
}
}