hello大家好,这里是花栗鼠鼠鼠,下面我们来介绍双写一致性问题!
首先我们要了解,何为双写一致性呢?
根据字面意思我们可以理解为,两次写操作写入的数据是一致的,那么这两次写指的就是数据库写入和缓存写入。所以定义是:双写一致性指的是在向数据库写入数据时,同时也要改变缓存中的数据,保证DB和缓存的数据一致。
那么,在高并发的情况下,可能会有多次请求去访问同一个数据,当我们在这时修改数据时不论是先删除缓存再修改数据库,还是先修改数据库再删除缓存,都有可能读到脏数据(数据已经被修改了,但是我们读到了未修改的数据),这时怎么去解决这个问题呢?
第一种是对于要求强一致性的数据:使用redisson提供的读写锁,在读数据时使用共享锁,其他线程可以进行读操作,但是不能写;在写数据时使用排他锁,其他线程不可读且不可写。
第二种情况是对于允许延迟一致(缓存和数据库中的数据同步可以延迟一小会)的情况:可以使用异步通知保证数据的最终一致性,例如:
①使用MQ中间件,更新数据之后,通知缓存删除。
②利用canal中间件,不需要修改业务代码,伪装为mys