Redis可以用来做数据库吗?

 我来答
绊你一生twrdx2c
2017-12-25 · TA获得超过351个赞
知道答主
回答量:288
采纳率:100%
帮助的人:52.1万
展开全部

结论:Redis 不能当数据用。

原因:我们理解的数据库,无论是 SQL、NoSQL、NewSQL,至少要是读写一致的。也就是说如果客户端发起一个写请求,如果服务器回复了成功,就算是之后服务器异常重启了,这个数据一样是能被读到的。

而 Redis 不是读写一致的。

答案里有人提到说 Redis 也会持久化,但是就算是 AOF,也是给客户端应答后,再定时写磁盘的,都是不一致的。

这里还没讨论磁盘损坏的问题。

有几个基于持久化存储的、兼容 Redis 协议的系统可以当作数据库使用,比如 SSDB、ARDB、Pika 等。但是据我所知,这些项目现在都不支持集群,没办法动态扩容。

另外,还有一个很麻烦的问题,就是刚才提到的 磁盘损坏问题,如果数据只存放在一个单点,一旦有磁盘损坏,就会造成数据丢失,所以,即使是同步持久化的但是没有集群备份数据的系统,用作数据库也是有很大风险的。

fltbkyfnv635
2017-12-25 · TA获得超过518个赞
知道答主
回答量:293
采纳率:98%
帮助的人:54.3万
展开全部

Redis本来就是内存数据库,用来当做计数器,队列等的确很不错,性能高效。但是,但是,但是架构不靠谱下可能使你提心吊胆。

只用Redis作为数据库时,使用时确实很爽,突然来个新需求、数据突然暴增、数据架构迁移的时候就给跪了。

Redis是key-value数据库,面对key的内存搜索,优势明显。

大部分还是要和其他持久化数据库合作使用,就只来说几个注意的场景:

1、Redis-RDB半持久化模式下,非实时,如果一旦断电,丢失一些数据,程序能不能接受、兼容?

2、Redis主要是Key的查询,对于复杂的数据结构,需要其他sql是不是更爽?需要其他关联查询?

3、Redis吃的是纯内存,跟磁盘相比,成本也要计算在内?

4、是否需要支持像银行存取款级别的事务?

5、数据总有“冷”、“热”之分,10亿的冷数据都放Redis显然浪费资源。

性能、成本、可靠性,最终是一个权衡的问题。

Redis 已经发展了 2 年多,很多团队已经验证了它是一个靠谱的数据库。 但是它并不通用,使用场景是有限的。

知乎日报的基础数据和统计信息是用 Redis 存储的,这使得请求的平均响应时间能在 10ms 以下。 其他数据仍然需要存放在另外的地方,其实完全用 Redis 也是可行的,主要的考量是内存占用。 就使用经验而言,Redis 的数据结构很丰富,精心设计地话,能满足很多应用场景。至少很多时候比 MySQL 更方便。 更重要的是,它很 cool,开发时有新鲜感。

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
回忆13096fe82a
2017-12-25 · TA获得超过284个赞
知道答主
回答量:298
采纳率:93%
帮助的人:75.2万
展开全部

redis是目前公认的速度最快的基于内存的键值对数据库,但redis的缺点也非常明显,仅提供最基本的hash set, list, sorted set等基于数据类型,不分表,没有schema,没有索引,没有外键,缺少int/date等基本数据类型,多条件查询需要通过集合内联(sinter,zinterstore)和连接间接实现,操作不便,开发效率低,可维护性不佳; 因此一般不将其视为完整的数据库单独使用,很多网站将redis作为高速缓存和session状态存储层,然后再与其他数据库搭配使用。

但是我们的开源博客和网站系统 newghost/ourjs · GitHub v0.1.x,后台数据库就采用了Redis,为了克服Redis操作不便的问题,我们还设计了redblade, 只要事先定好schema,就能像mongodb那样操作redis,自动帮你创建index/ keyword等索引;

至于内存限制,有很多第三方的Redis集群工具可以帮你把它扩展成一个内存无限大的数据库。

Redis (安装方法 )数据库采用极简的设计思想,最新版的源码包还不到2Mb。其在使用上也有别于一般的数据库。

Redis的一个Key不仅可以对应一个String类型的值,还支持hashes, lists, sets, sorted sets, bitmaps等。

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式