SpringBoot-Jedis缓存

本文介绍了如何在SpringBoot项目中集成Jedis作为缓存工具,并提供了添加依赖、配置文件、服务类的相关步骤。同时强调了使用Jedis时需要注意关闭连接,避免资源池异常。还提到了使用Java自带的序列化和反序列化方法。
摘要由CSDN通过智能技术生成

添加依赖

<!-- redis对象存储 -->
    <dependency>
      <groupId>redis.clients</groupId>
      <artifactId>jedis</artifactId>
      <version>2.9.0</version>
    </dependency>
    <dependency>
      <groupId>com.esotericsoftware</groupId>
      <artifactId>kryo</artifactId>
      <version>4.0.0</version>
    </dependency>

KryoSerializeUtil.java

import com.esotericsoftware.kryo.Kryo;
import com.esotericsoftware.kryo.io.Input;
import com.esotericsoftware.kryo.io.Output;

import java.io.ByteArrayOutputStream;
import java.io.IOException;

/**
 * 使用Kryo
 * 把java对象序列化和反序列化
 * 虽然所序列化和反序列化的类无需实现java.io.Serializable接口,
 * 但还是建议实现java.io.Serializable接口,避免类修改后无法反序列化
 */
public class KryoSerializeUtil {

 /**
  * 把java对象序列化成byte数组
  *
  * @param object
  * @return
  */
 public static byte[] serialize(Object object) {
 if (object == null) {
 return null;
 }
 ByteArrayOutputStream baos = null;
 Output output = null;
 try {
 Kryo kryo = new Kryo();
 baos = new ByteArrayOutputStream();
 output = new Output(baos);
 kryo.writeObject(output, object);
 output.flush();
 return baos.toByteArray();
 } finally {
 try {
 if (baos != null) baos.close();
 } catch (IOException e) {
 e.printStackTrace();
 }
 output.close();
 }
 }

 /**
  * 把byte数组反序列化得到java对象
  *
  * @param bytes
  * @param clazz
  * @return
  */
 public static <T> T unserialize(byte[] bytes, Class<T> clazz) {
 if (bytes == null || bytes.length == 0) {
 return null;
 }
 Kryo kryo = new Kryo();
 Input input = new Input(bytes);
 T obj = kryo.readObject(input, clazz);
 input.close();
 return obj;
 }
}

Redis配置文件

#redis配置开始
  redis:
   database: 0 # Redis数据库索引(默认为0)
   host: localhost # Redis服务器地址
   port: 6379 # Redis服务器连接端口
   password: 941218 # Redis服务器连接密码(默认为空)
   jedis:
    pool:
     max-active: 128 # 连接池最大连接数(使用负值表示没有限制)
     max-wait: 3000 # 连接池最大阻塞等待时间(使用负值表示没有限制)
     max-idle: 128 # 连接池中的最大空闲连接
     min-idle: 0 # 连接池中的最小空闲连接
   timeout: 5000 # 连接超时时间(毫秒)
   block-when-exhausted: true # 连接耗尽时是否阻塞, false报异常,ture阻塞直到超时, 默认true

RedisConfig.java

import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springf
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring Boot中,可以通过整合Jedis来使用Redis作为缓存或者消息队列。下面是整合Jedis的步骤: 1. 添加依赖:在`pom.xml`文件中添加Jedis的依赖。可以使用以下依赖配置: ```xml <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>3.6.0</version> </dependency> ``` 2. 配置Redis连接信息:在`application.properties`文件中配置Redis的连接信息,包括主机、端口、密码等。例如: ```properties spring.redis.host=127.0.0.1 spring.redis.port=6379 spring.redis.password= ``` 3. 创建Jedis连接池:在Spring Boot的配置类中创建Jedis连接池的Bean。可以使用以下代码示例: ```java import org.springframework.beans.factory.annotation.Value; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import redis.clients.jedis.JedisPool; import redis.clients.jedis.JedisPoolConfig; @Configuration public class RedisConfig { @Value("${spring.redis.host}") private String redisHost; @Value("${spring.redis.port}") private int redisPort; @Value("${spring.redis.password}") private String redisPassword; @Bean public JedisPool jedisPool() { JedisPoolConfig poolConfig = new JedisPoolConfig(); return new JedisPool(poolConfig, redisHost, redisPort, redisPassword); } } ``` 4. 使用Jedis进行操作:在需要使用Redis的地方,通过注入JedisPool对象并调用相应的方法来进行操作。例如: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; @Service public class RedisService { @Autowired private JedisPool jedisPool; public void set(String key, String value) { try (Jedis jedis = jedisPool.getResource()) { jedis.set(key, value); } } public String get(String key) { try (Jedis jedis = jedisPool.getResource()) { return jedis.get(key); } } } ``` 以上就是Spring Boot整合Jedis的基本步骤。通过配置Redis连接信息和使用JedisPool对象,可以方便地在Spring Boot项目中使用Redis
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值