Bamboo的redis封装层API

阅读更多
先扯一下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这个成员





你可能感兴趣的:(Bamboo的redis封装层API)