韩漫免费漫画在线观看方法,《好好疼爱里面》免费看,年轻漂亮的女士护士内衣,妈妈醉酒后把我当爸爸电视剧

文章 > MongoDB > mongodb副本集如何读写分离?

mongodb副本集如何读写分离?

头像

yang

2020-05-23 13:35:514271浏览 · 0收藏 · 0评论

首先我们先来搭建一个副本集(因为没有那么多服务器机器,这里采用在一台机器上,使用不同的端口号模拟不同的机器上的Mongodb实例)。

第一步:我们在本机的1111、2222和3333三个端口上启动三个不同的Mongodb实例;

mongod --port 1111 --dbpath F:/mongodb1/data/db --logpath F:/mongodb1/data/log/mongodb.log --replSet test --logappend
mongod --port 2222 --dbpath F:/mongodb2/data/db --logpath F:/mongodb2/data/log/mongodb.log --replSet test --logappend
mongod --port 3333 --dbpath F:/mongodb3/data/db --logpath F:/mongodb3/data/log/mongodb.log --replSet test --logappend

在这里我们启动了三个Mongodb实例,并指定了相应的数据目录和日志目录,需要说明的是,这里需要使用--replSet说明该Mongodb实例是副本集中的节点,而该副本集的名称是test。

第二步:登录到一个实例上,编写指令,将三个不同的Mongodb实例结合在一起形成一个完整的副本集;

config_test={"_id":"test",members:[
    {_id:0,host:"127.0.0.1:1111"},
    {_id:1,host:"127.0.0.1:2222"},
    {_id:2,host:"127.0.0.1:3333"},
]};

第三步:通过执行下面的命令初始化副本集。

rs.initiate(config_test);

这里使用上面的配置初始化Mongodb副本集。

通过上面的三步,便可以简单的搭建起一个由三个Mongodb实例构成的名称为test的副本集了。如果想查看副本集的状态,可以使用rs.status()命令来进行查看。

副本集读写分离结构如下图所示:

为了在副本集上实现读写分离,我们需要实现以下两步:

(1)在副本节点上设置setSlaveOk;

(2)代码层面,在读操作过程中设置从副本节点读取数据,如下所示:

<span style="font-family:KaiTi_GB2312;font-size:18px;">public class TestMongoDBReplSet { 
	public static void main(String[] args)  {
		try { 
			List<ServerAddress> addresses = new ArrayList<ServerAddress>();  
            ServerAddress address1 = new ServerAddress("127.0.0.1" , 1111); 
			ServerAddress address2 = new ServerAddress("127.0.0.1" , 2222); 
			ServerAddress address3 = new ServerAddress("127.0.0.1" , 3333); 
			addresses.add(address1);  
            addresses.add(address2); 
			addresses.add(address3); 
			MongoClient client = new MongoClient(addresses); 
			DB db = client.getDB( "test"); 
			DBCollection coll = db.getCollection( "test"); 
			
			BasicDBObject object = new BasicDBObject();  
            object.append( "key1", "value1" ); 
			ReadPreference preference = ReadPreference.secondary();  
			DBObject dbObject = coll.findOne(object, null , preference);  
			System. out .println(dbObject);  
		} catch (Exception e) { 
			e.printStackTrace();  
        } 
	} 
} </span>

读参数除了secondary以外,还有其他几个参数可以使用,他们的含义分别如下所示:

primary:默认参数,只从主节点上进行读取操作;

primaryPreferred:大部分从主节点上读取数据,只有主节点不可用时从secondary节点读取数据。

secondary:只从secondary节点上进行读取操作,存在的问题是secondary节点的数据会比primary节点数据“旧”。

secondaryPreferred:优先从secondary节点进行读取操作,secondary节点不可用时从主节点读取数据;

nearest:不管是主节点、secondary节点,从网络延迟最低的节点上读取数据。

更多mongodb相关文章请关注python自学网

关注

关注公众号,随时随地在线学习

本教程部分素材来源于网络,版权问题联系站长!

干别人老婆还当面打电话| 老师脱了内裤让我进去| 美女和男生一起努力的生孩子视频..| 成品免费PPT网站入口| 《黑人情欲》在线播放| 动漫| JK制服| 朋友的母亲中字ID| 韩国女演员克拉拉| 小小小蜜桃免费观看电视剧高清| 晃来晃去的大扔子| 兜兜动漫| 美国禁忌| 小俊在雪姨身上耕耘小说免费阅读| 三个男人躁我一个爽的后果及影响| 男人行房一般多久才算正常| 妈妈装睡配合孩子阴阳调和| 宝贝把腿开大让我添添你视频| 上海1920| 韩国女演员| 大肉大捧一进一出视频的注意事项 | CSGO未满十八岁能玩多久| 免费观看已满十八岁电视剧在线播.| 法国《口咬》电影完整版| 舌头伸进去添的我爽高潮 | 撸撸社| 4虎CVT4WD入口免费| 两个小婕子交换3| 《如狼似虎的女人》大结局| 有成人网站吗| 窝窝视频网| BOBO浏览器老司机模式改版特.| 法国电影《女流氓》的剧情简介| 憋尿白丝小肚子凸起高冷知乎| 女儿13岁爸爸来尝鲜食品的祝福... | 《妻子3》免费完整版高清韩剧| 韩国咬住奶头的乳三级| 强伦轩特级A片免费播放女的老师| 大杂烩(TXT)小说阅读| 免费视频在线观看人数在哪直播 | MISS CHANGE