redis常用命令,Redis常用命令
禁用长耗时的查询命令Redis绝大多数读写命令的时间复杂度都在O(1)到O(N)之间,在官方文档对每命令都有时间复杂度说明,如图所示:其中O(1)表示可以安全使用的,而O(N)就应该当心了,N表示不确定,数据越大查询的速度可能会越慢。因为Redis只用一个线程来做数据查询,如果这些指令耗时很长,就会阻塞Redis,造成大量延时。
Redis是啥?
想要了解Redis,先从Redis是什么?为何要用Redis?有哪些特性,以及其集群架构来几个方面来了解。Redis 简介Redis 是一个开源(BSD 许可)的、内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件。为什么要用 Redis在高并发场景下,如果需要经常连接结果变动频繁的数据库,会导致数据库读取及存取的速度变慢,数据库压力极大。
因此我们需要通过缓存来减少数据库的压力,使得大量的访问进来能够命中缓存,只有少量的需要到数据库层。由于缓存基于内存,可支持的并发量远远大于基于硬盘的数据库。所以对于高并发设计,缓存的设计是必不可少的一环。而 Redis 作为比较热门的内存存储系统之一,由于其对数据持久化的支持,种类丰富的数据结构,使其定位更倾向于内存数据库,适用于对读写效率要求都很高、数据处理业务复杂和对安全性要求较高的系统。
Redis 特征单线程,利用 redis 队列技术将访问变为串行访问,消除了传统数据库串行控制的开销。Redis 的线程模型:Redis 支持数据的持久化,包括 RDB 的全量持久化,或者 AOF 的增量持久化,从而使得Redis 挂了,数据是有机会恢复的。也可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用。
分布式架构,读写分离。支持的数据结构丰富。Redis 不仅仅支持简单的 key-value 类型的数据,同时还提供 list、set、zset、hash 等数据结构的存储。Redis 支持数据的备份,提供成熟的主备同步,故障切换的功能,从而保证了高可用。Redis Cluster 架构Redis 搭建方式有很多种,本章主要介绍 Redis Cluster 集群构建方式:Redis 3.0 之后版本支持 Redis Cluster 集群,Redis Cluster 采用无中心结构,每个节点保存数据和整个集群状态,每个节点都和其他所有节点连接。
Redis Cluster 为了保证数据的高可用性,加入了主从模式,一个主节点对应一个或多个从节点,主节点提供数据存取,从节点则是从主节点拉取数据备份,当这个主节点挂掉后,就会有这个从节点选取一个来充当主节点,从而保证集群不会挂掉。主从结构,一是为了纯粹的冗余备份,二是为了提升读性能,比如很消耗性能的 SORT 就可以由从服务器来承担。
redis有哪些数据类型?
Redis中的所有 value 都是以 Object 的形式存在的,其通用结构如下:typedef struct redisObject {unsigned [type] 4;unsigned [encoding] 4;unsigned [lru] REDIS_LRU_BITS;int refcount;void *ptr;} robj;type:指类型,String、Hash、List、Set、ZSet;encoding:类型具体的实现方式;比如 Set 是用 hashTable 实现还是 intSet 实现;lru:最后一次被访问的信息,其实一看到 LRU 估计也就和淘汰策略有关;refcount:对象引用计数;ptr:指向实际实现者的地址;StringRedis 中的 String 不仅仅表示 字符串,还可以表示 整型、浮点型。
String 的编码可以是 int、raw 或者 embstr;单说普通的字符串,就有 raw 和 embstr 两种实现方式,embstr 是 Redis 3.0 新增的数据结构:字符串长度小于 39 字节,就用 embstr 对象,否则用传统的raw对象(Redis 3.2版本之后,这里变成了以 44 字节为分界)。
embstr 的优势在于创建时少分配一次空间(RedisObject 和 sds 是连续的),删除时少释放一次空间,以及对象的所有数据连在一起,寻找方便;当然缺点也非常明显,如果字符串的长度增加,需要重新分配内存的时候,整个 RedisObject 和 sds 都需要重新分配空间。修改 embstr 对象的时候,Redis 会将其转换成 raw 格式再进行修改,所以 embstr 对象修改之后的对象,一定是 raw 的。
应用场景:常规计数都可以使用,可用作缓存、计数、限速等等,比如商品剩余数量,字典表信息,长度不能超过 512MB。HashHash 对象的底层实现可以是 ziplist 或者 hashtable。ziplist:在这个数据结构中,是按照 key1, value1, key2, value2 这样的顺序存放来存储的;hashTable:是由 dict 这个结构来实现的。
(这个结构比较复杂,后面单写一篇来说)应用场景:Hash 适用于存储结构化的对象,可以直接修改这个对象中的某个字段的值;比如用户信息。ListList 对象的编码可以是 ziplist 或者 linkedlist,从名字上也能看出来两种结构都是啥。ziplist:是一种压缩链表,它存储数据都是连续地放在内存区域当中。
linkedlist:是一种双向链表。应用场景:通常网站上的消息列表,可以使用 List 来进行存储;另外 lrange 命令,从某个元素开始,读取多少个元素,可以看做是分页查询,比如很多网站上那种不断下拉,不断分页的效果。SetSet 相对于 List 来说,Set 是可以自动排重的;它的编码可以是 intset 或者 hashtable 。
intset:是一个整数集合,支持三种长度的整数:int16_t、int32_t、int64_t;集合中的数据长度必须是一致的,比如一个 int16_t 长度的 Set,当插入了一条 int32_t 长度的数据,那么所有的数据都会转成 int32_t 长度(不支持降级)。hashTable:对于 Set 来说,hashTable 的 value 永远为 NULL。
应用场景:如果要存储一个列表,同时又需要做数据排重的时候,可以使用 set ;另外,Redis 还为 Set 提供了求交集、并集、差集等操作,比如微博上面的【共同关注】这个功能,就可以用 Set 实现。ZSet / Sorted Set和 Set 相比,ZSet 增加了一个参数 score,集合中的元素按照 score 进行有序排列。
有序集合的编码可能两种,一种是 ziplist,另一种是 skipList 与 hashTable 的结合。ziplist:和 Hash 类似,元素 和 score 都是按顺序存放的;比较适合用于元素内容不大的场景。skipList hashTable:是一种添加,移除,更新元素等操作更高效的数据结构,这个跳跃表的数据结构,我近期会发一篇文章单独介绍。
Redis面试题,为什么AOF文件往往大于RDB?为什么AOF恢复数据慢于RDB?aop存的是每一条指令,rdb存的是内存中的数据二进制备份,无论从结构还是数据上说,aof都会更大。
本文地址:http://cng.55jiaoyu.com/show-757983.html
本文由合作方发布,不代表展全思梦立场,转载联系作者并注明出处:展全思梦
推荐文档
- 11.往年大连中考满分是多少
- 12.为什么说学播音毁一生,原因有哪些
- 13.淘宝店铺的优质好评语大全
- 14.考研可改变第一学历吗、专科考研可以改变第一学历吗
- 15.民学网查出的学历国家承认吗(民学网查出的学历国家承认吗是真的吗)
- 16.往年轻薄商务笔记本电脑推荐-商务轻薄本性价比排行
- 17.承德护理职业学院(承德护理职业学院2023年招生计划)
- 18.wreak是什么意思wreak的翻译(wake,area是什么意思中文翻译)
- 19.电子科技大学A+类学科名单有哪些(含A、B、C类学科名单)
- 20.systematic是什么意思systematic的翻译(systematically是什么意思中文翻译)
- 21.leant是什么意思leant的翻译(lean,on什么意思中文意思)
- 22.华南农业大学是几本大学,华南农业大学是一本还是二本
- 23.包头中考考试科目时间预测安排,包头中考考哪几门考哪些课程
- 24.高考430分能上什么大学,430分高考能报啥学校
- 25.朱自清的散文代表作有什么(朱自清的散文代表作有什么散文集有什么散文诗集有什么)
- 26.浙江有几所大学是985和211,全国985和211大学名单汇总
- 27.i5,1155G7和R5,5600U哪款好-对比评测
- 28.荷兰什么叫-荷兰弟为什么叫荷兰弟,出演蜘蛛侠原因曝光
- 29.警察警衔工资改革新政策及新方案【全文】解读
- 30.电大专科(电大专科毕业论文)
- 31.广东省高级技工学校官网
- 32.广州大学专科
- 33.大连陆军学院,原大连陆军学院校址现在什么是什么学校
- 34.亲们,谁给一份南京大学的研究生招生简章?(河海大学
- 35.他日若遂凌云志全诗及出处
- 36.铜绿的化学式是什么有哪些性质
- 37.「佛山市顺德养正西山学校初中部」往年录取分数线
- 38.公办本科(公办本科和民办本科有什么区别)
- 39.外交学院是名牌大学吗
- 40.往年湖南高考成绩排名一分一段表
- 41.全国有8所烟草院校是哪些(这4所大学门槛低)
- 42.私人垄断资本主义基本概念是私人垄断资本主义
- 43.难以启齿,这8部影片可以一看(性教育适合看的影片)
- 44.美国独立战争的性质爆发战争的原因是什么
- 45.往年东莞市高中排名前十最新
- 46.大朗网络教育(大朗教育)
- 47.往年甘肃省高中排名最好的高中
- 48.逻辑思维训练有哪些方法优秀训练方法推荐
- 49.浙江大学教务管理系统
- 50.人类的动物老师有哪些这属于什么学科
- 51.往年山西高考状元榜_山西历届高考理科状元和文科状元
- 52.往年北京舞蹈学院艺术类招生简章招生人数及专业
- 53.航空最好的5个专业就业前景如何
- 54.太原科技大学怎么样及评价好不好太原科技大学口碑如何
- 55.满招损谦受益这句话的意思是什么出自哪
- 56.舍本逐末发生在什么时期含义是什么
- 57.女孩子首选十大专业什么专业适合女生
- 58.国防生是什么意思指的是什么
- 59.河南省三本学院有哪些2018最新三本院校名单
- 60.往年龙岩高中学校排名榜单龙岩十大优秀高中
- 51.什么是天网监控系统,如何让公安天网监控系统运维变简单
- 52.诺基亚全部手机图片,nokia所有手机图片
- 53.什么牌子的手机信号好,国产手机信号强排行榜
- 54.市府恒隆广场多少层,沈阳市府恒隆广场
- 55.华唐手机官网,华唐手机官网
- 56.库乐队怎么添加本地音乐(如何把库乐队的音乐变成本地的音乐)
- 57.毒化检验是什么,它会告诉法医什么呢
- 58.移动136号段手机号码选号,成都移动网上选号136
- 59.旅游资源采购是干什么的,「旅游资源采购招聘信息」
- 60.PCS7,pcs7与step7有何区别
- 61.为什么招标公告上有工程量清单,工程量清单由谁负责编制
- 62.哈尔滨中润物业挣多少,中润物业被上限处罚
- 63.贵港雅苑会所在哪里,你知道在哪里吗
- 64.磁场刺激仪治疗什么,从脑袋入手治疗全身疾病
- 65.设计委托怎么走政府采购,政府采购的组织形式
- 66.三网通工程是什么,全网联三网融合
- 67.保民农场怎么样,记悦来镇保民村党总支
- 68.青藏线是什么国道路标,更原始更震撼的是青藏线
- 69.茅店属于什么区,丈夫报警捉妻子
- 70.室外走廊地面怎么做,幼儿园走廊地面设计

