redisPool使用

Jedis jedis = jedisPool.getResource();
jedis.select(4);
jedis.hset(key, "id", id);
jedis.hset(key, "username", username);
jedis.hset(key, "password", password);

其中jedis.select(4);是选择第4个数据库,redis默认9个数据库;

 

现在redisPool获取jedis插入数据后,java代码能获取到数据,但是在服务器客户端查询不到?


        
	Jedis jedis = jedisPool.getResource();
		try {
			String key = MD5.encode(id + userInfoBean.hashCode());
			Cookie userCookie = new Cookie("remember", key);
			userCookie.setMaxAge(60 * 60 * 24 * 3);
			// 将用户信息加密,存入redis
			String name = userInfoBean.getUsername();
			String password = userInfoBean.getPassword();
			String username = SymmetricEncoder.AESEncode(id, name);
			if (flag == null || flag != 1) {
				password = SymmetricEncoder.AESEncode(name, password);
			}
			jedis.select(4);//选择存入哪个库,redis.conf中默认有16个库,所以获取的时候也要选择存入的库中
			jedis.hset(key, "id", id);
				jedis.hset(key, "username", username);
				jedis.hset(key, "password", password);
			// 设置过期时间为3天
			jedis.expire(key, 60 * 60 * 24 * 3);
			// 将密钥放入cookie
			response.addCookie(userCookie);
			return true;
		} catch (Exception e) {
			throw new RuntimeException(e);
		} finally {
			jedis.close();
		}

重点是当时选择了第4个库,但是取的时候没有从第4个库中取!!!!!!!!!!!!!!!

jedis.select(4);//选择存入哪个库,redis.conf中默认有16个库,所以获取的时候也要选择存入的库中

使用JedisPool来管理Redis连接池,可以按照以下步骤操作: 1. 首先,确保你已经将Jedis库添加到你的项目中。你可以在Maven或Gradle的配置文件中添加以下依赖: ```xml <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>版本号</version> </dependency> ``` 2. 在代码中导入Jedis和JedisPool相关的类: ```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、付费专栏及课程。

余额充值