java中在项目中用到的缓存_如何在java项目中操作Redis缓存

如何在java项目中操作Redis缓存

发布时间:2020-12-02 17:25:10

来源:亿速云

阅读:96

作者:Leah

这篇文章给大家介绍如何在java项目中操作Redis缓存,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

1.导入必须的Jar包

使用Java操作Redis需要两个必须的Jar包:jedis-2.5.1.jar 和  commons-pool2-2.0.jar 。每个版本可以不一样,根据你自己下载的为准。

2.实现RedisUtils工具类

把连接Redis服务器的代码封装到一个工具类里面,这样就可以直接调用攻击类来获取Redis的服务。

RedisUtils工具类代码如下:  以下代码和网上其他的实现类大同小异,其实这个没什么创新的东西。

下面代码需要注意的地方:config.setMaxTotal(MAX_TOTAL); 由于我的jedis版本是2.5的,所有没有setMaxActive这个方法。

public class RedisUtils {

//Redis服务器IP

private static String ADDR = "192.168.125.130";

//Redis的端口号

private static int PORT = 6379;

//访问密码,若你的redis服务器没有设置密码,就不需要用密码去连接

private static String AUTH = "123456";

//可用连接实例的最大数目,默认值为8;

private static int MAX_TOTAL = 512;

//控制一个pool最多有多少个状态为idle(空闲的)的jedis实例,默认值也是8。

private static int MAX_IDLE = 50;

//等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。

private static int MAX_WAIT = 10000;

private static int TIMEOUT = 10000;

//在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的;

private static boolean TEST_ON_BORROW = true;

private static JedisPool jedisPool = null;

/**

* 初始化Redis连接池

*/

static {

try {

JedisPoolConfig config = new JedisPoolConfig();

config.setMaxTotal(MAX_TOTAL);

config.setMaxIdle(MAX_IDLE);

config.setMaxWaitMillis(MAX_WAIT);

config.setTestOnBorrow(TEST_ON_BORROW);

jedisPool = new JedisPool(config, ADDR, PORT, TIMEOUT, AUTH);

} catch (Exception e) {

e.printStackTrace();

}

}

/**

* 获取Jedis实例

* @return

*/

public synchronized static Jedis getJedis() {

try {

if (jedisPool != null) {

Jedis jedis = jedisPool.getResource();

return jedis;

} else {

return null;

}

} catch (Exception e) {

e.printStackTrace();

return null;

}

}

/**

* 释放jedis资源

* @param jedis

*/

public static void returnResource(final Jedis jedis) {

if (jedis != null) {

jedisPool.returnResource(jedis);

}

}

}

3.进行Redis测试

接下来就可以进行测试了。一般我们都是用Junit测试工具来测试:测试部分代码如下

@Test

public void testRedisPool() {

RedisUtils.getJedis().set("xiaomin", ”12122“);

System.out.println(RedisUtils2.getJedis().get("xiaomin"));

}

关于如何在java项目中操作Redis缓存就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

当使用Spring Boot项目时,你可以使用Redis作为缓存或数据存储的解决方案。以下是一个示例,展示了如何在Spring Boot项目使用Redis集合存储数据: 1. 首先,确保你的Spring Boot项目已经添加了Redis依赖。在pom.xml文件添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> ``` 2. 在application.properties或application.yml文件配置Redis连接信息。例如: ```yaml spring.redis.host=localhost spring.redis.port=6379 ``` 3. 创建一个Redis配置类,用于配置Redis连接和操作。在该类上使用`@Configuration`注解,并添加`@EnableCaching`注解启用缓存。 ```java import org.springframework.cache.annotation.EnableCaching; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.data.redis.connection.RedisConnectionFactory; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.data.redis.serializer.StringRedisSerializer; @Configuration @EnableCaching public class RedisConfig { @Bean public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) { RedisTemplate<String, Object> template = new RedisTemplate<>(); template.setConnectionFactory(redisConnectionFactory); template.setKeySerializer(new StringRedisSerializer()); template.setHashKeySerializer(new StringRedisSerializer()); template.setValueSerializer(new GenericJackson2JsonRedisSerializer()); template.setHashValueSerializer(new GenericJackson2JsonRedisSerializer()); return template; } } ``` 4. 创建一个服务类,用于操作Redis集合存储数据。在该类注入RedisTemplate,并使用`opsForSet()`方法获取集合操作对象。 ```java import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Service; import javax.annotation.Resource; import java.util.Set; @Service public class RedisSetService { @Resource private RedisTemplate<String, Object> redisTemplate; public void addToSet(String key, Object value) { redisTemplate.opsForSet().add(key, value); } public Set<Object> getSet(String key) { return redisTemplate.opsForSet().members(key); } public void removeFromSet(String key, Object value) { redisTemplate.opsForSet().remove(key, value); } } ``` 这样,你就可以在其他组件或服务使用`RedisSetService`类来操作Redis集合数据了。例如: ```java @Service public class ExampleService { @Resource private RedisSetService redisSetService; public void example() { String setKey = "mySet"; redisSetService.addToSet(setKey, "value1"); redisSetService.addToSet(setKey, "value2"); Set<Object> setValues = redisSetService.getSet(setKey); System.out.println("Set values: " + setValues); redisSetService.removeFromSet(setKey, "value1"); setValues = redisSetService.getSet(setKey); System.out.println("Updated set values: " + setValues); } } ``` 这是一个简单的示例,展示了如何在Spring Boot项目使用Redis集合存储数据。你可以根据自己的需求进行相应的修改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值