list类型
数据存储需求:存储多个数据,并对数据进入存储空间的顺序进行区分
需要的存储数据:一个存储空间保存多个数据,且通过数据可以体现进入顺序
list类型:保存多个数据,底层使用双向链表存储结构实现
list类型数据基本操作
常用指令:
添加/修改数据
lpush key value1 [value2] …rpush key value1 [value2] …
获取数据
lrange key start stoplindex key indexllen key
删除并移除数据
lpop keyrpop key
全部常用指令:
list 类型数组扩展操作
规定时间内获取并移除数据
blpop key1 [key2] timeoutbrpop key1 [key2] timeout
阻塞式获取,获取值如果还没有的时候可以等,如果有值就可以获取到。
list 类型常见业务场景
微信朋友圈点赞,要求按照点赞顺序显示点赞好友信息,如果取消点赞,移除对应好友信息
移除指定数据
lrem key count value
redis应用于具有操作线后顺序的数据控制
list类型数据注意事项
list 中保存的数据都是string类型的,数据总容量是有限的,最多232-1个元素(4294967295)
list具有索引的概念,但是操作数据时候通常以队列的形式进行入队出队操作,或以栈的形式进入栈出栈的操作
获取全部数据操作结束索引设置为-1
list 可以对数据进行分页操作,通过第一页的信息来自list,第2页及更多的信息通过数据库的形式加载
如果键不存在,创建新的链表;
如果键已存在,新增内容;
如果值全移除,对应的键也就消失了。
链表的操作无论是头和尾效率都极高,但假如是对中间元素进行操作,效率就很惨淡了。
list类型应用场景
业务场景
twitter、新浪微博、腾讯微博中个人用于的关注列表需要按照用户的关注顺序进行展示,粉丝列表需要将最近关注的粉丝列在前面
新闻、资讯类网站如何将最新的新闻或资讯按照发生的事件顺序展示
企业运营过程中,系统将产生出大量的运营数据,如何保障多台服务器操作日志的统一顺序输出?
解决方案
依赖list的数据具有顺序的特征对信息进行管理
使用队列模型解决多路信息汇总合并的问题
使用栈模型解决最新消息的问题