这篇文章将为大家详细讲解有关Mongodb中怎么实现副本集和分片,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

Python只用mongo事务

在python中使用使用pymongo 来操作数据库

importpymongomc=pymongo.MongoClient('mongodb://localhost:27018',connect=False,maxPoolSize=2000)withmc.start_session()assession:withsession.start_transaction():mc['test']['test'].insert_one({'a':1},session=session)mc['test']['test'].delete_one({'a':1},session=session)...

但在实际使用中却报了个错

MongoError: Transaction numbers are only allowed on a replica set member or mongos.

上网搜索后很多解决方法都是npm安装一个什么包,然后用它启动mongo。

其实根据英文的意思也差不多能明白是怎么回事,网上搜索后发现了根本原因:事务只支持副本集和切片。而我这开发环境是直接mongod启的

副本集

副本集搭建

启动两个mongodb服务(一个master,一个slave)

#1/usr/local/mongodb/mongodb4.0.10/bin/mongod\--bind_ip=0.0.0.0--port=27018--logpath=/var/log/mongodb/mongodb_4_0_10.log\--dbpath=/data/mongo_4.0.10_db\--replSetrs0--fork#2/usr/local/mongodb/mongodb4.0.10/bin/mongod\--bind_ip=0.0.0.0--port=27019\--logpath=/var/log/mongodb/mongodb_4_0_10-2.log\--dbpath=/data/mongo_4.0.10_db-2\--replSetrs0--fork

在mongo shell中执行

#启动一个新的副本集rs.initiate()#添加一个副本集rs.add("localhost.localdomain:27019")

关于Mongodb中怎么实现副本集和分片就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。