Redis
此條目可參照英語維基百科相應條目來擴充。 (2023年4月13日) |
此條目翻譯品質稍有不足。 |
Redis(Remote Dictionary Server)是一個使用ANSI C編寫的支持網絡、基於內存、分布式、可選持久性的鍵值對存儲數據庫。根據月度排行網站DB-Engines.com的數據,Redis是最流行的鍵值對存儲數據庫。[2]
開發者 | Salvatore Sanfilippo |
---|---|
首次發布 | 2009年5月10日 |
當前版本 | 7.4.1[1](2024年10月2日,56天前) |
源代碼庫 | |
編程語言 | ANSI C |
操作系統 | 跨平台 |
語言 | 英語 |
類型 | 非關係型數據庫 |
許可協議 | Redis Source Available License 或 伺服器端公眾授權條款雙重授權 |
網站 | redis |
歷史
Redis始於2009年,最初的開發者是Salvatore Sanfilippo。
Sanfilippo於2010年3月被VMware聘用。[3]
2013年5月,Redis由VMware子公司畢威拓贊助。[4]
2015年6月至,Redis的開發在Redis Labs贊助下由Sanfilippo團隊維護。[5]
2019年11月,RedisLabs發布了全新的可視化圖形用戶界面Redis工具RedisInsight。
2020年6月,Sanfilippo辭去Redis維護者職務,退居二線擔任「謀士」。Redis轉為社區自治模式。[6]
2024年3月,Redis更改主程式碼授權條款,從開源的BSD許可證轉為 Redis Source Available License 或 伺服器端公眾授權條款雙重授權,不再屬於開源軟件。
支持語言
許多語言都包含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.
- ^ 1.0 1.1 Release 7.4.1. 2024年10月2日 [2024年10月27日].
- ^ DB-Engines Ranking of Key-value Stores. [2013-06-29]. (原始內容存檔於2013-07-07).
- ^ Shapira, Gwen. VMware Hires Redis Key Developer – But Why?. Blog. March 17, 2010 [September 25, 2016]. (原始內容存檔於2023-03-14).
- ^ Sanfilippo, Salvatore. Redis Sponsors. Redis.io. Redis Labs. [April 11, 2019]. (原始內容存檔於2023-03-14).
- ^ Sanfilippo, Salvatore. Thanks Pivotal, Hello Redis Labs. <antirez>. July 15, 2015 [2019-04-03]. (原始內容存檔於2015-07-18).
- ^ Redis之父退出开源项目维护:人生苦短不想上班_工作. www.sohu.com. [2023-11-20].
- ^ Redis language bindings. [2013-07-01]. (原始內容存檔於2014-02-08).
- ^ CRAN - Package rredis. [2013-07-01]. (原始內容存檔於2013-06-20).
- ^ 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. [2013-07-01]. (原始內容存檔於2013-05-29).
- ^ FAQ. [2013-07-01]. (原始內容存檔於2013-07-16).
外部連結
- Redis項目官網(英文)
- 對Salvatore Sanfillipo的播客採訪(英文)
- 由Simon Willison講解的Redis真實應用場景教程(英文)
- 使用PHP進行Redis開發的實例(英文)
- 使用Ruby進行Redis開發的實例(頁面存檔備份,存於網際網路檔案館)(英文)