什么情况下必须用Redis,而不能使用其他数据库(为什么用redis不用hashmap)

匿名- 2023-08-20 17:40:06

Redis为什么默认16个数据库 这次终于知道答案了

大家好,如果您还对什么情况下必须用Redis,而不能使用其他数据库不太了解,没有关系,今天就由本站为大家分享什么情况下必须用Redis,而不能使用其他数据库的知识,包括不建议使用redis的问题都会给大家分析到,还望可以解决大家的问题,下面我们就开始吧!

本文目录

  1. 什么情况下必须用Redis,而不能使用其他数据库
  2. 有些程序员一直坚持反对使用redis怎么办
  3. redis和memcached的区别
  4. redis有集群模式了为什么还要哨兵

什么情况下必须用Redis,而不能使用其他数据库

首先,你一定知道redis是单线程的NoSQL落地产品。既然是NOSQL肯定是可以做一些数据库的事情,但在这个之外,它可以有高效进行内存缓存。明白点就是将数据存放于内存中而不是每次都从数据库的存储文件上面捣腾。这样速度就可以很快。

既然是基于内存进行缓存,那必然有一点不能放太大太多的数据,所以第一点,我们一定放一些实用性较高,命中率较高的数据。这样不至于占着茅坑不拉屎。所以,结合起来就是,需要查询的存储数据比较多,而每次几乎只查这么多数据中的其中一小部分经常使用的数据时,就用他了!

第二点,既然是单线程!那么你怕啥?你想到啥?高并发环境呀!对!针对一些高并发的数据排队,任务执行时候,可以通过Redis进行分布式锁的控制。

第三点,还有啥?太多了!可以做订阅发布,服务注册……

但是!我们公司和支付宝等大企业很多架构师明确提出,中间件的就应该做自己该做的事情!Redis其实开发的初衷就是缓存储缓存!其他功能都是对它的扩展和包装!不建议使用!就把它当成一个分布式缓存中间件来用吧!其他扩展功能都有对应的其他中间件。

不越俎代庖,不推诿避任!它就是一个缓存中间件。

感谢指导,相互指正学习!

有些程序员一直坚持反对使用redis怎么办

分享大佬的回答,似乎很有道理。

不要告诉我们用不用redis,你得告诉我们你为什么想要用redis,不用redis业务会有什么问题?天下没有免费的午餐,不动脑子直接上缓存/NOSQL可能会带来更多更严重的问题。

单一数据库最大的好处在于事务性实现简单,由数据库自己保证。举个简单的例子,下订单需要扣除一个库存,然后插入一条订单条目,如果库存和订单都是数据库表项的话这个事务是无懈可击的,如果库存在redis里,订单条目是MySQL,通常就需要先写redis,成功之后再写数据库,如果写数据库失败了还需要回滚redis,如果最后这个回滚因为网络之类的原因失败了,就会多扣一个库存。不要以为这些事情很好解决,事务性处理的复杂性远远超过你的想象,比如说还有写MySQL在提交的一瞬间连接断了这种情况,你都没法判断提交到底成功了还是失败了,那你的redis是回滚还是不回滚?

所以引入新的层一定要说清楚,你为了什么目的一定要用缓存/NOSQL,能接受什么样的一致性模型,否则就是在胡闹。

redis和memcached的区别

Redis和Memcached都是常见的内存缓存系统,它们都可以用来加速应用程序的数据读取速度。

以下是它们的一些主要区别:

1.数据存储方式:Redis不仅支持内存缓存,还支持磁盘持久化,可以将内存中的数据保存到硬盘上,以防止数据丢失。而Memcached只支持内存缓存,不能将数据持久化到硬盘上。

2.数据类型支持:Redis支持多种数据类型,包括字符串、哈希表、列表、集合和有序集合等,而Memcached只支持简单的键值存储。

3.内存管理方式:Redis使用一种称为VM(VirtualMemory)的技术来管理内存,这种技术可以将内存分为多个区域,并且可以将一部分数据保存在磁盘上以释放内存。而Memcached使用一种称为SlabAllocation的技术来管理内存,这种技术可以将内存分为多个大小不同的块,并且可以动态调整内存大小。

4.性能表现:在单个节点的场景下,Memcached通常比Redis表现更好,因为它的内存管理方式更简单,处理速度更快。但是,在大规模分布式场景下,Redis表现更好,因为它提供了更多的功能和更好的可靠性保障。

5.Redis和Memcached都是常见的内存缓存系统,它们在数据存储方式、数据类型支持、内存管理方式和性能表现等方面有所不同,开发者需要根据自己的需求和场景来选择合适的缓存系统。

redis有集群模式了为什么还要哨兵

Redis的集群模式确实可以提供高可用性和可伸缩性,但是在实际使用中,仍然需要哨兵来监控和维护Redis的运行状态。以下是一些原因:

1.故障切换:当Redis集群中的某个主节点出现故障时,哨兵可以及时发现并将从节点晋升为新的主节点,保证Redis集群的高可用性。在集群模式下,如果没有哨兵的故障切换机制,可能会导致Redis集群的不可用或数据丢失。

2.配置管理:哨兵可以监控Redis集群中所有节点的状态,并在需要的时候进行配置管理。例如,当添加或删除节点时,哨兵可以及时更新集群配置,使其保持一致性。

3.监控报警:哨兵可以监控Redis集群中各个节点的运行状态和性能指标,并在发现异常时发送警报。这对于管理员来说非常重要,可以及时发现和解决问题,避免数据丢失或系统不可用。

综上所述,尽管Redis集群模式可以提供高可用性和可伸缩性,但在实际使用中,哨兵仍然是非常重要的组件,可以提供故障切换、配置管理和监控报警等功能,保证Redis集群的稳定运行。

好了,文章到这里就结束啦,如果本次分享的什么情况下必须用Redis,而不能使用其他数据库和不建议使用redis问题对您有所帮助,还望关注下本站哦!

Redis数据库的配置与优化
  • 声明:本文内容来自互联网不代表本站观点,转载请注明出处:bk.0755org.com/12/100951.html
上一篇:什么情况下不用办理休学
下一篇:什么季节点斑效果最佳(什么季节点雀斑最好)
相关文章
返回顶部小火箭