Redis整体面貌

Redis基本数据结构

  1. 1String
  2. 1.1 数据结构
  3. long len byte数组长度
  4. long free 可用数组长度
  5. char buff[] 数据内容
  6. 1.2 命令
  7. 键值:设置值通过字符串名
  8. set:设置键值
  9. setnx(set not exist):设置键值|若键不存在则可以存,否则返回0.
  10. setex(set expire):设置键值(含过期时间),set key seconeds value
  11. setrange:设置指定位置key的键值 例如setrange name diaodiao 2 haha-->dihahaao 从第二个位置开始替换
  12. mset:设置多个键值
  13. msetnx:设置多个不存在的键值
  14. get:通过键获得值
  15. getset:先通过键获得值,再设置值。
  16. getrange(0~-1):获取指定范围的字符。范围|从左往右数从0开始 从右往左数-1开始。例如hello0~4|-5~-1
  17. mget:获得多个键的值。
  18.     数字类型相关操作
  19.     set age </span>10<span style="color: #000000;">(以下操作都是针对10操作)
  20.     incr 递增1 incr age</span>--&gt;11<span style="color: #000000;">
  21.     incrby 递增指定数字</span>--&gt;incr age 5-&gt;16<span style="color: #000000;">
  22.     decr 递减1
  23.     decrby 递减指定值
  24.     字符属性操作
  25.     set name </span>"hello"<span style="color: #000000;">
  26.     append:在尾部追加字符串 append name </span>"Diaodiao"-&gt;<span style="color: #000000;">helloDiaodiao
  27.     strlen: 获得字符串长度 strlen name </span>-&gt;5
  28.  
  29. 2hashes(存储键值对,类似于hashmap)

  30. 2.1 配置(redis.conf配置文件中)

  31. 默认:hash-max-zipmap-entries 配置字段最多64个(key的个数)

  32. hash-max-zipmap-value 配置value最大为512字节

  33. 2.2 命令(参考String)

  34. hset key field value

  35. hset:若key不存在就创建,否则覆盖。

  36. hsetnx:设置 hash field 为指定值,如果 key 不存在,则先创建。如果 field 已经存在,返回 0nx not exist 的意思。

  37. hmset:同时设置hash多个field

  38. hget:获取指定的hash field

  39. hmget:获取全部指定的hash field

  40. hexists:测试指定field是否存在

  41. hlen:返回指定的field的个数

  42. hdel:删除指定field

  43. hkeys:查询指定key的所有field

  44. hvals:获取指定key的所有value

  45. hgetall:获得指定key的所有field以及值

  46. 3lists

  47. 3.1 简介

  48. list是基于双向链表的数据结构,操作就是入栈(push)、出栈(pop),包括左(头)入出栈、右(尾)入出栈,也含有超时阻塞的功能。

  49. 3.2 命令

  50. lpush:在key对应的list的头部添加元素。

  51. lrange:获得list范围的值。 lrange mylist start(0) stop(2)(获取0 1 2索引的值)

  52. rpush:在key对应的list的尾部添加元素

  53. linsert:在key对应的特定位置之前或者之后添加字符串元素 linsert mylist before world hello

  54. lset:设置list指定下表的元素(从0开始)

  55. lrem:从key对应的list里,删除countvalue相同的元素。

  56. ltrim:保留指定key的值范围内的数据。

  57. lpop:从list的头部删除元素,并且返回删除元素

  58. rpop:从list的尾部删除元素,并且返回删除元素

  59. rpoplpush:第一个list的尾部移除元素并且添加到第二个list的头部

  60. lindex:返回名称为keylistindex位置的元素

  61. llen:返回key对应list的长度

  62. 4sets

  63. 4.1 简介

  64. sets是无序集合,是通过hashtable实现的。额外功能有并集、交集、差集。

  65. 4.2 命令

  66. sadd:向名称为keyset当中添加元素

  67. srem:删除名称为key的元素

  68. spop:随机返回并且删除set中某key元素

  69. sdiff:两个set的差集

  70. sdiffstore:假设有set3set1set2-->set1set2差集返回的元素,添加到set3

  71. sinter:两个set的交集

  72. sinterstore:假设有set3set1set2-->set1set2交集返回的元素,添加到set3

  73. sunion:两个set的并集

  74. sunionstore:假设有set3set1set2-->set1set2交集返回的元素,添加到set3

  75. smove:假设有set1set2-->删除set1的某个key值,并且添加到set2

  76. scard:返回set的元素个数

  77. sismember:测试set中是否存在某member(元素)。

  78. srandmember:随机返回一个元素,但是不删除

  79. 5sorted set

  80. 5.1 简介

  81. sorted set(skip list|双向链表和hashtable的结合体)是set的一个升级版本,升级版本的sets,有两个纬度,一个纬度用来存顺序,一个纬度用于存value

  82. 5.2 命令

  83. zadd:向名称为keyzset中添加元素memberscore用于排序。如果该元素存在,则根据score更新该元素的顺序

  84. zrem:删除名为keyzset的元素member

  85. zincrby:如果在名称为 key zset 中已经存在元素 member,则该元素的 score 增加 increment;否则向集合中添加该元素,其 score 的值为 increment

  86. zrank:返回名称为 key zset member 元素的排名(按 score 从小到大排序)即下标

  87. zrevrank:返回名称为 key zset member 元素的排名(按 score 从大到小排序)即下标

  88. zrange:返回名称为 key zset(按 score 从小到大排序)中的 index start end 的所有元素

  89. zrevrange:返回名称为 key zset(按 score 从大到小排序)中的 index start end 的所有元素

  90. zrangebyscore:返回集合中 score 在给定区间的元素

  91. zcount:返回集合中 score 在给定区间的数量

  92. zcard:返回集合中元素个数

  93. zscore:返回给定元素对应的 score

  94. zremrangebyrank:删除集合中排名在给定区间的元素

  95. zremrangebytscore:删除集合中 score 在给定区间的元素

Redis常用命令

  1. 1、键值相关命令
  2. keys *|key*|key???
  3. exists key:确认一个 key 是否存在
  4. del key:删除一个 key
  5. expire key seconeds:设置一个 key 的过期时间(单位:秒)
  6. move:将当前数据库中的 key 转移到其它数据库中。
  7. persist:移除给定 key 的过期时间
  8. ttl:查看过期还需要多长时间
  9. randomkey:随机返回命名空间的一个key
  10. renamekey:重命名key
  11. type:返回值类型
  12. </span>2<span style="color: #000000;">、元务器相关命令
  13.     ping:测试连接是否存活
  14.     echo:在命令行打印一些内容
  15.     select:选择数据库。Redis 数据库编号从 </span>0~15<span style="color: #000000;">,我们可以选择任意一个数据库来进行数据的存取。
  16.     quit:退出连接。
  17.     dbsize:返回当前数据库中 key 的数目。
  18.     info:获取服务器的信息和统计。
  19.     monitor:实时转储收到的请求。
  20.     config:获取服务器配置信息。
  21.     flushdb:删除当前选择数据库中的所有 key
  22.     flushall:删除所有数据库中的所有 key。</span></span></pre>
  23.  

Redis高级使用属性

  1. 1、安全性:设置每次命令之前都要确认密码|在redis.conf配置文件中修改 requirepass
  2. 2、主从复制
  3. 2.1 特点
  4. (1)master可以拥有多个slave
  5. (2)多个slave可以连接同一个master外,还可以连接其他slave
  6. (3)主从复制不会阻塞master,同步数据,master可以继续处理client
  7. (4)提高系统的伸缩性
  8. 2.2、搭建过程
  9. 参考:http://www.cnblogs.com/qiuyong/p/6705689.html
  10. 3、事务控制
  11. 3.1 简单事务控制
  12. multi-->事务begin
  13. exec-->退出提交
  14. 3.2 事务回滚
  15. muliti-->事务begin
  16. discard-->事务回滚
  17. 4、持久化
  18. 4.1 snapshotting(默认)-快照方式
  19. 将数据以快照的方式写入到二进制文件中,也是dump.rpb。执行savebgsave的时候会对dump.rpb
  20. 保存方式
  21. save:手动存储、阻塞当前线程,把内存数据存到dump.rpb中。
  22. bgsave:开启子线程、调用fork操作,后台将内存数据存到dump.rpb中。
  23. redis.conf中默认设置为自动bgsave
  24. 缺陷:
  25. 假设有client1client2.
  26. client1执行flushall、把内存数据全部清除。
  27. client2执行的时候,因为之前数据在未知情况下被清除,这样就会造成很大的麻烦。
  28. 通常情况下,我们先把save之前,把相应dump.rpb转移到其他目录下进行保存,利于数据恢复。
  29. 4.2 aof(append-only file)-->如果应用要求不能丢失任何修改的话,可以采用 aof 持久化方式
  30. 机制:默认每隔一秒,redis会收到写命令,把内容追加到appendonnly.aof文件中。
  31. 配置redis.conf
  32. appendonly yes //启用 aof 持久化方式
  33. # appendfsync always //收到写命令就立即写入磁盘,最慢,但是保证完全的持久化
  34. appendfsync everysec //每秒钟写入磁盘一次,在性能和持久化方面做了很好的折中
  35. # appendfsync no //完全依赖 os,性能最好,持久化没保证
  36. 5、发布及订阅消息
  37. 5.1 订阅者 subscribe 通道(频道)例如tv1/tv2/tv3 psubscribe tv*例如tv开头的消息都能收到
  38. 5.2 发送者 publish tv1 message
  39. 5.3 退出订阅模式:unsubscribeunpsubscribe
  40. 6Pipeline 批量发送请求
  41. 1、普通方式
  42. 基于tcp的连接方式,每次都要等着回复才能执行
  43. 2Pipeline方式
  44. 多个命令执行完以后,然后把执行结构返回给客户端。
  45. 7、虚拟内存相关配置
  46. vm-enabled yes #开启 vm 功能
  47. vm-swap-file /tmp/redis.swap #交换出来的 value 保存的文件路径
  48. vm-max-memory 1000000 #redis 使用的最大内存上限
  49. vm-page-size 32 #每个页面的大小 32 个字节
  50. vm-pages 134217728 #最多使用多少页面
  51. vm-max-threads 4 #用于执行 value 对象换入换出的工作线程数量

Redis 持久化磁盘 IO 方式及其带来的问题

  有 Redis 线上运维经验的人会发现 Redis 在物理内存使用比较多,但还没有超过实际物理内存总容量时就会发生不稳定甚至崩溃的问题,有人认为是基于快照方式持久化的 fork 系统调用造成内存占用加倍而导致的,这种观点是不准确的,因为 fork 调用的 copy-on-write 机制是基于操作系统页这个单位的,也就是只有有写入的脏页会被复制,但是一般你的系统不会在短时间内所有的页都发生了写入而导致复制,那么是什么原因导致 Redis 崩溃的呢?
 
  答案是 Redis 的持久化使用了 Buffer IO 造成的,所谓 Buffer IO 是指 Redis 对持久化文件的写入和读取操作都会使用物理内存的 Page Cache,而大多数数据库系统会使用 Direct IO 来绕过这层 Page Cache 并自行维护一个数据的 Cache,而当 Redis 的持久化文件过大(尤其是快照文件),并对其进行读写时,磁盘文件中的数据都会被加载到物理内 存中作为操作系统对该文件的一层 Cache,而这层 Cache 的数据与 Redis 内存中管理的数据实际是重复存储的,虽然内核在物理内存紧张时会做 Page Cache 的剔除工作,但内核很可能认为某块 Page Cache 更重要,而让你的进程开始 Swap,这时你的系统就会开始出现不稳定或者崩溃了。我们的经验是当你的 Redis 物理内存使用超过内存总容量的3/5时就会开始比较危险了。
  
  总结:
  1. 根据业务需要选择合适的数据类型,并为不同的应用场景设置相应的紧凑存储参数。
  2. 当业务场景不需要数据持久化时,关闭所有的持久化方式可以获得最佳的性能以及最大的内存使用量。
  3. 如果需要使用持久化,根据是否可以容忍重启丢失部分数据在快照方式与语句追加方式之间选择其一,不要使用虚拟内存以及 diskstore 方式。
  4. 不要让你的 Redis 所在机器物理内存使用超过实际内存总量的3/5。

Redis-用思维导图二天搞定Redis用法。的更多相关文章

  1. JavaSE思维导图(二)

  2. 面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)

    Redis 面试题 1.什么是 Redis?. 2.Redis 的数据类型? 3.使用 Redis 有哪些好处? 4.Redis 相比 Memcached 有哪些优势? 5.Memcache 与 Re ...

  3. 【转】面试还搞不懂redis,快看看这40道Redis面试题(含答案和思维导图)

    ———————————————— 版权声明:本文为CSDN博主「程序员追风」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明. 原文链接:https://blog. ...

  4. redis基础知识思维导图

    看到一张redis的基础知识思维导图,比较清晰, 但是没有标明来源,希望知道的给个地址,我也好说明来源 图大小有1M多.在博客上看比较模糊,可以先下载下来查看,或者在浏览器新标签中打开图片查看,就比较 ...

  5. mybatis思维导图(二)

    写在前面 上一篇文章写了mybatis的基本原理和配置文件的基本使用,这一篇写mybatis的使用,主要包括与sping集成.动态sql.还有mapper的xml文件一下复杂配置等.值得注意的是,导图 ...

  6. 查漏补缺:2020年搞定SpringCloud面试(含答案和思维导图)

    前言 Spring Cloud是一系列框架的有序集合.它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册.配置中心.消息总线.负载均衡.断路器.数据监控等,都 ...

  7. JS高程读书笔记-第一、二章-内附在线思维导图和quizlet卡片

    之前在kindle上买了高程,今天又到了纸质的<JavaScript语言精粹>,<高性能JavaScript>,<JavaScipt设计模式>,开始读书之旅啦. 我 ...

  8. mistral 工作流组件之二 思维导图

    Mistral 思维导图

  9. [原创] 思维导图笔记(二):SQL

    为了补一补知识体系上的缺漏,最近找了看完了Ben Forta写的<Sams Teach Yourself SQL in 10 Minutes>,翻译过来叫<SQL必知必会>.从 ...

随机推荐

  1. cin循环输入控制问题

    之前写一个简单的输入节点值自动生成链表的测试程序,发现cin的输入控制好像在VC++6.0和VS2010中不一样,特此记录. 现在有以下代码: vector<int> ivec; int ...

  2. juery中监听input的变化事件

    $('#searchValue').bind('input propertychange', function() { searchFundList(); });

  3. Windows下Oracle数据库自动备份批处理脚本

    expdb命令版本 @echo off REM ########################################################### REM # Windows Se ...

  4. oracle只要第一条数据SQL

    select * from ( select * from COMMON_BIZREL_WF where sponsor is not null order by serialid ) where r ...

  5. linux -j 4

    把源码编译成可执行的二进制文件, 4为服务器内核数

  6. caffe使用finetume

    训练时, solver.prototxt中使用的是train_val.prototxt ./build/tools/caffe/train -solver ./models/bvlc_referenc ...

  7. Floyd_Warshall(任意两点之间的最短路)

    /* O(V^3) 案例: 1 2 2 1 3 5 2 3 1 */ #include <cstdio>#include <iostream>using namespace s ...

  8. css实现一行居中显示,两行靠左显示

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. elk搭建实战

    1 安装elasticsearch 1.1安装elasticsearch 相关中文文档:https://es.xiaoleilu.com 下载:从https://www.elastic.co/down ...

  10. centos 下tomcat 自动启动

    1.修改start.sh文件 vim /usr/local/tomcat8/bin/startup.sh 在文件头增加以下内容: #!/bin/sh # chkconfig: 2345 97 00 # ...