33、一次奇怪的数据丢失你好,我是蒋德钧。 在使用主从集群时,我曾遇到过这样一个问题:我们的主从集群有1个主库、5个从库和3个哨兵实例,在使用的过程中,我们发现客户端发送的一些数据丢失了,这直接影响到了业务层的数据可靠性。 通过一系列的问题排查,我们才知道,这其实是主从集群...2025-10-18Redis核心技术与实战
32、Redis主从同步与故障切换的坑你好,我是蒋德钧。 Redis的主从同步机制不仅可以让从库服务更多的读请求,分担主库的压力,而且还能在主库发生故障时,进行主从库切换,提供高可靠服务。 不过,在实际使用主从机制的时候,我们很容易踩到一些坑。这节课,我就向你介绍3个坑,分别是主从数据不...2025-10-18Redis核心技术与实战
31、Redis能实现ACID属性吗你好,我是蒋德钧。 事务是数据库的一个重要功能。所谓的事务,就是指对数据进行读写的一系列操作。事务在执行时,会提供专门的属性保证,包括原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durabil...2025-10-18Redis核心技术与实战
30、如何使用Redis实现分布式锁你好,我是蒋德钧。 上节课,我提到,在应对并发问题时,除了原子操作,Redis客户端还可以通过加锁的方式,来控制并发写操作对共享数据的修改,从而保证数据的正确性。 但是,Redis属于分布式系统,当有多个客户端需要争抢锁时,我们必须要保证,这把锁不能...2025-10-18Redis核心技术与实战
29、Redis如何应对并发访问你好,我是蒋德钧。 我们在使用Redis时,不可避免地会遇到并发访问的问题,比如说如果多个用户同时下单,就会对缓存在Redis中的商品库存并发更新。一旦有了并发写操作,数据就会被修改,如果我们没有对并发写请求做好控制,就可能导致数据被改错,影响到业务...2025-10-18Redis核心技术与实战
28、如何基于SSD实现大容量Redis你好,我是蒋德钧。 我们在应用Redis时,随着业务数据的增加(比如说电商业务中,随着用户规模和商品数量的增加),就需要Redis能保存更多的数据。你可能会想到使用Redis切片集群,把数据分散保存到多个实例上。但是这样做的话,会有一个问题,如果要保...2025-10-18Redis核心技术与实战
27、缓存被污染了,该怎么办你好,我是蒋德钧。 我们应用Redis缓存时,如果能缓存会被反复访问的数据,那就能加速业务应用的访问。但是,如果发生了缓存污染,那么,缓存对业务应用的加速作用就减少了。 那什么是缓存污染呢?在一些场景下,有些数据被访问的次数非常少,甚至只会被访问一次...2025-10-18Redis核心技术与实战
26、解决缓存雪崩、击穿、穿透难题你好,我是蒋德钧。 上节课,我们学习了缓存和数据库的数据不一致问题和应对方法。除了数据不一致问题,我们常常还会面临缓存异常的三个问题,分别是缓存雪崩、缓存击穿和缓存穿透。这三个问题一旦发生,会导致大量的请求积压到数据库层。如果请求的并发量很大,就会导...2025-10-18Redis核心技术与实战
25、解决缓存和数据库数据不一致问题你好,我是蒋德钧。 在实际应用Redis缓存时,我们经常会遇到一些异常问题,概括来说有4个方面:缓存中的数据和数据库中的不一致;缓存雪崩;缓存击穿和缓存穿透。 只要我们使用Redis缓存,就必然会面对缓存和数据库间的一致性保证问题,这也算是Redis...2025-10-18Redis核心技术与实战
24、缓存满了怎么办你好,我是蒋德钧。 Redis缓存使用内存来保存数据,避免业务应用从后端数据库中读取数据,可以提升应用的响应速度。那么,如果我们把所有要访问的数据都放入缓存,是不是一个很好的设计选择呢?其实,这样做的性价比反而不高。 举个例子吧。MySQL中有1TB...2025-10-18Redis核心技术与实战