error RS102 too stale to catch up

    mongodb在建立副本集或者分片集群的时候,都会遇到数据同步的问题,从PRIMARY到SECONDARY节点的数据同步。
    特别是在新导入大批量的数据,千万级,可能会非PRIMARY节点出现同步不及时,并且出错,此时节点的状态显示为RECOVERING,并且错误信息显示为“error RS102 too stale to catch up”。
    查阅各种资料,提到说是oplog的设置有问题,但是我在启动mongo的时候该参数设置的为1000,即1G,我想怎么可能会出现问题呢?
    因为我的需求是将副本集的数据导入到分片集群中,变化各种做法,都会出现副本集同步的错误,更不要说分片了。
    查看mongo的官方文档,该参数不设置则默认为磁盘的5%,最小为1G。索性去掉该参数,导入数据后然后同步,不会报错,而且两个节点的状态一直是SECONDARY,没有任何问题。如果要设置,数据量在千万级别,建议最起码的10G以上。
   
    可见,有的参数在不了解的情况下还是不要冒然设置,否则会走很多冤枉路。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值