跳转到内容

Redis

本页使用了标题或全文手工转换
维基百科,自由的百科全书

这是本页的一个历史版本,由InternetArchiveBot留言 | 贡献2021年2月8日 (一) 18:26 (补救18个来源,并将0个来源标记为失效。) #IABot (v2.0.8)编辑。这可能和当前版本存在着巨大的差异。

Redis
開發者Salvatore Sanfilippo英语Salvatore Sanfilippo
首次发布2009年5月10日,​15年前​(2009-05-10
当前版本
  • 7.2.5 (2024年5月19日;穩定版本)[1]
編輯維基數據鏈接
源代码库 編輯維基數據鏈接
编程语言ANSI C
操作系统跨平台
语言英语
类型非关系型数据库
许可协议BSD
网站redis.io 编辑维基数据

Redis是一个使用ANSI C编写的开源、支持网络、基于内存分布式、可选持久性英语Durability_(database_systems)键值对存储数据库。从2015年6月开始,Redis的开发由Redis Labs英语Redis Labs赞助,而2013年5月至2015年6月期间,其开发由Pivotal赞助。[2]在2013年5月之前,其开发由VMware赞助。[3][4]根据月度排行网站DB-Engines.com的数据,Redis是最流行的键值对存储数据库。[5]

支持语言

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

Python简单示例

# coding:utf-8
import redis

# lredis-server保持开启状态 如果在客户端设置了密码 添加password=密码即可
pool = redis.ConnectionPool(host='127.0.0.1', port=6379, db=0)
r = redis.StrictRedis(connection_pool=pool)
# 字符串
r.set('test', 'aaa')
print r.get('test')
# 列表
# 注意python、lrange两个range的范围
x = 0
for x in range(0, 11):
    r.lpush('list', x)
    x = x + 1
print r.lrange('list', '0', '10')

# 雜湊(哈希)
dict_hash = {'name': 'tang', 'password': 'tang_passwd'}
r.hmset('hash_test', dict_hash)
print r.hgetall('hash_test')

# 集合
r.sadd('set_test', 'aaa', 'bbb')
r.sadd('set_test', 'ccc')
r.sadd('set_test', 'ddd')
print r.smembers('set_test')

# 有序集
r.zadd('zset_test', {'aaa': 1, 'bbb': 1})
r.zadd('zset_test', {'ccc': 1})
r.zadd('zset_test', {'ddd': 1})
print r.zrange('zset_test', 0, 10)

数据模型

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

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

持久化

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

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

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

同步

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

性能

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

参见

参考资料

  1. ^ 1.0 1.1 Release 7.2.5. 2024年5月19日 [2024年5月25日]. 
  2. ^ Redis Sponsors – Redis. [2014-07-11]. (原始内容存档于2014-06-25). 
  3. ^ VMware: the new Redis home. [2011-02-15]. (原始内容存档于2010-03-22). 
  4. ^ VMWare: The Console: VMware hires key developer for Redis. [2011-02-15]. (原始内容存档于2010-03-22). 
  5. ^ DB-Engines Ranking of Key-value Stores. [2013-06-29]. (原始内容存档于2013-07-07). 
  6. ^ Redis language bindings. [2013-07-01]. (原始内容存档于2014-02-08). 
  7. ^ CRAN - Package rredis. [2013-07-01]. (原始内容存档于2013-06-20). 
  8. ^ Redis documentation "Virtual Memory"页面存档备份,存于互联网档案馆), redis.io, accessed January 18, 2011.
  9. ^ ReplicationHowto - redis - A persistent key-value database with built-in net interface written in ANSI-C for Posix systems - Google Project Hosting. [2013-07-01]. (原始内容存档于2013-05-29). 
  10. ^ FAQ. [2013-07-01]. (原始内容存档于2013-07-16). 

外部链接