StackExchange.Redis 官方文档(四) KeysScan
KEYS
, SCAN
, FLUSHDB
方法在哪?
经常有人问这些问题:
好像并没有看到
Keys(...)
或者Scan(...)
方法?那我要怎么查询数据库里面存有哪些key?
或者
好像没有
Flush(...)
方法?那我要怎么清除数据库里面的所有key?
问题的关键就在这里:数据库。因为StackExchange.Redis旨在cluster等场景,知道哪些命令的目标是database(逻辑数据库可以分布在多个节点上)和哪些命令的目标是server是很重要的。下面的命令的目标全部指向一个单独server:
KEYS
/SCAN
FLUSHDB
/FLUSHALL
RANDOMKEY
CLIENT
CLUSTER
CONFIG
/INFO
/TIME
SLAVEOF
SAVE
/BGSAVE
/LASTSAVE
SCRIPT
(not to be confused withEVAL
/EVALSHA
)SHUTDOWN
SLOWLOG
PUBSUB
(not to be confused withPUBLISH
/SUBSCRIBE
/ etc)- some
DEBUG
operations
(我可能会漏掉不止一个。。。)他们当中大部分都可以很明显的看出来,除了前面三个:
KEYS
/SCAN
只会列出当前server上的keys:而不是整个逻辑数据库FLUSHDB
/FLUSHALL
同样只会移除当前server上的所有的keysRANDOMKEY
同样只会选出当前服务器上的一个key
事实上,StackExchange.Redis在 IDatabase
API 实现RANDOMKEY
的方式是随机选择一个目标服务器,对于其他的命令是不能这样做的。
那我要怎么使用这些命令呢?
很简单:从server上使用这些命令,而不是database。
// get the target server
var server = conn.GetServer(someServer);
// show all keys in database 0 that include "foo" in their name
foreach(var key in server.Keys(pattern: "*foo*")) {
Console.WriteLine(key);
}
// completely wipe ALL keys from database 0
server.FlushDatabase();
要注意不像IDatabase
API(在调用 GetDatabase()
就已经选好了target database),这些方法对database都有一个可选的参数,或者默认为0
。
Keys(...)
方法需要特别注意的是:它的与众不同之处在于它没有对应的*Async
方法。原因是在scene下,系统会判断出最适合采用的方法(KEYS
vs SCAN
,基于服务器版本),而且如果可以的话将会使用SCAN
在内部处理分页的方式返回一个IEnumerable<RedisKey>
-所以并不需要知道当前操作的实现细节。如果SCAN
不可用,将会采用KEYS
,这将会造成服务器阻塞,无论哪一种方式,SCAN
and KEYS
需要遍历整个key控件,所以在production server要避免使用这个方法-至少,在从服务器上使用。
那我就需要记住我连接是哪一台服务器?that sucks。。。
不,并不需要。你可以使用conn.GetEndPoints()
列出节点(或者是所有已知的,或者在config当中指出来的-两者不一定是相同的),然后使用GetServer()
迭代查处需要的server(例如:选择一个slave)
StackExchange.Redis 官方文档(四) KeysScan的更多相关文章
- StackExchange.Redis 官方文档
原文:StackExchange.Redis 官方文档 时隔多年的翻译终于完成了第六个,也是很重要的的官方文档,是介绍有关链接管理,管道流水线和多路复用的 官方地址在这里:官方文档 下面做个汇总: S ...
- StackExchange.Redis 官方文档(六) PipelinesMultiplexers
原文:StackExchange.Redis 官方文档(六) PipelinesMultiplexers 流水线和复用 糟糕的时间浪费.现代的计算机以惊人的速度产生大量的数据,而且高速网络通道(通常在 ...
- StackExchange.Redis 官方文档(五) Keys, Values and Channels
原文:StackExchange.Redis 官方文档(五) Keys, Values and Channels Keys, Values and Channels 在使用redis的过程中,要注意到 ...
- StackExchange.Redis 官方文档(一) Basics
基本使用方法: StackExchange.Redis的核心是 StackExchange.Redis 命名空间的 ConnectionMultiplexer 类;它隐藏了多服务器的实现细节.Conn ...
- StackExchange.Redis 官方文档(三) Events
事件 ConnectionMultiplexer类型提供了很多可以用来了解表面状态下正在发生着什么的事件.这对日志是很有用的. ConfigurationChanged - ConnectionMul ...
- StackExchange.Redis 官方文档(二) Configuration
配置 有多种方式可以配置redis,StackExchange.Redis提供了一个丰富的配置模型,在执行Connect (or ConnectAsync) 时被调用: var conn = Conn ...
- Redis官方文档》持久化
原文链接 译者:Alexandar Mahone 这篇文章从技术层面描述了Redis持久化,建议所有读者阅读.如果希望更多了解Redis持久化和持久性保障,建议阅读Redis持久化揭秘. Redis ...
- Redis官方文档资源
官方文档: 如果要深入研究时,官方提供的文档是最权威的. 英文: https://redis.io/documentation 中文: http://www.redis.cn/documentatio ...
- 《Redis官方文档》用Redis构建分布式锁
用Redis构建分布式锁 在不同进程需要互斥地访问共享资源时,分布式锁是一种非常有用的技术手段. 有很多三方库和文章描述如何用Redis实现一个分布式锁管理器,但是这些库实现的方式差别很大,而且很多简 ...
随机推荐
- C#获取客服端ip和用户名
. 在asp.Net中专用属性: 获取服务器电脑名:page.server.manchinename 获取用户信息:page.user 获取客户端电脑名:page.request.userhostna ...
- oracle中的赋权
1 怎么给用户赋权限 grant create view to scott; (create view 是权限的名称) 2 怎么给用户撤销权限 revoke create view from scot ...
- 【gcd】 最大公约数
int gcd(int a,int b) { int r; ) { r=a%b; a=b; b=r; } return a; }
- js document
<html><head lang="en"> <meta charset="UTF-8"> <title>< ...
- js选择一个选项 跳出另一个选项 跳出一个输入框
跳出输入框 <script language="javascript"> function $(obj){return document.getElementById( ...
- Java对数函数及Java对数运算
Java对数函数及Java对数运算 2010-05-17 10:32 中国IT实验室 佚名 关键字:Java Java对数函数的计算方法非常有问题,然而在API中却有惊人的误差.但是假如运用了 ...
- Android之EditText控件
<EditText android:layout_width="fill_parent" android:layout_height="wrap_content&q ...
- API 友好
API友好 新版ThinkPHP针对API开发做了很多的优化,并且不依赖原来的API模式扩展. 数据输出 新版的控制器输出采用Response类统一处理,而不是直接在控制器中进行输出,通过设置defa ...
- apache服务器中设置目录不可访问
<Directory "d:/amp/apache/htdocs/images"> Allow from all Options None</Dire ...
- 【HighCharts系列教程】九、语言属性——Lang
一.lang属性说明 Lang属性主要用于配置显示的文字等语言相关属性. 主要可配置如下内容:小数点符号.导出相关文字.月份文字.星期文字等 lang属性不重要,无特殊情况,不用配置. 二.lang属 ...