目录
2.2.1 使用Jedis连接实例池:RedisUtil.java
1、Java中使用Jedis操作Redis-项目中常采用
1.1 项目结构
1.2 RedisUtils.java 类
package com.wind.ssm.javaRedis.test;
import org.springframework.stereotype.Component;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
import java.io.Serializable;
@Component
public class RedisUtils implements Serializable {
private static final long serialVersionUID = 7223626844967286296L;
private static JedisPool pool; //整个项目中只有这一个JedisPool
/**
* 池化思想:创建JedisPool对象(Jedis实例池)
*/
public static JedisPool openPool(String host, int port) {
if (pool == null) {
//(1)创建JedisPoolConfig,给config设置连接池的参数,使用config对象创建JedisPool
JedisPoolConfig poolConfig = new JedisPoolConfig();
//(2)给config对象设置连接池的参数
//(2.1)设置最大的线程数,一个线程就是一个Jedis实例
poolConfig.setMaxIdle(20);
//(2.2)设置最大空闲数,总有两个Jedis实例存活以便瞬时可以拿来使用
poolConfig.setMaxIdle(2);
//(2.3)设置检查项为true,表示从线程池中获取的Jedis实例都是经过检查的,都是可用的实例
poolConfig.setTestOnBorrow(true);
//(3)创建JedisPool对象
/**
* poolConfig:JedisPoolConfig对象
* host:Redis服务器IP地址
* port:Redis服务器进程的端口号
* timeout:连接Redis的超时时间,毫秒值
* password:Redis的访问密码
*/
pool = new JedisPool(poolConfig, host, port, 6000);
}
return pool;
}
/**
* 关闭pool池对象
*/
public static void closePool() {
if (pool != null) {
pool.close();
}
}
}
1.3 JRedisTest.java 类
package com.wind.ssm.javaRedis.test;
import org.springframework.stereotype.Component;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import java.io.Serializable;
import java.util.List;
import java.util.Objects;
@Component
public class JRedisTest implements Serializable {
private static final long serialVersionUID = -5396106851277887769L;
public static void main(String[] args) {
/**
* 通过网络访问Redis服务器:
*(1)修改redis.conf文件,启动Redis需要指定redis.conf的位置。
*(2)关闭linux防火墙,或者让Redis的端口号通过防火墙。
* (3)设置密码了吗
*/
JedisPool pool = null;
Jedis jedis = null;
try {
//使用工具类获取Jedis对象池
//String host:Redis服务器的IP。int port:Redis服务器进程运行的端口号。
String host = "127.0.0.1";
int port = 6382;
pool = RedisUtils.openPool(host, port);
//从pool中获取Jedis对象
jedis = pool.getResource();
//调用Jedis对象的方法,操作Redis数据
jedis.set("breakfast", "breakfastDouJiangAndYouTiao2");
//获取key的值
String breakfastValue = jedis.get("breakfast");
System.out.println("breakfastKey=breakfast,breakfastValue=" + breakfastValue);
//mset一次创建多个key-value
jedis.mset("lunch", "lunchMilk2", "dinner", "dinnerNoodle2");
//mget获取每个key对应的值
List<String> values = jedis.mget("breakfast", "lunch", "dinner");
values.stream().filter(Objects::nonNull).forEach(System.out::println);
} finally {
//关闭Jedis对象,把从pool中获取的Jedis对象放回到Pool池子中,以便其他请求使用
if (jedis != null) {
jedis.close();
}
//在这里关闭了Jedis对象的池子
if (pool != null) {
pool.close();
}
}
}
}
1.4 操作结果
(1)控制台输出:
(2)Redis服务器输出
2、Java中使用Jedis操作Redis-项目实战
2.0 项目中加入 jar包
● jedis-2.9.0.jar
● commons-pool2-2.4.2.jar
加入项目后如图:
2.1 字符串(string) 做测试
2.2 哈希(hash) 做测试
2.2.1 使用Jedis连接实例池:RedisUtil.java
2.2.2 使用Jedis连接池操作 hash 数据类型1
2.2.2 使用Jedis连接池操作 hash 数据类型2
2.3 列表 (list) 做测试
2.4 集合(Set) 做测试
2.5 有序集合(ZSet) 做测试
2.6 事务(Transaction) 做测试
3、参考文档
(1)动力节点Redis文档:http://www.bjpowernode.com/tutorial_redis/343.html