文档数据库服务 DDS-如何规避dds mongos路由缓存缺陷:使用场景

时间:2024-05-20 17:43:40

使用场景

当未对数据进行分片时,若系统中存在多个dds mongos,通过不同的dds mongos进行数据访问时,可能出现不同dds mongos上本地缓存的路由信息不一致的情况。场景示例:

  1. 通过mongos1创建A数据库,未开启分片。写入数据1后,数据1被全部分到shard server1上存储。然后,在mongos2上对数据进行查询。此时,mongos1和mongos2上,均存在缓存的A数据库的路由信息。
  2. 通过mongos2执行了A数据库的删除操作。此时,config server和shard server1中的A数据库信息都被删掉。而mongos1无法识别数据1已经被删除。
  3. 通过mongos1向A数据库中写入数据2时,由于存在缓存,所以无法识别A数据库已经被删除的场景。参照已经存在的路由信息,数据2被存储到shard server1上。然后,通过mongos2向A数据库中写入数据3时,由于能够识别出A数据库已经被删除,所以会在config server和shard server2中生成新的A数据库的信息。
  4. 此时,mongos1和mongos2中缓存的路由信息不一致,关联不同的shard server,且仅能看到部分数据,导致数据异常。
图2 mongos缓存缺陷的场景

客户端通过不同mongos,所查询到的数据不同:

  • mongos1:可以查到数据2,无法查询到数据3。
  • mongos2:可以查询到数据3,无法查询到数据2。
support.huaweicloud.com/bestpractice-dds/dds_0007.html