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<Szgp> list){
        mongoTemplate.insert(list,Szgp.class);
    }

修改为

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

问题得以解决

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容