Redis 学习(四)Jedis使用

上篇文章说明了redis 集群、分片的几种方式。一般的数据和流量不高的项目用一个redis做缓存或者分片基本能够满足需求。

下面就针对jedis做一个简单demo。

1、准备jedis环境

<dependencies>
		<!-- jedis 客户端 目前到2.8.X start -->
		<dependency>
			<groupId>redis.clients</groupId>
			<artifactId>jedis</artifactId>
			<version>2.7.0</version>
		</dependency>
		<!-- jedis 客户端 end -->
		<dependency>
			<groupId>com.google.code.gson</groupId>
			<artifactId>gson</artifactId>
			<version>2.2.4</version>
		</dependency>
	</dependencies>
2、jedis支持连接池和分片连接池  
JedisPool

import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
/**
 * redis连接池
 * @author yangfenge
 * 2016年6月2日
 */
public class RedisPool {
	private static JedisPool pool;
	
	/**
	 * 创建连接池
	 * @param host redis机器地址
	 * @param port redis机器端口
	 */
	private static void createJedisPool(String host,int port){
		JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
		// 设置最大连接数
		jedisPoolConfig.setMaxTotal(100);
		// 设置最大阻塞时间,记住是毫秒数milliseconds
		jedisPoolConfig.setMaxWaitMillis(1000);
        // 设置空间连接
		jedisPoolConfig.setMaxIdle(10);
        // 创建连接池
        pool = new JedisPool(jedisPoolConfig, host, port);
	}
	/**
	 * 同步初始化连接池,防止多线程调用重复创建
	 * @param host redis机器地址
	 * @param port redis机器端口
	 */
	public static synchronized JedisPool GetIntance(String host,int port){
		if (pool==null) {
			createJedisPool(host,port);
		}
		return pool;
	}
	
}
ShardJedisPool

/**
 * redis分片连接池
 * @author yangfenge
 * 2016年6月2日
 */
public class RedisShardPool {
	private static ShardedJedisPool pool;
	
	/**
	 * 创建分片连接池
	 * @param confs 分片的各个机器配置
	 */
	private static void createJedisPool(List<Map<String, Integer>> confs){
		JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
		// 设置最大连接数
		jedisPoolConfig.setMaxTotal(100);
		// 设置最大阻塞时间,记住是毫秒数milliseconds
		jedisPoolConfig.setMaxWaitMillis(1000);
        // 设置空间连接
		jedisPoolConfig.setMaxIdle(10);
		List<JedisShardInfo> jedisShardInfos = new ArrayList<JedisShardInfo>();
		for (Map<String, Integer> item : confs) {
			Set<Entry<String, Integer>> conf = item.entrySet();
			for (Entry<String, Integer> entry : conf) {
				JedisShardInfo jedisShardInfo = new JedisShardInfo(entry.getKey(), entry.getKey());
				jedisShardInfos.add(jedisShardInfo);
				break;
			}
		}
        // 创建连接池
        pool = new ShardedJedisPool(jedisPoolConfig,jedisShardInfos);
	}
	/**
	 * 同步初始化连接池,防止多线程调用重复创建
	 * @param confs 分片的各个机器配置
	 */
	public static synchronized ShardedJedisPool GetIntance(List<Map<String, Integer>> confs){
		if (pool==null) {
			createJedisPool(confs);
		}
		return pool;
	}
	
}
3、jedis客户端和jedis分片客户端

JedisClient

/**
 * redis客户端
 * 
 * @author yangfenge 2016年6月2日
 */
public class JedisClient {
	private static JedisPool pool;

	/**
	 * 获取redis客户端jedis
	 * 
	 * @param host
	 * @param port
	 * @return
	 */
	public static Jedis GetIntance(String host, int port) {
		pool = RedisPool.GetIntance(host, port);
		return pool.getResource();
	}

	/**
	 * 释放redis客户端jedis
	 * 
	 * @param host
	 * @param port
	 * @return
	 */
	public static void ReturnJedisToPool(Jedis jedis) {
		pool.returnResourceObject(jedis);
	}
}
JedisShardClient

/**
 * redis分片客户端
 * 
 * @author yangfenge 2016年6月2日
 */
public class JedisShardClient {
	private static ShardedJedisPool pool;

	/**
	 * 获取redis分片客户端jedis
	 * 
	 * @param host
	 * @param port
	 * @return
	 */
	public static ShardedJedis GetIntance(List<Map<String, Integer>> confs) {
		pool = RedisShardPool.GetIntance(confs);
		return pool.getResource();
	}

	/**
	 * 释放redis客户端分片jedis
	 * 
	 * @param host
	 * @param port
	 * @return
	 */
	public static void ReturnJedisToPool(ShardedJedis jedis) {
		pool.returnResourceObject(jedis);
	}
}





使用JedisPool来管理Redis连接池,可以按照以下步骤操作: 1. 首先,确保你已经将Jedis库添加到你的项目中。你可以在Maven或Gradle的配置文件中添加以下依赖: ```xml <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>版本号</version> </dependency> ``` 2. 在代码中导入JedisJedisPool相关的类: ```java import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; import redis.clients.jedis.JedisPoolConfig; ``` 3. 创建JedisPoolConfig对象,并设置连接池的相关属性(如最大连接数、最大空闲连接数等): ```java JedisPoolConfig jedisPoolConfig = new JedisPoolConfig(); jedisPoolConfig.setMaxTotal(100); // 设置最大连接数 jedisPoolConfig.setMaxIdle(10); // 设置最大空闲连接数 // 可以根据需要设置其他属性,比如最小空闲连接数、连接超时时间等 ``` 4. 创建JedisPool对象,传入Redis服务器的主机名、端口号、连接超时时间和密码(如果有的话): ```java JedisPool jedisPool = new JedisPool(jedisPoolConfig, "localhost", 6379, 10000, "password"); ``` 注意:如果Redis服务器没有设置密码,可以省略密码参数。 5. 从连接池中获取Jedis对象,并使用Jedis对象进行Redis操作: ```java try (Jedis jedis = jedisPool.getResource()) { // 执行Redis操作,如存储键值对 jedis.set("key", "value"); String value = jedis.get("key"); System.out.println(value); } catch (Exception e) { // 异常处理 } ``` 6. 当不再需要使用Redis连接时,记得将Jedis对象还回连接池: ```java jedis.close(); ``` 这就是使用JedisPool来管理Redis连接池的基本步骤。通过合理配置连接池的属性,可以提高Redis操作的性能和效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值