此條目可参照英語維基百科相應條目来扩充。 (2023年4月13日) |
此條目翻譯品質稍有不足。 |
開發者 | Salvatore Sanfilippo |
---|---|
首次发布 | 2009年5月10日 |
当前版本 | 7.4.1[1](2024年10月2日,56天前) |
源代码库 | |
编程语言 | ANSI C |
操作系统 | 跨平台 |
语言 | 英语 |
类型 | 非关系型数据库 |
许可协议 | Redis Source Available License 或 伺服器端公眾授權條款雙重授權 |
网站 | redis |
Redis(Remote Dictionary Server)是一个使用ANSI C编写的支持网络、基于内存、分布式、可选持久性的键值对存储数据库。根据月度排行网站DB-Engines.com的数据,Redis是最流行的键值对存储数据库。[2]
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]写与读操作速度没有明显差别。