redis 模糊查找keys
2024-09-30 16:07:10
Redis入门教程可参考:超强、超详细Redis数据库入门教程
Redis操作命令可参考:Redis操作命令总结
redis可以通过命令Keys Match来进行键值的模糊匹配,借助StackExchange.Redis时,由于Dll内部没有实现Keys Match的操作,不过,StackExchange.Redis提供了直接执行Lua语句的入口:
RedisResult ScriptEvaluate(LoadedLuaScript script, object parameters = null, CommandFlags flags = CommandFlags.None);
RedisResult ScriptEvaluate(string script, RedisKey[] keys = null, RedisValue[] values = null, CommandFlags flags = CommandFlags.None);
RedisResult ScriptEvaluate(byte[] hash, RedisKey[] keys = null, RedisValue[] values = null, CommandFlags flags = CommandFlags.None);
RedisResult ScriptEvaluate(LuaScript script, object parameters = null, CommandFlags flags = CommandFlags.None);
Windows下调试Lua的环境搭建可参考如下:Windows下Lua+Redis 断点调试环境搭建==Linux下类似
Keys Match,当数据规模较大时使用,会严重影响Redis性能,Redis还可以通过SCAN命令模糊匹配Key。
以上两种方式的Lua语句如下:
//使用Keys *模糊匹配Key
return redis.call('keys',KEYS[]) //使用SCAN模糊匹配Key
local dbsize=redis.call('dbsize') local res=redis.call('scan',,'match',KEYS[],'count',dbsize) return res[]
StackExchange.Redis调用如下:
private static object _locker = new Object();
private static ConnectionMultiplexer _instance = null; public static ConnectionMultiplexer Instance
{
get
{
if (_instance == null)
{
lock (_locker)
{
if (_instance == null || !_instance.IsConnected)
{
_instance = ConnectionMultiplexer.Connect(ConfigUtils.ArrangeResultHost);
}
}
}
return _instance;
}
} public static IDatabase GetDatabase()
{
return Instance.GetDatabase();
} //使用Keys *模糊匹配Key
public static List<string> GetKeys(string key) {
var result=(string[])GetDatabase().ScriptEvaluate(LuaScript.Prepare("return redis.call('KEYS',@keypattern)"),new{ keypattern=key });
return result.ToList();
} //使用SCAN模糊匹配Key
public static List<string> GetKeys(string key)
{
var result = (string[])GetDatabase().ScriptEvaluate(
LuaScript.Prepare("local dbsize=redis.call('dbsize') local res=redis.call('scan',0,'match',KEYS[1],'count',dbsize) return res[2]"),
new RedisKey[] { key });
return result.ToList();
}
最新文章
- java布局学习 (一)
- Jvm基础(2)-Java内存模型
- 动态规划(斜率优化):BZOJ 1010 【HNOI2008】 玩具装箱
- 《javascript设计模式》--接口
- thinkphp 分组、页面跳转与ajax
- 业务接口+UI层的设计(基于Castle实现的Repository)
- svn switch 的用法
- 精读《Scheduling in React》
- 【译】1. Java反射——引言
- 【翻译】asp.net core2.1认证和授权解密
- XmlDocument.Load(url) url是https远程时,报错"; 基础连接已经关闭: 未能为 SSL/TLS 安全通道建立信任关系。"; ";根据验证过程,远程证书无效。";
- Error-MVC: “/”应用程序中的服务器错误。
- Http协议和Tomcat服务器
- 人机猜拳游戏Java
- SpringBoot @AutoWired Null
- Android内核编译
- linux 笔记(一)
- redis源码学习_整数集合
- Ubuntu16.04安装postgresql9.4(转发:http://www.cnblogs.com/sparkdev/p/5678874.html)
- python&#39;s ninteenth day for me 类的组合,继承。