本文由葡萄城技术团队于 V2EX 首发
转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具、解决方案和服务,赋能开发者。
在 Web 应用发展的初期,那时关系型数据库受到了较为广泛的关注和应用,原因是因为那时候 Web 站点基本上访问和并发不高、交互也较少。而在后来,随着访问量的提升,使用关系型数据库的 Web 站点多多少少都开始在性能上出现了一些瓶颈,而瓶颈的源头一般是在磁盘的 I/O 上。而随着互联网技术的进一步发展,各种类型的应用层出不穷,这导致在当今云计算、大数据盛行的时代,对性能有了更多的需求,主要体现在以下四个方面:
为了克服这一问题,NoSQL 应运而生,它同时具备了高性能、可扩展性强、高可用等优点,受到广泛开发人员和仓库管理人员的青睐。
Redis 是现在最受欢迎的 NoSQL 数据库之一,Redis 是一个使用 ANSI C 编写的开源、包含多种数据结构、支持网络、基于内存、可选持久性的键值对存储数据库,其具备如下特性:
相比于其他数据库类型,Redis 具备的特点是:
Redis 的应用场景包括:缓存系统(“热点”数据:高频读、低频写)、计数器、消息队列系统、排行榜、社交网络和实时系统。
Redis 提供的数据类型主要分为 5 种自有类型和一种自定义类型,这 5 种自有类型包括:String 类型、哈希类型、列表类型、集合类型和顺序集合类型。
它是一个二进制安全的字符串,意味着它不仅能够存储字符串、还能存储图片、视频等多种类型, 最大长度支持 512M。
对每种数据类型,Redis 都提供了丰富的操作命令,如:
该类型是由 field 和关联的 value 组成的 map。其中,field 和 value 都是字符串类型的。
Hash 的操作命令如下:
该类型是一个插入顺序排序的字符串元素集合, 基于双链表实现。
List 的操作命令如下:
Set 类型是一种无顺序集合, 它和 List 类型最大的区别是:集合中的元素没有顺序, 且元素是唯一的。
Set 类型的底层是通过哈希表实现的,其操作命令为:
Set 类型主要应用于:在某些场景,如社交场景中,通过交集、并集和差集运算,通过 Set 类型可以非常方便地查找共同好友、共同关注和共同偏好等社交关系。
ZSet 是一种有序集合类型,每个元素都会关联一个 double 类型的分数权值,通过这个权值来为集合中的成员进行从小到大的排序。与 Set 类型一样,其底层也是通过哈希表实现的。
ZSet 命令:
Redis 的数据结构如下图所示:
关于上表中的部分释义:
如下是定义一个 Struct 数据结构的例子:
基于 C 语言中传统字符串的缺陷,Redis 自己构建了一种名为简单动态字符串的抽象类型,简称 SDS,其结构如下:
SDS 几乎贯穿了 Redis 的所有数据结构,应用十分广泛。
和 C 字符串相比,SDS 的特点如下:
常数复杂度获取字符串长度
Redis 中利用 SDS 字符串的 len 属性可以直接获取到所保存的字符串的长度,直接将获取字符串长度所需的复杂度从 C 字符串的 O(N)降低到了 O(1)。
减少修改字符串时导致的内存重新分配次数
通过 C 字符串的特性,我们知道对于一个包含了 N 个字符的 C 字符串来说,其底层实现总是 N+1 个字符长的数组(额外一个空字符结尾)那么如果这个时候需要对字符串进行修改,程序就需要提前对这个 C 字符串数组进行一次内存重分配(可能是扩展或者释放)而内存重分配就意味着是一个耗时的操作。
Redis 巧妙的使用了 SDS 避免了 C 字符串的缺陷。在 SDS 中,buf 数组的长度不一定就是字符串的字符数量加一,buf 数组里面可以包含未使用的字节,而这些未使用的字节由 free 属性记录。
与此同时,SDS 采用了空间预分配的策略,避免 C 字符串每一次修改时都需要进行内存重分配的耗时操作,将内存重分配从原来的每修改 N 次就分配 N 次——>降低到了修改 N 次最多分配 N 次。
如下是 Redis 对 SDS 的简单定义:
以上就是 Redis 的基本概念,下面我们将介绍在开发过程中可能会踩到的“坑”。
下面我们来简单了解一下 Redis 的进阶知识。
Redis 客户端通讯协议:RESP(Redis Serialization Protocol),其特点是:
Redis 集群内部通讯协议:RECP(Redis Cluster Protocol ) ,其特点是:
Redis 协议支持的数据类型:
“+OK\r\n”
“-error msg\r\n”
“:123\r\n”
“&hello\r\nWhoa re you\r\n”
“*0\r\n”
“*-1\r\n”
以上就是 Redis 入门介绍教程,如果各位还想了解更多,欢迎通过评论和私信的方式告诉我。
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.