导读:本文带你了解Redis,再推荐4本关于Redis的书。
Redis从一个不为人熟知、只有少量应用的崭新数据库,逐渐变成了内存数据库领域的事实标准。时至今日,经过大量的实践应用,Redis简洁高效、安全稳定的特性已经深入人心。
无论是国内还是国外,从五百强公司到小型初创公司都在使用Redis,很多云服务提供商还以Redis为基础构建了相应的缓存服务、消息队列服务以及内存存储服务,当你使用这些服务时,实际上就是在使用Redis。
Redis是一个主要由Salvatore Sanfilippo(Antirez)开发的开源内存数据结构存储器,经常用作数据库、缓存以及消息代理等。
Redis因其丰富的数据结构、极快的速度、齐全的功能而为人所知,它是目前内存数据库方面的事实标准,在互联网上有非常广泛的应用,微博、Twitter、GitHub、Stack Overf?low、知乎等国内外公司都大量地使用了Redis。
Redis之所以广受开发者欢迎,跟它自身拥有强大的功能以及简洁的设计不无关系。
Redis最重要的特点有以下几种(参见下图):
1. 结构丰富
Redis为用户提供了字符串、散列、列表、集合、有序集合、HyperLogLog、位图、流、地理坐标等一系列丰富的数据结构,每种数据结构都适用于解决特定的问题。
在有需要的时候,用户还可以通过事务、Lua脚本、模块等特性,扩展已有数据结构的功能,甚至从零实现自己专属的数据结构。通过这些数据结构和特性,Redis能够确保用户可以使用适合的工具去解决问题。
2. 功能完备
在上述数据结构的基础上,Redis提供了很多非常实用的附加功能,比如自动过期、流水线、事务、数据持久化等,这些功能能够帮助用户将Redis应用在更多不同的场景中,或者为用户带来便利。
更重要的是,Redis不仅可以单机使用,还可以多机使用:通过Redis自带的复制、Sentinel和集群功能,用户可以将自己的数据库扩展至任意大小。
无论你运营的是一个小型的个人网站,还是一个为上千万消费者服务的热门站点,都可以在Redis中找到你想要的功能,并将其部署到你的服务器中。
3. 速度飞快
Redis是一款内存数据库,它将所有数据存储在内存中。因为计算机访问内存的速度要远远高于访问硬盘的速度,所以与基于硬盘设计的传统数据库相比,Redis在数据的存取速度方面具有天然的优势。
但Redis并没有因此放弃在效率方面的追求,相反,Redis的开发者在实现各项数据结构和特性的时候都经过了大量考量,在底层选用了很多非常高效的数据结构和算法,以此来确保每个操作都可以在尽可能短的时间内完成,并且尽可能地节省内存。
4. 用户友好
“虽然Redis提供了很多很棒的数据结构和特性,但如果它们使用起来非常困难的话,那么这一切就没有意义。”如果你对此有所担心的话,那么现在可以打消你的顾虑了!Redis API遵循的是UNIX“一次只做一件事,并把它做好”的设计哲学。
Redis的API虽然丰富,但它们大部分都非常简短,并且只需接受几个参数就可以完成用户指定的操作。更棒的是,Redis在官方网站(redis.io)上为每个API以及相关特性都提供了详尽的文档,并且客户端本身也可以在线查询这些文档。
当你遇到文档无法解决的问题时,还可以在Redis项目的GitHub页面:
github.com/antirez/redis
Google Group:
groups.google.com/forum/#!forum/redis-db
甚至作者的Twitter上提问:
twitter.com/antirez
5. 支持广泛
正如之前所说,Redis已经在互联网公司得到广泛应用,许多开发者为不同的编程语言开发了相应的客户端(redis.io/clients),大多数编程语言的使用者都可以轻而易举地找到所需的客户端,然后直接开始使用Redis。
此外,包括亚马逊、谷歌、RedisLabs、阿里云和腾讯云在内的多个云服务提供商都提供了基于Redis或兼容Redis的服务,如果你不打算自己搭建Redis服务器,那么上述提供商可能是不错的选择。
Redis这么好,要不要现在就学起来?我们这就给你推荐4本书:
推荐语:资深 Redis 技术专家撰写,深入了解 Redis 技术内幕的必读之作。从源码角度解析 Redis 的架构设计、实现原理和工作机制,为高效使用 Redis 提供原理性指导。
推荐语:《Redis设计与实现》作者黄健宏全新力作,涵盖Redis5.0以上版本,掌握Redis的案头必备参考书。
推荐语:从开发、运维两个角度总结了Redis实战经验,深入浅出地剖析底层实现,包含大规模集群开发与运维的实际案例、应用技巧。全面覆盖Redis 基本功能及应用,图示丰富,讲解细腻。
推荐语:多名专家联袂推荐,资深专家联合撰写,深入理解Redis 5设计精髓。系统讲解Redis 5设计、数据结构、底层命令实现,以及持久化、主从复制、集群。