MongoDB-4.x 开启shard集群后批量插入性能低的问题

关注我的blog获取最新内容

最近接触了mongodb,用两台物理机部署了3个centos7-vm,分别在没台机器上部署了route和config。其中shard每台vm部署了一个,并没有配置复制集。


节点部署

在性能验证的时候发现在不对collection开启shard的时候批量插入的性能大概在25000条/s。而开启shard之后批量插入的性能下降到了5000条/s。

。。。。

在经过一番排查之后再Stack Overflow上找到了这篇问答

其中一位回答者提到了可能是collection.bulkWrite(list);导致的。

所以想到了问题可能出在客户端上。
我用的是springboot集成的MongoTemplate。

    public void batchInsert(List list){
        mongoTemplate.insert(list,Szgp.class);
    }

修改为

    public void batchInsert(List list){
        BulkOperations ops = mongoTemplate.bulkOps(BulkOperations.BulkMode.UNORDERED,  Szgp.class);
        ops.insert(list);
        ops.execute();
    }

问题得以解决

你可能感兴趣的:(MongoDB-4.x 开启shard集群后批量插入性能低的问题)