设为首页 收藏本站
查看: 2446|回复: 0

[经验分享] ServiceStack.Redis之IRedisClient<第三篇>

[复制链接]

尚未签到

发表于 2015-7-19 12:31:16 | 显示全部楼层 |阅读模式
  事实上,IRedisClient里面的很多方法,其实就是Redis的命令名。只要对Redis的命令熟悉一点就能够非常快速地理解和掌握这些方法,趁着现在对Redis不是特别了解,我也对着命令来了解一下这些方法。

一、属性
  IRedisClient的属性如下:

属性说明
ConnectTimeout 连接超时
Db当前数据库的ID或下标
DbSize 当前数据库的 key 的数量
HadExceptions
Hashes 存储复杂对象,一个value中有几个field
Host Redis的Server服务器主机地址
Info 返回关于 Redis 服务器的各种信息和统计数值
LastSave 最近一次 Redis 成功将数据保存到磁盘上的时间
Lists 当前数据库中所有的List集合
Password 密码
Port Redis的Server端口
RetryCount 重试次数
RetryTimeout 重试超时
SendTimeout 发送超时
Sets 当前数据库中所有的HashSet集合
SortedSets 当前数据库中所有的SortedSet集合
this[string key]通过索引的方式(key)访问一个字符串类型值
  代码示例:



        RClient.AddItemToSet("蜀国", "刘备");
RClient.AddItemToSet("蜀国", "关羽");
RClient.AddItemToSet("蜀国", "张飞");
IHasNamed rr = RClient.Sets;
HashSet HashSetString = rr["蜀国"].GetAll();
foreach (string str in HashSetString)
{
Response.Write(str);
}
  

二、IRedisClient数据操作
  1、ICacheClient接口
  IRedisClient实现了接口ICacheClient,其中ICacheClient主要提供的功能如下:

方法说明
Add根据传入的key-value添加一条记录,当key已存在返回false
FlushAll使所有缓存失效(清除Redis所有数据库的所有Key)
Get根据传入的key获取一条记录的值
GetAll根据传入的多个key获取多条记录的值
Remove根据传入的key移除一条记录
RemoveAll根据传入的多个key移除多条记录
Replace根据传入的key覆盖一条记录的值,当key不存在不会添加
Set根据传入的key修改一条记录的值,当key不存在则添加
SetAll根据传入的多个key覆盖多条记录
Increment
Decrement
  特别说明,比如添加的主要方法包括两个重载,一个多了个DateTime类型参数,一个多了TimeSpan类型的参数。这两个都是缓存失效的时间(相当于缓存依赖里的绝对过期时间)。


  • DateTime失效点:到达该时间点,立即失效;
  • TimeSpan失效点:经过该时间段,立即失效;
  简单示例:



        public ActionResult Index()
{
RedisClientManagerConfig RedisConfig = new RedisClientManagerConfig();
RedisConfig.AutoStart = true;
RedisConfig.MaxReadPoolSize = 60;
RedisConfig.MaxWritePoolSize = 60;
PooledRedisClientManager prcm = new PooledRedisClientManager(new List() { "127.0.0.1" }, new List() { "127.0.0.1" }, RedisConfig);
using (IRedisClient RClient = prcm.GetClient())
{
RClient.Add("c1", "缓存1");
RClient.Set("c1", "缓存2");
RClient.Replace("c1", "缓存3");
Response.Write(RClient.Get("c1"));
RClient.Remove("c1");
Response.Write(RClient.Get("c1") == null);
}
return Content("");
}
    2、简单功能
    当然,除了实现ICacheClient接口的功能外,对于基本操作,实际上也还有很多功能

方法说明
AppendToValue根据Key将参数value追加到原有值的结尾
ContainsKey判断Key在本数据库内是否已被使用(包括各种类型、内置集合等等)
GetAllKeys获取所有的Keys集合
DecrementValue根据指定的Key,将值减1(仅整型有效)
DecrementValueBy根据指定的Key,将值减去指定值(仅整型有效)
IncrementValue根据指定的Key,将值加1(仅整型有效)
IncrementValueBy根据指定的Key,将值加上指定值(仅整型有效)
RenameKey重命名一个Key,值不变
SearchKeys从数据库中查找名称相等的Keys的集合,特殊模式如h[ae]llo,仅英文有效。
GetRandomKey随机获取一个已经被使用的Key
GetValue根据Key获取值,只对string类型有效
GetValues根据输入的多个Key获取多个值,支持泛型
GetTimeToLive获取指定Key的项距离失效点的TimeSpan
GetSortedSetCount获取已排序集合的项的数目,参数支持下标以及score筛选
ExpireEntryAt根据指定的key设置一项的到期时间(DateTime)
ExpireEntryIn根据指定的key设置一项的到期时间(TimeSpan)
FlushDb清除本数据库的所有数据
FlushAll清除所有数据库的所有数据
Shutdown停止所有客户端,保存,关闭Redis服务
Save保存数据DB文件到硬盘
SaveAsync异步保存
RewriteAppendOnlyFileAsync只在异步情况下将数据追加到服务器文件
WriteAll
PublishMessage将Message发送到指定的频道
StoreObject
GetValuesMap以键值对的方式返回值类型相同的多条数据,支持泛型与返回字符串。
字符串
SetEntry根据Key修改一个值,存在则覆盖。(只能设置字符串)
SetEntryIfNotExists根据Key设置一个值,仅仅当Key不存在时有效,如Key已存在则不修改(只支持字符串)
SetEntryIfNotExists根据Key设置一个值,返回旧值。
GetEntryType  根据Key获取当前存储的值是什么类型:
  None = 0
                String = 1
                List = 2
                Set = 3
                SortedSet = 4
                Hash = 5

    
    
    3、内置集合
  比如,IRedisClient支持在内部维护如下集合类型的数据:


  • List
  • 排序的List(.Net 4.0后的SortedSet)
  • HashSet
  关于如下4种类型数据的操作:

方法说明
AddItemToList添加一个项到内部的List
AddItemToSet添加一个项到内部的HashSet
AddItemToSortedSet添加一个项到内部的排序List,其中重载方法多了个score:排序值。优先按照score从小->大排序,否则按值小到大排序
AddRangeToList一次过将参数中的List中的多个值添加入内部的List
AddRangeToSet一次过将参数中的HashSet中的多个值添加入内部的HashSet
AddRangeToSortedSet一次过将参数中的List中的多个值添加到内部List,重载方法的score表示排序值。
GetAllItemsFromList获取指定ListId的内部List的所有值
GetAllItemsFromSet获取指定SetId的内部HashSet的所有值
GetAllItemsFromSortedSet获取指定ListId的内部已排序List的所有值
GetAllItemsFromSortedSetDesc获取指定ListId的内部已排序List的所有值,不过获取的值是倒序排列后的。
GetRangeFromList获取指定ListId的内部List中指定下标范围的数据
GetRangeFromSortedList获取指定ListId的内部已排序List中指定下标范围的数据
GetRangeFromSortedSet获取指定SetId的内部HashSet中指定下标范围的数据
GetRangeFromSortedSetByHighestScore获取指定SetId的内部HashSet中按照score由高->低排序后的分值范围的数据,并且支持skip、take
GetRangeFromSortedSetByLowestScore同上,只不过是按score分值由低->高取一定范围内的数据
GetRangeFromSortedSetDesc按倒序获取内部HashSet的指定下标范围内的数据
GetRangeWithScoresFromSortedSet与From相同,只不过获取的是键值对,数据中带分值score
GetRangeWithScoresFromSortedSetByHighestScore同上
GetRangeWithScoresFromSortedSetByLowestScore同上
GetRangeWithScoresFromSortedSetDesc同上
GetAllWithScoresFromSortedSet获取指定ListId的已排序的内部List与其score
GetSortedItemsFromList从指定ListId的List中获取按指定排序的集合,支持Skip,Take
GetSortedEntryValues从指定ListId的List中获取经过排序指定开始位置与个数的项
RemoveAllFromList移除指定ListId的内部List
RemoveItemFromList移除指定ListId的内部List中第二个参数值相等的那一项
RemoveItemFromSet从指定SetId的内部HashSet中移除与第二个参数值相等的那一项
RemoveItemFromSortedSet从指定ListId中已排序的内部List中移除值相等的那一项
RemoveRangeFromSortedSet从指定ListId已排序的List中移除指定下标范围的项
RemoveRangeFromSortedSetByScore从指定ListId已排序的List中移除指定score范围的项
RemoveStartFromList从指定ListId移除开头那一项
RemoveEndFromList从指定ListId移除末尾那项
BlockingRemoveStartFromList阻塞地从指定ListId移除开头那一项
BlockingRemoveStartFromLists
RemoveEntry根据传入的多个ListId,清除多个内部List
RemoveAllLuaScripts清除所有的 Lua 脚本缓存
RemoveEntryFromHash
GetItemFromList根据ListId和下标获取一项
GetItemIndexInSortedSet根据List和值,获取内置的排序后的List的下标
GetItemIndexInSortedSetDesc同上,不过顺序相反
GetItemScoreInSortedSet根据传入的ListId和值获取内置List项的score
GetListCount根据ListId,获取内置的List的项数
GetSetCount根据SetId,获取内置的HashSet的项数
GetIntersectFromSets从输入的多个HashSet的Id中获取交集
GetUnionFromSets从输入的多个HashSet的Id中获取并集
GetRandomItemFromSet从指定ListId的集合中获取随机项
StoreUnionFromSets将多个HashSet,合并为第一个参数中的一个大HashSet,第一个参数中的HashSet原本可以不存在
StoreUnionFromSortedSets将多个SortedSet,合并为第一个参数中的一个大SortedSet,第一个参数中的SortedSet原本可以不存在
StoreIntersectFromSets将交集结果保存在第一个参数的集合中,对HastSet作用
StoreIntersectFromSortedSets将交集结果保存在第一个参数的集合中,对SortedSet作用
EnqueueItemOnList将一个元素存入指定ListId的List的头部
DequeueItemFromList将指定ListId的List末尾的那个元素出列,返回出列元素
BlockingDequeueItemFromList将指定ListId的List末尾的那个元素出列,区别是:会阻塞该List,支持超时时间,返回出列元素
BlockingDequeueItemFromLists
BlockingPopItemFromList阻塞地将指定ListId的List末尾的哪一个元素移除
BlockingPopItemFromLists
BlockingPopAndPushItemBetweenLists将第一个集合的元素移除并添加到第二个集合的头部,返回该元素,会同时阻塞两个集合
PopItemFromList从指定ListId的List末尾移除一项并返回
PopItemFromSet从指定SetId的HashSet末尾移除一项并返回
PopItemWithHighestScoreFromSortedSet从指定SetId的HashSet移除score最高的那一项
PopItemWithLowestScoreFromSortedSet从指定SetId的HashSet移除score最低的那一项
PopAndPushItemBetweenLists将第一个集合的元素移除并添加到第二个集合的头部
SetContainsItem判断指定SetId的HashSet中是否包含指定的value(仅仅支持字符串)
SortedSetContainsItem判断SortedSet是否包含一个键
TrimList根据ListId裁剪内置集合,保留下去from->at之间(包含from于at)的元素,其余的裁去
IncrementItemInSortedSet为指定ListId的集合中的value的分值score加上指定分值
SetItemInList重新设置指定ListId和下标的value为指定值
PushItemToList在指定ListId的内置List中入列一个键值对,在末尾
PrependItemToList将一个值插入到List的最前面
PrependRangeToList一次性添加多个值到指定ListId的内置List中
GetDifferencesFromSet返回存在于第一个集合,但是不存在于其他集合的数据。差集
StoreDifferencesFromSet将求差集的结果保存在第一个参数的集合中
MoveBetweenSets将元素从一个集合移动到另一个集合的开头。(删除与添加)
  下面仅给出一个List与HashSet的示例:



        //内部维护一个List集合
RClient.AddItemToList("蜀国", "刘备");
RClient.AddItemToList("蜀国", "关羽");
RClient.AddItemToList("蜀国", "张飞");
List ListString = RClient.GetAllItemsFromList("蜀国");
foreach (string str in ListString)
{
Response.Write(str);    //输出 刘备 关羽 张飞
        }
RClient.AddItemToSet("魏国", "曹操");
RClient.AddItemToSet("魏国", "曹操");
RClient.AddItemToSet("魏国", "典韦");
HashSet HashSetString = RClient.GetAllItemsFromSet("魏国");
foreach (string str in HashSetString)
{
Response.Write(str);    //输出 典韦 曹操
}
  下面再给一个范围Range操作示例:



        //内部维护一个List集合
RClient.AddItemToSortedSet("蜀国", "刘备", 5);
RClient.AddItemToSortedSet("蜀国", "关羽", 2);
RClient.AddItemToSortedSet("蜀国", "张飞", 3);
IDictionary DicString = RClient.GetRangeWithScoresFromSortedSet("蜀国", 0, 2);
foreach (var r in DicString)
{
Response.Write(r.Key + ":" + r.Value);    //输出
}
  3、内置Hash
  内部维护一个HashTable

方法说明
SetEntryInHash设置一个键值对入Hash表,如果哈希表的key存在则覆盖
SetEntryInHashIfNotExists当哈希表的key未被使用时,设置一个键值对如Hash表
GetHashValues根据HashId获取多个改HashId下的多个值
GetValuesFromHash根据HashId和Hash表的Key获取多个值(支持多个key)
GetValueFromHash根据HashId和Hash表的Key获取单个值
GetHashKeys获取指定HashId下的所有Key
GetHashValues获取指定HashId下的所有值
GetHashCount获取指定HashId下的所有Key数量
HashContainsEntry判断指定HashId的哈希表中是否包含指定的Key
IncrementValueInHash将指定HashId的哈希表中的值加上指定值
StoreAsHash将一个对象存入Hash(支持泛型)
GetFromHash根据Id从Hash表中取出对象(支持泛型)
SetRangeInHash通过IEnumerable一次性设置多个值,当内部Hash的key不存在则添加,存在则覆盖
  代码示例:



        RClient.SetEntryInHash("xxx","key","123");
List keyValuePairs = new List();
KeyValuePair kvp = new KeyValuePair("key", "1");
keyValuePairs.Add(kvp);
RClient.SetRangeInHash("xxx", keyValuePairs);
  
  4、Lua Script
  从 Redis 2.6.0 版本开始,通过内置的 Lua 解释器,可以执行各种Lua脚本。IRedisClient支持执行Lua脚本,其供用于执行Lua脚本的方法如下:

方法说明
LoadLuaScript将一个脚本装入脚本缓存,但并不立即运行它
KillRunningLuaScript停止正在运行的指定Id的脚本
ExecLuaAsInt
ExecLuaAsList
ExecLuaAsString
ExecLuaShaAsInt
ExecLuaShaAsList
ExecLuaShaAsString
HasLuaScript判断Lua脚本是否在脚本缓存里
CalculateSha1
WhichLuaScriptsExists
  关于Lua脚本可以到这里去了解:http://www.iyunv.com/ly4cn/archive/2006/08/04/467550.html
  5、事务
  Redis中的事务

方法说明
Watch监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。
UnWatch取消 WATCH 命令对所有 key 的监视
AcquireLock申请对一个Key加锁(期间其他对象不能访问)
CreateTransaction创建一个事务,返回一个IRedisTransaction对象
CreateSubscription创建一个订阅事件返回一个IRedisSubscription对象
CreatePipeline返回一个IRedisPipeline对象

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-88271-1-1.html 上篇帖子: Redis 实践笔记 下篇帖子: 【轮子狂魔】手把手教你自造Redis Client
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表