redis查询keys报错的实现
ERR unknown command keys
切换redis后发现keys命令出现报错,经查询原因如下:
原因可能是:keys命令用于全局查询 一般不建议使用所以能在redis.conf中配置了置换该命令
解决方案: 检查redis.conf 中是否有该命令禁用配置
rename-command FLUSHALL "" 清空所有的库数据
rename-command FLUSHDB "" 清空当前库数据
rename-command KEYS "" 查询所有库数据 (因为数据量大时 执行此操作会消耗大量的资源 一般不建议使用该命令)
如果有注释掉即可
但是因为使用的是统一部署的redis,无法进行修改操作,于是只好修改涉及kes命令的操作
使用scan获取redisKey
@Autowired
public RedisTemplate redisTemplate;
public Set<String> scan(String matchKey) {
Set<String> keys = new HashSet<>();
ScanOptions scanOptions = ScanOptions.scanOptions().match(matchKey).count(1000).build();
Cursor<byte[]> cursor = (Cursor<byte[]>) redisTemplate.execute(redisConnection -> redisConnection.scan(scanOptions), true);
RedisSerializer redisSerializer = redisTemplate.getKeySerializer();
while (cursor.hasNext()) {
keys.add(String.valueOf(redisSerializer.deserialize(cursor.next())));
}
return keys;
}到此这篇关于redis查询keys报错的实现的文章就介绍到这了,更多相关redis查询keys报错内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
一文搞懂阿里云服务器部署Redis并整合Spring Boot
这篇文章主要介绍了一文搞懂阿里云服务器部署Redis并整合Spring Boot,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下2022-09-09
Redis中3种特殊的数据类型(BitMap、Geo和HyperLogLog)
这篇文章主要给大家介绍了关于Redis中3种特殊的数据类型(BitMap、GEOADD和GEODIST)的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。2018-03-03
Redis SETNX命令在Spring Cloud中的分布式锁用法详解
在Spring Cloud项目中,使用Java和Redis结合实现的分布式锁可以确保订单的一致性和并发控制,通过合理使用锁的粒度以及注意事项,可以减少死锁问题并提高系统的并发性能,这篇文章主要介绍了Redis SETNX命令在Spring Cloud中的分布式锁用法详解,需要的朋友可以参考下2023-10-10


最新评论