一、客户端 Jedis
1、Jedis
Jedis 是一款java操作 redis 数据库的工具。
2、使用步骤
(1)下载 Jedis 的 jar 包
(2)使用:
1 //1. 获取连接
2 Jedis jedis = new Jedis("localhost",6379); // 可以使用空参构造,默认值"localhost",6379端口3
4 //2. 操作
5 jedis.set("username","zhangsan");6
7 //3. 关闭连接
8 jedis.close();
二、Jedis 操作各种 redis 中的数据结构
1、操作字符串类型 String
使用的方法同 redis 里面的方法。
Demo:
1 //1. 获取连接
2 Jedis jedis = new Jedis();3 //2. 操作4 //存储
5 jedis.set("username","zhangsan");6 //获取
7 String username = jedis.get("username");8 System.out.println(username);9
10 //可以使用setex()方法存储可以指定过期时间的 key value
11 jedis.setex("activecode",20,"asdf");//将activecode:asdf键值对存入redis,并且20秒后自动删除该键值对12
13 //3. 关闭连接
14 jedis.close();
2、操作哈希类型 hash:map格式
使用的方法:hset、hget、hgetall
Demo:
1 //1. 获取连接
2 Jedis jedis = new Jedis();3 //2. 操作4 //存储hash
5 jedis.hset("user","name","lisi");6 jedis.hset("user","age","23");7 jedis.hset("user","sex","man");8
9 //获取hash
10 String name = jedis.hget("user", "name");11 System.out.println(name);12
13
14 //获取hash的所有map中的数据
15 Map user = jedis.hgetAll("user");16
17 //keyset
18 Set keySet =user.keySet();19 for(String key : keySet) {20 //获取value
21 String value =user.get(key);22 System.out.println(key + ":" +value);23 }24
25 //3. 关闭连接
26 jedis.close();
3、操作列表类型 list:linkedlist 格式。支持重复元素。
常用方法:lpush、lpush、lpop、rpop、lrange start end。
Demo:
1 //1. 获取连接
2 Jedis jedis = new Jedis();3 //2. 操作4 //list 存储
5 jedis.lpush("mylist","a","b","c");//从左边存
6 jedis.rpush("mylist","a","b","c");//从右边存7
8 //list 范围获取
9 List mylist = jedis.lrange("mylist", 0, -1);10 System.out.println(mylist);11
12 //list 弹出
13 String element1 = jedis.lpop("mylist");//c
14 System.out.println(element1);15
16 String element2 = jedis.rpop("mylist");//c
17 System.out.println(element2);18
19 //list 范围获取
20 List mylist2 = jedis.lrange("mylist", 0, -1);21 System.out.println(mylist2);22
23 //3. 关闭连接
24 jedis.close();
4、操作集合类型 set:不允许重复元素
常用方法:sadd、smembers。
Demo:
1 //1. 获取连接
2 Jedis jedis = newJedis();3
4 //2. 操作5 //set 存储
6 jedis.sadd("myset","java","php","c++");7
8 //set 获取
9 Set myset = jedis.smembers("myset");10 System.out.println(myset);11
12 //3. 关闭连接
13 jedis.close();
5、操作有序集合类型 sortedset:不允许重复元素,且元素有序。
常用方法:zadd、zrange。
Demo:
1 //1. 获取连接
2 Jedis jedis = newJedis();3 //2. 操作4 //sortedset 存储
5 jedis.zadd("mysortedset",3,"亚瑟");6 jedis.zadd("mysortedset",30,"后裔");7 jedis.zadd("mysortedset",55,"孙悟空");8
9 //sortedset 获取
10 Set mysortedset = jedis.zrange("mysortedset", 0, -1);11
12 System.out.println(mysortedset);13
14
15 //3. 关闭连接
16 jedis.close();
三、Jedis 连接池:JedisPool
1、使用步骤
(1)创建一个配置对象
(2)创建一个 JedisPool 连接池对象
(3)调用方法 getResource() 方法获取 Jedis 连接
(4)使用连接
(5)关闭连接,把连接归还到连接池中
2、代码实现
代码实现:
1 //1.创建一个配置对象
2 JedisPoolConfig config = newJedisPoolConfig();3 config.setMaxTotal(50); //设置最大连接数
4 config.setMaxIdle(10); //设置最大空闲数5
6 //2.创建Jedis连接池对象
7 JedisPool jedisPool = new JedisPool(config,"localhost",6379);8
9 //3.获取连接
10 Jedis jedis =jedisPool.getResource();11 //4. 使用
12 jedis.set("hehe","heihei");13
14
15 //5. 关闭 归还到连接池中
16 jedis.close();;
四、连接池工具类
在上面的代码中,将一些配置信息放入了代码中,但是这样并不有利于配置信息的修改,可以将配置信息单独放入一个文件中,然后读取该文件的内容即可。
jedis 详细配置说明:
1 #最大活动对象数2 redis.pool.maxTotal=10003 #最大能够保持idel状态的对象数4 redis.pool.maxIdle=1005 #最小能够保持idel状态的对象数6 redis.pool.minIdle=507 #当池内没有返回对象时,最大等待时间8 redis.pool.maxWaitMillis=100009 #当调用borrow Object方法时,是否进行有效性检查10 redis.pool.testOnBorrow=true11 #当调用return Object方法时,是否进行有效性检查12 redis.pool.testOnReturn=true13 #“空闲链接”检测线程,检测的周期,毫秒数。如果为负值,表示不运行“检测线程”。默认为-1.14 redis.pool.timeBetweenEvictionRunsMillis=3000015 #向调用者输出“链接”对象时,是否检测它的空闲超时;16 redis.pool.testWhileIdle=true17 # 对于“空闲链接”检测线程而言,每次检测的链接资源的个数。默认为3.18 redis.pool.numTestsPerEvictionRun=5019 #redis服务器的IP20 redis.ip=xxxxxx21 #redis服务器的Port22 redis1.port=6379
jedis.properties 文件
1 host=127.0.0.12 port=63793 maxTotal=504 maxIdle=10
jedis 连接池工具类
1 importredis.clients.jedis.Jedis;2 importredis.clients.jedis.JedisPool;3 importredis.clients.jedis.JedisPoolConfig;4
5 importjava.io.IOException;6 importjava.io.InputStream;7 importjava.util.Properties;8
9 /**
10 JedisPool工具类11 加载配置文件,配置连接池的参数12 提供获取连接的方法13
14 */
15 public classJedisPoolUtils {16
17 private staticJedisPool jedisPool;18
19 static{20 //读取配置文件
21 InputStream is = JedisPoolUtils.class.getClassLoader().getResourceAsStream("jedis.properties");22 //创建Properties对象
23 Properties pro = newProperties();24 //关联文件
25 try{26 pro.load(is);27 } catch(IOException e) {28 e.printStackTrace();29 }30 //获取数据,设置到JedisPoolConfig中
31 JedisPoolConfig config = newJedisPoolConfig();32 config.setMaxTotal(Integer.parseInt(pro.getProperty("maxTotal")));33 config.setMaxIdle(Integer.parseInt(pro.getProperty("maxIdle")));34
35 //初始化JedisPool
36 jedisPool = new JedisPool(config,pro.getProperty("host"),Integer.parseInt(pro.getProperty("port")));37
38
39 }40
41
42 /**
43 * 获取连接方法44 */
45 public staticJedis getJedis(){46 returnjedisPool.getResource();47 }48 }