先扯一下Bamboo与Redis的关系:Bamboo对redis目前严重依赖,但是无需担心无法使用其它数据库。Redis可以看成是一个中间层,后端使用其它机制来实现数据库的持久化。
Redis的指令虽然已经很好用了,但如果要上层逻辑直接使用,还是很复杂,容易出错。于是,对Redis的封装还是有必要的。在这个封装中,不是简单的redis的指令的包装,还有一些策略性的东西放在里面。
API基本范畴
名称 | 用途 |
save | 创建,批量写入 |
update | 在已经创建的情况下,批量写入 |
retrieve(及其衍生) | 获取所有 |
del | 删除 |
add(append及衍生) | 添加元素 |
remove(pop) | 删除一个元素 |
num(len) | 测量长度 |
have | 测试是否包含 |
下面分门别类列出各个存储模型的API
redis/list.lua
API method | 说明 |
save(key, tbl) | 创建一个redis list, 并传递一个表格参数tbl进来,写入此list中。 |
update(key, tbl) | 将传递进来的tbl的值写入已经存在的key中去。 |
retrieve(key) | 获取此list的所有成员,返回一个lua list |
append(key, val) | 在list右端添加一个成员 |
prepend(key, val) | 在list左端添加一个成员 |
pop(key) | 删除最右端的成员 |
remove(key, val) | 删除list中的val成员 |
removeByIndex(key, index) | 按索引删除某一个成员 |
len(key) | 测量list长度,返回数值 |
del(key) | 删除此list |
have(key, obj) | 检测list中是否有obj这个成员 |
redis/zset.lua
API method | 说明 |
save(key, tbl) | 创建一个redis zset, 并传递一个表格参数tbl进来,写入此zset中。 |
update(key, tbl) | 将传递进来的tbl的值写入。 |
add(key, val) | 将val添加到zset中去,如果已经存在,则直接返回nil;不存在,则加进去,score为zset内的累计值 |
retrieve(key) | 获取此zset的所有成员,按score由低到高的顺序,返回一个lua list |
retrieveReversely(key) | 获取此zset的所有成员,不过顺序是相反的,按score由高到低顺序,返回一个lua list |
retrieveWithScores(key) | 获取此zset的所有成员,同时获取member值和score值,按score由低到高的顺序,返回一个lua list,每个list成员为{member, score} |
retrieveReverselyWithScores(key) | 获取此zset的所有成员,同时获取member值和score值,按score由高到低的顺序,返回一个lua list,每个list成员为{member, score} |
remove(key, val) | 删除此zset中的val成员 |
removeByScore(key, score) | 删除此zset中的score为score的成员 | |
num(key) | 测量此zset长度,返回数值 |
del(key) | 删除此zset |
have(key, obj) | 检测zset中是否有obj这个成员 |
redis/set.lua
API method | 说明 |
save(key, tbl) | 创建一个redis set, 并传递一个表格参数tbl进来,写入此set中。 |
update(key, tbl) | 将传递进来的tbl的值写入。 |
add(key, val) | 将val添加到set中去 |
retrieve(key) | 获取此set的所有成员,返回一个lua list,无固定顺序 |
remove(key, val) | 删除此set中的val成员 |
removeByScore(key, score) | 删除此zset中的score为score的成员 | |
num(key) | 测量此set长度,返回数值 |
del(key) | 删除此set |
have(key, obj) | 检测set中是否有obj这个成员 |
redis/fifo.lua
API method | 说明 |
save(key, tbl) | 没实现,不需要。 |
update(key, tbl) | 没实现,不需要。 |
retrieve(key) | 获取此fifo的所有成员,返回一个lua list |
push(key, val) | 在list左端添加一个成员,于是最新的成员在左边 |
pop(key) | 删除最右端的成员,最老的成员在右边 |
remove(key, val) | 删除fifo中的val成员 |
len(key) | 测量fifo长度,返回数值 |
del(key) | 删除此fifo |
have(key, obj) | 检测fifo中是否有obj这个成员 |
redis/zfifo.lua
API method | 说明 |
save(key, tbl) | 没实现,不需要。 |
update(key, tbl) | 没实现,不需要。 |
retrieve(key) | 获取此zfifo的所有成员,返回一个lua list |
retrieveWithScores(key) | 获取此zfifo的所有成员,同时获取member和score,返回一个lua list,每个list成员为 {member, score} |
push(key, val) | 在此zfifo中新加入一个成员val。这个新成员的score是在内部递增计算出来的,始终保持新加入的成员分值最大 |
pop(key) | 删除最老的成员 |
remove(key, val) | 删除此zfifo中的val成员 |
removeByScore(key, score) | 删除此zfifo中的score为score的成员 |
len(key) | 测量此zfifo长度,返回数值 |
del(key) | 删除此zfifo |
have(key, obj) | 检测此zfifo中是否有obj这个成员 |
分享到:
相关推荐
一个php操作redis封装的类,Redis 操作,支持 Master/Slave 的负载集群,服务器连接句柄,连接服务器,注意:这里使用长连接,提高效率,但不会自动关闭,得到 Redis 原始对象可以有更多的操作,条件形式设置缓存,...
对StackExchange.Redis.dll的Redis封装类,抽象一个接口ICacheStorageProvider作为公共缓存接口,具有增,删,改的功能接口
Redis使用操作类库,对其进行封装生成类库文件源码。
一个php操作redis封装的类,Redis 操作,支持 Master/Slave 的负载集群,服务器连接句柄,连接服务器,注意:这里使用长连接,提高效率,但不会自动关闭,得到 Redis 原始对象可以有更多的操作,条件形式设置缓存,...
C# StackExchange.Redis 操作封装类库,包括Redis五大数据结构(String,Hash,List,Set,ZSet)的各种用法、单元测试实例。
java项目使用redis封装一些方法和一些初始化数据,如初始化连接池等
StackExchange.redis 封装帮助类(支持批量)
C++的redis的API、 需要boost库、可直接加入工程目录编译
c++ 调用 redis 封装
Redis常用方法封装核心类;对象序列化和反序列化;RedisSession 用于微信分部署session操作;Redis数据源操作接口;商品Redis 存储查询 针对redis缓存技术进行了封装,对象类型存贮封装了序列化,redis穿透的处理。
包含翻译后的API文档:spring-data-redis-2.5.5-javadoc-API文档-中文(简体)版.zip; Maven坐标:org.springframework.data:spring-data-redis:2.5.5; 标签:springframework、data、spring、redis、中文文档、jar...
此代码实现了redis使用hiredis c接口开发,具体实现了string和list类型的存取,具体信息请看 https://blog.csdn.net/bwangk/article/details/83060374
redis c++封装
redis简单封装及技术文档
由于ServiceStack.Redis已经收费,所以开始转向StackExchange.Redis使用,这里不讨论性能,只是封装其使用;网上有一位网友的封装我很喜欢,逐步修改了下。把redis几种存储的操作分别封装在一个类中;分别增加了单例...
C# StackExchange.Redis 操作封装类库,分别封装了Redis五大数据结构(String,Hash,List,Set,ZSet)的增删改查的操作方法,支持Async异步操作。支持Redis分库操作。支持信息队列操作。 带有单元测试,为每个...
Qt 封装redis接口,redis key-value 数据库 , 应用点对点消息队列,多对多发布订阅通信
从网上抓取的redis文档,中文版本!!提供给在没有网络下的朋友查询参考使用!!
使用StackExchange.Redis,针对String、Hath、List、SortedSet、key的各种操作,包括订阅发布的相关使用。