Redis安装

下载地址:http://redis.io/download安装步骤:1、yum install gcc2、wget http://download.redis.io/releases/redis‐5.0.3.tar.gztar xzf redis‐5.0.3.tar.gzcd redis‐5.0.33、make4、src/redis‐server redis.conf(注意要使用后台启动,所以修改redis.conf里的daemonize改为yes)5、ps ‐ef | grep redis6、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中储存的数字值加1DECR key //将key中储存的数字值减1INCRBY key increment //将key所储存的值加上incrementDECRBY 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:201908194)展示七日排行前十ZREVRANGE hotNews:20190813-20190819 0 10 WITHSCORES

redis 获取所有的key_在微博微信场景下学习Redis数据结构相关推荐

  1. 微博直播场景下,如何实现百万并发的答题互动系统

    内容来源:2018 年 09 月 07 日,新浪微博系统开发工程师陈浩在"RTC2018 实时互联网大会"进行<微博直播场景下百万并发的消息互动系统>演讲分享.IT 大 ...

  2. 获取小程序short url 链接 微信场景打开

    1 $wxapp = new Wxapp($config);$res = $wxapp->getTempShortUrl('pages/shop/', '?ru_id='.$ru_id.'&am ...

  3. redis存储图片_一不小心肝出了4W字的Redis面试教程

    本文脑图 redis基本数据结构 本文脑图 前言 Redis是基于c语言编写的开源非关系型内存数据库,可以用作数据库.缓存.消息中间件,这么优秀的东西客定要一点一点的吃透它. 这是关于Redis五种数 ...

  4. 学习Redis这一篇就够了

    这里写目录标题 本文脑图 redis基本数据结构 本文脑图 前言 Redis核心对象 String类型 int SDS SDS与c语言字符串对比 String类型应用 Hash类型 字典 rehash ...

  5. centos / Linux 服务环境下安装 Redis 5.0.3

    centos / Linux 服务环境下安装 Redis 5.0.3 原文:centos / Linux 服务环境下安装 Redis 5.0.3 1.首先进入你要安装的目录 cd /usr/local ...

  6. Mac OS Catalina (10.15)下编译Redis Desktop Manager(RDM)

    前言 Redis Desktop Manager(RDM) 是个简单易用的GUI Redis 管理工具,支持跨平台.现在Redis Desktop Manager官网已经不在提供编译好的下载来使用,改 ...

  7. 解决docker下安装redis后,RedisDesktopManager可以链接,但是springboot项目不能链接的问题

    主要原因:docker中的redis需要添加密码,不然数据会丢失,添加了密码远程访问的时候可能会出现链接不上,密码报错等问题,是因为docker中的redis版本是随时更新的,可以用 docker i ...

  8. QRCode 扫描二维码、扫描条形码、相册获取图片后识别、生成带 Logo 二维码、支持微博微信 QQ 二维码扫描样式...

    QRCode 扫描二维码.扫描条形码.相册获取图片后识别.生成带 Logo 二维码.支持微博微信 QQ 二维码扫描样式 参考链接:https://github.com/bingoogolapple/B ...

  9. formdata.append加多个值_redis的五种数据结构和应用场景:微博微信点赞+加购物车等...

    Redis五种数据结构如下: 1.String 字符串类型 是redis中最基本的数据类型,一个key对应一个value. String类型是二进制安全的,意思是 redis 的 string 可以包 ...

最新文章

  1. 对java多线程里Synchronized的思考
  2. 成功部署SD-WAN策略应注意的几个事项—Vecloud微云
  3. Ant Design入门之介绍
  4. centos6编译安装MYSQL8_CentOS 6.4编译安装MySQL8.0
  5. 20151118小问题
  6. 第十七章 我国农业科学技术
  7. STL之Vector(Linux内核)完整实现
  8. Django模型之Meta选项详解
  9. 值类型和引用类型和数据大小排名
  10. cocos 发布android 返回值2,用cocos creator打包发布的时候,编译失败是怎么回事?执行命令出错,返回值:1。...
  11. 轻松玩转windows7之一:利用无线玩转虚拟网络
  12. python机器人编程教材_python人工智能机器人工具书籍: Learn Robotics Programming(python and Raspberry Pi 3) - 2018...
  13. 芯片数据手册下载和阅读
  14. javaScript、PHP连接外卖小票机打印机方案(调用佳博、芯烨等)
  15. 【Ubuntu+Caffe+CPU】Cannot use GPU in CPU-only Caffe: check mode
  16. 提升自我的42个实用技巧
  17. 多维数组扁平化的方法
  18. DDD基础 (实体 值对象)
  19. Python使用rawpy获取相机图像的原始RAW数据
  20. 如何设置计算机的网络参数,如何为计算机新手简单地设置路由器的基本参数

热门文章

  1. 搭建直播源码与软件开发的注意事项
  2. 停止对人类的迷恋!AI完全模仿人类大脑是在浪费时间
  3. Android中你可能忽略的知识点(1)-分辨率那些事
  4. css优雅降级和渐进增强
  5. Python元祖,列表,字典,集合的比较
  6. Dev Treelist使用经验(2)
  7. Hadoop集群下进行集成测试的小策略
  8. Resharper进阶一:简要介绍
  9. JavaScript遇到浏览器不兼容与解决方案
  10. AFNetWork 学习资源....