Redis

维基百科,自由的百科全书
跳转至: 导航搜索
Redis
200px
開發者 Salvatore Sanfilippo
初始版本 2009年4月10日;5年前 (2009-04-10)
穩定版本 2.8.12 / 2014年6月23日;58天前 (2014-06-23)
编程语言 ANSI C
操作系统 跨平台
语言 英语
类型 非关系型数据库
许可协议 BSD
網站 redis.io

Redis是一个开源、支持网络、基于内存、键值对存储数据库,使用ANSI C编写。从2013年5月开始,Redis的开发由Pivotal赞助。[1]在这之前,其开发由VMware赞助。[2][3]根据月度排行网站DB-Engines.com的数据显示,Redis是最流行的键值对存储数据库。[4]

支持语言[编辑]

许多语言都包含Redis支持,包括:[5]

数据模型[编辑]

Redis的外围由一个键、值映射的字典构成。与其他非关系型数据库主要不同在于:Redis中值的类型不仅限于字符串,还支持如下抽象数据类型:

值的类型决定了值本身支持的操作。Redis支持不同无序、有序的列表,无序、有序的集合间的交集、并集等高级服务器端原子操作。

持久化[编辑]

Redis通常将全部的数据存储在内存中。2.4版本后可配置为使用虚拟内存[7]一部分数据集存储在硬盘上,但这个特性废弃了。

目前通过两种方式实现持久化

  • 使用快照,一种半持久耐用模式。不时的将数据集以异步方式从内存以RDB格式写入硬盘。
  • 1.1版本开始使用更安全的AOF格式替代,一种只能追加的日志类型。将数据集修改操作记录起来。Redis能够在后台对只可追加的记录作修改来避免無限增长的日志。

同步[编辑]

Redis支持主从同步。数据可以从主服务器向任意数量的从服务器上同步,从服务器可以是关联其他从服务器的主服务器。这使得Redis可执行单层树复制。从盘可以有意无意的对数据进行写操作。由于完全实现了发布/订阅机制,使得从数据库在任何地方同步树时,可订阅一个频道并接收主服务器完整的消息发布记录。同步对读取操作的可扩展性和数据冗余很有帮助。[8]

性能[编辑]

当数据依赖不再需要,Redis这种基于内存的性质,与在执行一个事务时将每个变化都写入硬盘的数据库系统相比就显得执行效率非常高。[9]写与读操作速度没有明显差别。

使用Redis的公司[编辑]

参见[编辑]

引用[编辑]

  1. ^ Redis Sponsors – Redis
  2. ^ VMware: the new Redis home
  3. ^ VMWare: The Console: VMware hires key developer for Redis
  4. ^ DB-Engines Ranking of Key-value Stores
  5. ^ Redis language bindings
  6. ^ CRAN - Package rredis
  7. ^ Redis documentation "Virtual Memory", redis.io, accessed January 18, 2011.
  8. ^ ReplicationHowto - redis - A persistent key-value database with built-in net interface written in ANSI-C for Posix systems - Google Project Hosting
  9. ^ FAQ. 

外部链接[编辑]