redis实现抽奖功能
redis实现抽奖功能,利用redis中的set数据结构的特点,里面数据不是按照顺序进行排序的,所以拿里面的数据是随机的
·
- redis实现抽奖功能,利用redis中的set数据结构的特点,里面数据不是按照顺序进行排序的,所以拿里面的数据是随机的
- 首先我们先初始化一下RedisTemplate,这个是操作redis的第三方库,我们先要对他初始化一下(重新序列化)
- 先把StringRedisTemplate注入进来,这里有人会用RedisTemplate可能会报错,可能是序列化的问题,私下百度一下就行了
@Autowired
private StringRedisTemplate stringRedisTemplate;
@Configuration
public class RedisConfig {
@Bean
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory connectionFactory) {
RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
redisTemplate.setConnectionFactory(connectionFactory);
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setValueSerializer(new StringRedisSerializer());
redisTemplate.setHashKeySerializer(new StringRedisSerializer());
// 这个地方不可使用 json 序列化,如果使用的是ObjectRecord传输对象时,可能会有问题,会出现一个 java.lang.IllegalArgumentException: Value must not be null! 错误
redisTemplate.setHashValueSerializer(RedisSerializer.string());
return redisTemplate;
}
}
- 然后我们就可以用@Autowired进行注入到spring容器中使用了,这里我将方法都放在一个类中,用作与测试的
/**
* 用redis中的set数据结构模拟抽奖的功能
*
* 因为set数据结构里面的数据不是按照顺序进行排序的,所以随机pop是随机一个数字
*/
@RequestMapping("set")
public int redisSet() {
// 将数据放到redis中
depositValue();
String string = redisTemplate.opsForSet().pop("pop_user").toString();
LOGGER.info("幸运儿是:{}",string);
return Integer.parseInt(string);
}
private void depositValue() {
// 初始化先把员工放进redis中的容器当中
List<Integer> integers = initUser();
Boolean aBoolean = redisTemplate.hasKey("pop_user");
if (!aBoolean){
// 这里有一个data.toString()注意一下,知道的小伙伴可以留个言哦
integers.forEach(data -> redisTemplate.opsForSet().add("pop_user",data.toString()));
}
}
/**
* 初始化员工,用Integer代替员工实体类
* 模拟100个员工进行抽奖
* @return
*/
private static List<Integer> initUser() {
// 因为我确定是100个人,所以直接给集合一个初始化100,节约内存的消耗
List<Integer> list = new ArrayList<>(100);
for (int i = 0; i < 100; i++) {
list.add(i+1);
}
return list;
}
- 最后我测试,我这里只是一个测试
- 最后发现redis中的数据
因为已经被pop出去了,所以抽中了以后,redis中的数据就被删除了
到这里就结束了
更多推荐
已为社区贡献3条内容
所有评论(0)