Redis

本页使用了标题或全文手工转换,现处于繁体转换模式
出自求聞百科
Redis
開發者Salvatore Sanfilippo
首次發布2009年5月10日,​15年前​(2009-05-10
編程語言ANSI C
操作系統跨平台
語言英語
類型非關係型數據庫
許可協議BSD

Redis是一個使用ANSI C編寫的開源、支持網絡、基於內存分布式、可選持久性鍵值對存儲數據庫。從2015年6月開始,Redis的開發由Redis Labs贊助,而2013年5月至2015年6月期間,其開發由Pivotal贊助。[1]在2013年5月之前,其開發由VMware贊助。[2][3]根據月度排行網站DB-Engines.com的數據,Redis是最流行的鍵值對存儲數據庫。[4]

支持語言

許多語言都包含Redis支持,包括:[5]

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版本後可配置為使用虛擬內存[7]一部分數據集存儲在硬盤上,但這個特性廢棄了。

目前通過兩種方式實現持久化

  • 使用快照,一種半持久耐用模式。不時的將數據集以異步方式從內存以RDB格式寫入硬盤。
  • 1.1版本開始使用更安全的AOF格式替代,一種只能追加的日誌類型。將數據集修改操作記錄起來。Redis能夠在後台對只可追加的記錄進行修改,從而避免日誌的無限增長。

同步

Redis支持主從同步。數據可以從主服務器向任意數量的從服務器上同步,從服務器可以是關聯其他從服務器的主服務器。這使得Redis可執行單層樹複製。從盤可以有意無意的對數據進行寫操作。由於完全實現了發布/訂閱機制,使得從數據庫在任何地方同步樹時,可訂閱一個頻道並接收主服務器完整的消息發布記錄。同步對讀取操作的可擴展性和數據冗餘很有幫助。[8]

性能

當數據依賴不再需要,Redis這種基於內存的性質,與在執行一個事務時將每個變化都寫入硬盤的數據庫系統相比就顯得執行效率非常高。[9]寫與讀操作速度沒有明顯差別。

參見

參考資料

  1. Redis Sponsors – Redis. [2014-07-11]. 
  2. VMware: the new Redis home. [2011-02-15]. 
  3. VMWare: The Console: VMware hires key developer for Redis. [2011-02-15]. 
  4. DB-Engines Ranking of Key-value Stores. [2013-06-29]. 
  5. Redis language bindings. [2013-07-01]. 
  6. CRAN - Package rredis. [2013-07-01]. 
  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. [2013-07-01]. 

外部連結