Loading AI tools
NoSQL資料庫管理軟體 来自维基百科,自由的百科全书
Redis(Remote Dictionary Server)是一個使用ANSI C編寫的支援網路、基於主記憶體、分散式、可選永續性的鍵值對儲存資料庫。根據月度排行網站DB-Engines.com的資料,Redis是最流行的鍵值對儲存資料庫。[2]
此條目可參照英語維基百科相應條目來擴充。 (2023年4月13日) |
此條目翻譯品質稍有不足。 |
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]
# 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]一部分資料集儲存在硬碟上,但這個特性廢棄了。
目前通過兩種方式實現持久化:
Redis支援主從同步。資料可以從主伺服器向任意數量的從伺服器上同步,從伺服器可以是關聯其他從伺服器的主伺服器。這使得Redis可執行單層樹複製。從盤可以有意無意的對資料進行寫操作。由於完全實現了發布/訂閱機制,使得從資料庫在任何地方同步樹時,可訂閱一個頻道並接收主伺服器完整的訊息發布記錄。同步對讀取操作的可延伸性和資料冗餘很有幫助。[10]
當資料依賴不再需要,Redis這種基於主記憶體的性質,與在執行一個事務時將每個變化都寫入硬碟的資料庫系統相比就顯得執行效率非常高。[11]寫與讀操作速度沒有明顯差別。
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.