
Redis
跳至導覽
跳至搜尋
開發者 | Salvatore Sanfilippo |
---|---|
初始版本 | 2009年5月10日 |
穩定版本 |
5.0.6 (2019年9月25日[1]) |
預覽版本 |
5.0-rc6 (2018年10月10日[2]) |
原始碼庫 |
![]() |
程式語言 | ANSI C |
作業系統 | 跨平台 |
語言 | 英語 |
類型 | 非關係型數據庫 |
許可協定 | BSD |
網站 |
redis |
Redis是一個使用ANSI C編寫的開源、支援網絡、基於記憶體、可選永續性的鍵值對儲存數據庫。從2015年6月開始,Redis的開發由Redis Labs贊助,而2013年5月至2015年6月期間,其開發由Pivotal贊助。[3]在2013年5月之前,其開發由VMware贊助。[4][5]根據月度排行網站DB-Engines.com的數據,Redis是最流行的鍵值對儲存數據庫。[6]
支援語言[編輯]
許多語言都包含Redis支援,包括:[7]
|
|
|
|
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版本後可組態為使用虛擬記憶體,[9]一部分數據集儲存在硬碟上,但這個特性廢棄了。
目前通過兩種方式實現持久化:
- 使用快照,一種半持久耐用模式。不時的將數據集以非同步方式從記憶體以RDB格式寫入硬碟。
- 1.1版本開始使用更安全的AOF格式替代,一種只能追加的紀錄檔類型。將數據集修改操作記錄起來。Redis能夠在後台對只可追加的記錄作修改來避免無限增長的紀錄檔。
同步[編輯]
Redis支援主從同步。數據可以從主伺服器向任意數量的從伺服器上同步,從伺服器可以是關聯其他從伺服器的主伺服器。這使得Redis可執行單層樹複製。從盤可以有意無意的對數據進行寫操作。由於完全實現了發佈/訂閱機制,使得從數據庫在任何地方同步樹時,可訂閱一個頻道並接收主伺服器完整的訊息發佈記錄。同步對讀取操作的可延伸性和數據冗餘很有幫助。[10]
效能[編輯]
當數據依賴不再需要,Redis這種基於記憶體的性質,與在執行一個事務時將每個變化都寫入硬碟的數據庫系統相比就顯得執行效率非常高。[11]寫與讀操作速度沒有明顯差別。
參見[編輯]
參考資料[編輯]
- Jeremy Zawodny, Redis: Lightweight key/value Store That Goes the Extra Mile, Linux Magazine, August 31, 2009
- Isabel Drost and Jan Lehnard(29 October 2009),Happenings: NoSQL Conference, Berlin, The H. Slides for the Redis presentation. Summary.
- Billy Newport(IBM):"Evolving the Key/Value Programming Model to a Higher Level" Qcon Conference 2009 San Francisco.
- ^ Salvatore Sanfilippo. [RELEASE] Redis 5.0.6 is out. Google Groups.
- ^ Salvatore Sanfilippo. Redis 5.0 RC6 is out. Google Groups.
- ^ Redis Sponsors – Redis
- ^ VMware: the new Redis home
- ^ VMWare: The Console: VMware hires key developer for Redis
- ^ DB-Engines Ranking of Key-value Stores
- ^ Redis language bindings
- ^ CRAN - Package rredis
- ^ Redis documentation "Virtual Memory", redis.io, accessed January 18, 2011.
- ^ ReplicationHowto - redis - A persistent key-value database with built-in net interface written in ANSI-C for Posix systems - Google Project Hosting
- ^ FAQ.
外部連結[編輯]
- Redis專案官網(英文)
- 對Salvatore Sanfillipo的Podcast採訪(英文)
- 由Simon Willison講解的Redis真實應用場景教程(英文)
- 使用PHP進行Redis開發的實例(英文)
- 使用Ruby進行Redis開發的實例[永久失效連結](英文)
|