在微博微信场景下学习Redis数据结构

Redis安装

下载地址:http://redis.io/download

安装步骤:
1、yum install gcc
2、wget http://download.redis.io/releases/redis‐5.0.3.tar.gz
tar xzf redis‐5.0.3.tar.gz
cd redis‐5.0.3
3、make
4、src/redis‐server redis.conf(注意要使用后台启动,所以修改redis.conf里的daemonize改为y
es)
5、ps ‐ef | grep redis
6、src/redis‐cli

Redis核心数据结构以及使用场景

String结构

  • 字符串常用操作
SET  key  value             //存入字符串键值对
MSET  key  value [key value ...]    //批量存储字符串键值对
SETNX  key  value               //存入一个不存在的字符串键值对
GET  key                    //获取一个字符串键值
MGET  key  [key ...]        //批量获取字符串键值
DEL  key  [key ...]         //删除一个键
EXPIRE  key  seconds        //设置一个键的过期时间(秒)
  • 原子加减
INCR  key           //将key中储存的数字值加1
DECR  key           //将key中储存的数字值减1
INCRBY  key  increment  //将key所储存的值加上increment
DECRBY  key  decrement  //将key所储存的值减去decrement
  • String应用场景

这个是微信公众号的文章阅读量数量的统计,可以通过redis的string数据结构来解决。使用incr原子操作命令,redis的key是article:readcount:{文章id},当该文章被阅读时,调用incr命令,阅读数量加一,通过get该redis的key,实现文章阅读数量统计的功能。

incr article:readcount:{文章id}
get article:readcount:{文章id}

Hash结构

  • Hash常用操作
HSET  key  field  value             //存储一个哈希表key的键值
HSETNX  key  field  value       //存储一个不存在的哈希表key的键值
HMSET  key  field  value [field value ...]  //在一个哈希表key中存储多个键值对
HGET  key  field                //获取哈希表key对应的field键值
HMGET  key  field  [field ...]      //批量获取哈希表key中多个field键值
HDEL  key  field  [field ...]       //删除哈希表key中的field键值
HLEN  key               //返回哈希表key中field的数量
HGETALL  key                //返回哈希表key中所有的键值
HINCRBY  key  field  increment      //为哈希表key中field键的值加上增量increment
  • Hash使用场景

这个是京东购物车的截图,可以看到很多功能都用redis的命令可来实现。在redis中保存对商品id、购物车id等等id的操作,在前端保存对于该商品的描述,在操作购物车的时候,底层其实就是操作redis的命令。

添加商品:hset cart:1001 1088 1
添加数量:hincrby cart:1001 1088 1
商品总数:hlen cart:1001
删除商品:hdel cart:1001 1008
获取购物车所有商品: hgetall cart:1001
  • Hash优缺点
    优点:同类数据归类整合存储,方便数据管理,相比string操作消耗内存与cpu更小
    缺点:过期功能上不能使用在field上,只能使用在key上

List结构

  • List常用操作
LPUSH  key  value [value ...]       //将一个或多个值value插入到key列表的表头(最左边)
RPUSH  key  value [value ...]       //将一个或多个值value插入到key列表的表尾(最右边)
LPOP  key           //移除并返回key列表的头元素
RPOP  key           //移除并返回key列表的尾元素
LRANGE  key  start  stop        //返回列表key中指定区间内的元素,区间以偏移量start和stop指定

BLPOP  key  [key ...]  timeout  //从key列表表头弹出一个元素,若列表中没有元素,阻塞等待,timeout秒,如果timeout=0,一直阻塞等待
BRPOP  key  [key ...]  timeout  //从key列表表尾弹出一个元素,若列表中没有元素,阻塞等待,timeout秒,如果timeout=0,一直阻塞等待
  • List的应用场景

这是我们经常使用的新浪微博,我们看在微博文章中如何使用redis的list数据结构。新浪微博是使用redis的大户,据在新浪工作的朋友说,新浪使用redis的总容量超过500T,可想而知几乎70%的功能都在redis中操作。

"小米手机"发微博,消息id为1001,使用的redis命令是:

LPUSH msg:{小强-id} 1001

"号外长沙"发微博,消息id为1002,使用的redis命令是:

LPUSH msg:{小强-id} 1002

小强查看最新10条的新浪微博消息:

LRANGE msg:{小强-id} 0 10

Set结构

  • Set常用操作
SADD  key  member  [member ...]         //往集合key中存入元素,元素存在则忽略,若key不存在则新建
SREM  key  member  [member ...]         //从集合key中删除元素
SMEMBERS  key                   //获取集合key中所有元素
SCARD  key                  //获取集合key的元素个数
SISMEMBER  key  member          //判断member元素是否存在于集合key中
SRANDMEMBER  key  [count]           //从集合key中选出count个元素,元素不从key中删除
SPOP  key  [count]              //从集合key中选出count个元素,元素从key中删除
  • Set运算操作
SINTER  key  [key ...]              //交集运算
SINTERSTORE  destination  key  [key ..]     //将交集结果存入新集合destination中
SUNION  key  [key ..]               //并集运算
SUNIONSTORE  destination  key  [key ...]        //将并集结果存入新集合destination中
SDIFF  key  [key ...]               //差集运算
SDIFFSTORE  destination  key  [key ...]     //将差集结果存入新集合destination中
  • Set使用场景

使用这个抽奖界面作为set的使用场景的例子,相信大家对这个界面都很熟悉,微信小程序的“抽奖”功能,这个是使用redis的set数据结构的典型场景。
当用户点击“参与抽奖”,也就是把将用户ID加入集合中:

SADD key {userID}

查看参与抽奖的所有用户:

SMEMBERS key

抽取count名中奖用户

SRANDMEMBER key [count]

Zset有序集合结构

  • ZSet常用操作
ZADD key score member [[score member]…] //往有序集合key中加入带分值元素
ZREM key member [member …]      //从有序集合key中删除元素
ZSCORE key member           //返回有序集合key中元素member的分值
ZINCRBY key increment member        //为有序集合key中元素member的分值加上increment
ZCARD key               //返回有序集合key中元素个数
ZRANGE key start stop [WITHSCORES]  //正序获取有序集合key从start下标到stop下标的元素
ZREVRANGE key start stop [WITHSCORES]   //倒序获取有序集合key从start下标到stop下标的元素
  • Zset使用场景

微博热搜榜处处使用到了Redis的有序集合这个数据结构,我们都知道有序集合是对集合的一个扩展,增加了score字段。通过score字段,我们可以选出最大或者最小的topN,这样就有了排行榜,如果用传统的数据库去实现这个功能,估计对数据性能的消耗非常大。

1)点击新闻
ZINCRBY  hotNews:20190819  1  乌镇十二时辰
2)展示当日排行前十
ZREVRANGE  hotNews:20190819  0  10  WITHSCORES
3)七日搜索榜单计算
ZUNIONSTORE  hotNews:20190813-20190819  7
hotNews:20190813  hotNews:20190814... hotNews:20190819
4)展示七日排行前十
ZREVRANGE hotNews:20190813-20190819  0  10  WITHSCORES

还没关注我的公众号?

  • 扫文末二维码关注公众号【小强的进阶之路】可领取如下:
  • 学习资料: 1T视频教程:涵盖Javaweb前后端教学视频、机器学习/人工智能教学视频、Linux系统教程视频、雅思考试视频教程;
  • 100多本书:包含C/C++、Java、Python三门编程语言的经典必看图书、LeetCode题解大全;
  • 软件工具:几乎包括你在编程道路上的可能会用到的大部分软件;
  • 项目源码:20个JavaWeb项目源码。

原文地址:https://www.cnblogs.com/xiaoqiang-code/p/11710010.html

时间: 2024-08-29 04:02:23

在微博微信场景下学习Redis数据结构的相关文章

分布式缓存技术redis学习系列(二)——详细讲解redis数据结构(内存模型)以及常用命令

Redis数据类型 与Memcached仅支持简单的key-value结构的数据记录不同,Redis支持的数据类型要丰富得多,常用的数据类型主要有五种:String.List.Hash.Set和Sorted Set. Redis数据类型内存结构分析 Redis内部使用一个redisObject对象来表示所有的key和value.redisObject主要的信息包括数据类型(type).编码方式(encoding).数据指针(ptr).虚拟内存(vm)等.type代表一个value对象具体是何种数

Redis 数据结构使用场景

Redis 数据结构使用场景 redis共有5种数据结构,每种的使用场景都是什么? 一.redis 数据结构使用场景 原来看过 redisbook 这本书,对 redis 的基本功能都已经熟悉了,从上周开始看 redis 的源码.目前目标是吃透 redis 的数据结构.我们都知道,在 redis 中一共有5种数据结构,那每种数据结构的使用场景都是什么呢? String——字符串 Hash——字典 List——列表 Set——集合 Sorted Set——有序集合 下面我们就来简单说明一下它们各自

分布式缓存技术redis学习(二)——详细讲解redis数据结构(内存模型)以及常用命令

Redis数据类型 与Memcached仅支持简单的key-value结构的数据记录不同,Redis支持的数据类型要丰富得多,常用的数据类型主要有五种:String.List.Hash.Set和Sorted Set. Redis数据类型内存结构分析 Redis内部使用一个redisObject对象来表示所有的key和value.redisObject主要的信息包括数据类型(type).编码方式(encoding).数据指针(ptr).虚拟内存(vm)等.type代表一个value对象具体是何种数

3.redis 都有哪些数据类型?分别在哪些场景下使用比较合适?

作者:中华石杉 面试题 redis 都有哪些数据类型?分别在哪些场景下使用比较合适? 面试官心理分析 除非是面试官感觉看你简历,是工作 3 年以内的比较初级的同学,可能对技术没有很深入的研究,面试官才会问这类问题.否则,在宝贵的面试时间里,面试官实在不想多问. 其实问这个问题,主要有两个原因: 看看你到底有没有全面的了解 redis 有哪些功能,一般怎么来用,啥场景用什么,就怕你别就会最简单的 KV 操作: 看看你在实际项目里都怎么玩儿过 redis. 要是你回答的不好,没说出几种数据类型,也没

Redis 数据结构与内存管理策略(下)

Redis 数据结构与内存管理策略(下) Redis 数据类型特点与使用场景 String.List.Hash.Set.Zset 案例:沪江团购系统大促 hot-top 接口 cache 设计 Redis 内存数据结构与编码 OBJECT encoding key.DEBUG OBJECT key 简单动态字符串(simple dynamic string) 链表(linked list) 字典(dict) 跳表(skip list) 整数集合(int set) 压缩表(zip list) Re

【深入学习Redis】主从复制(下)

(续上文) 六.应用中的问题 1. 读写分离及其中的问题 在主从复制基础上实现的读写分离,可以实现Redis的读负载均衡:由主节点提供写服务,由一个或多个从节点提供读服务(多个从节点既可以提高数据冗余程度,也可以最大化读负载能力):在读负载较大的应用场景下,可以大大提高Redis服务器的并发量.下面介绍在使用Redis读写分离时,需要注意的问题. 1.延迟与不一致问题 前面已经讲到,由于主从复制的命令传播是异步的,延迟与数据的不一致不可避免.如果应用对数据不一致的接受程度程度较低,可能的优化措施

redis学习(二) redis数据结构介绍以及常用命令

redis数据结构介绍 我们已经知道redis是一个基于key-value数据存储的数据结构数据库,这里的key指的是string类型,而对应的value则可以是多样的数据结构.其中包括下面五种类型: 1.string 字符串 string字符串类型是redis最基础的数据存储类型.string是最基础的一种数据类型,其可以拓展为某种特定类型,例如普通文本,json字符串,二进制数据等等.就本质上来说,接下来要介绍的hash,list,set等其内部最基础的组成单位依然是string,只不过re

Redis学习系列六ZSet(有序列表)及Redis数据结构的过期

一.简介 ZSet可以说是Redis中最有趣的数据结构了,因为他兼具了Hash集合和Set的双重特性,也是用的最多的,保证了value值的唯一性的同时,,同时又保证了高性能,最主要的是还可以给每个Value设置Source(权重),那么我们就可以通过权重进行排序,这在业务上是非常常见的,比如很多地方需要,比如我们需要对所有用户的数学成绩进行排序.对英语等等地例子比比皆是,那么通过ZSet,你将会得到一个响应速度非常快的过程.下面会介绍. ZSet的内部原理是通过跳跃列表来实现的,这里还是不想说太

学习Redis(二)

自关系型DB诞生40年来,从理论产生到现实产品(MySQL.Oracle),已在DB领域上升到了霸主地位,每年数百亿$的庞大产业市场: 随着web2.0的兴起,对于规模日益庞大的海量数据,传统的关系型DB显得力不从心,如超大规模和高并发的微博.微信.SNS(socail network site,socail network services)纯动态网站等,关系型DB面临很多难以克服的问题,有IO瓶颈.性能瓶颈都难以有效突破,于是出现了很多针对特定场景,以高性能和使用便利为目的的差异化的DB产品