MongoDB安装与副本集配置
admin
2023-04-13 17:21:37
0
副本集是一组,由N个mongo节点组成并协同工作的,提供自动的故障集群转移。建立一个副本集需要步骤,1、需要启动每个节点,2、然后进行初始化设置。在这里,我们将配置一组(三个节点),这是标准设置。

一旦mongod节点启动,我们将发出一个命令,以正确地初始化设置。几秒钟后,将选举产生一个主节点,你就可以开始写和查询集。


环境描述:

a.192.168.30.112:3306   主节点

b.192.168.30.113:3306   从节点

c.192.168.30.114:3306   从节点


1,解压安装mongodb

[root@localhost ~]# tar zxvf mongodb-linux-x86_64-2.0.4.tgz

[root@localhost ~]# mv mongodb-linux-x86_64-2.0.4 /usr/local/mongodb

[root@localhost ~]# cd /usr/local/mongodb/

[root@localhost mongodb]# mkdir -p mongodb_data/mongodb_db

[root@localhost mongodb]# mkdir mongodb_data/mongodb_logs

以上3台服务器,一样的安装步骤


2.设置启动配置文件

[root@localhost mongodb]# vi /etc/mongodb.conf

fork = true

quiet = true

bind_ip = 192.168.30.112

port = 3306

dbpath = /usr/local/mongodb/mongodb_data/mongodb_db

logpath = /usr/local/mongodb/mongodb_data/mongodb_logs/server1.log

logappend = true

journal = true

rest = true

replSet = test


其余2台服务器,修改相应IP即可


3.启动mongodb


[root@localhost ~]# /usr/local/mongodb/bin/mongod -f /etc/mongodb.conf


4.初始化节点

我们连接到其中一个节点上,并使用replSetInitiate命令进行初始化。此命令需要一个配置对象,指定设定的每个成员的名字。

>/usr/local/mongodb/bin/mongo 192.168.30.112:3306/admin

>config ={_id:"test",members:[

...{_id:0,host:'192.168.30.112:3306',priority:4},

...{_id:1,host:'192.168.30.113:3306',priority:2},

...{_id:2,host:'192.168.30.114:3306',priority:1}]

...}

>rs.initiate(config);

{

"info":"Config now saved locally.  Should come online in about a minute.",

"ok":1

}

PRIMARY> rs.status()

{

"set" : "test",

"date" : ISODate("2013-12-31T07:49:39Z"),

"myState" : 1,

"members" : [

{

"_id" : 0,

"name" : "192.168.30.112:3306",

"health" : 1,

"state" : 1,

"stateStr" : "PRIMARY",

"optime" : {

"t" : 1388474768000,

"i" : 1

},

"optimeDate" : ISODate("2013-12-31T07:26:08Z"),

"self" : true

},

{

"_id" : 1,

"name" : "192.168.30.113:3306",

"health" : 1,

"state" : 2,

"stateStr" : "SECONDARY",

"uptime" : 790,

"optime" : {

"t" : 1388474768000,

"i" : 1

},

"optimeDate" : ISODate("2013-12-31T07:26:08Z"),

"lastHeartbeat" : ISODate("2013-12-31T07:49:38Z"),

"pingMs" : 0

},

{

"_id" : 2,

"name" : "192.168.30.114:3306",

"health" : 1,

"state" : 2,

"stateStr" : "SECONDARY",

"uptime" : 786,

"optime" : {

"t" : 1388474768000,

"i" : 1

},

"optimeDate" : ISODate("2013-12-31T07:26:08Z"),

"lastHeartbeat" : ISODate("2013-12-31T07:49:38Z"),

"pingMs" : 0

}

],

"ok" : 1

}

检查节点状态。
复制

现在我们来测试一下,向主节点中写点东西。

PRIMARY> db.test.save({c:3})

PRIMARY> db.test.find()

{ "_id" : ObjectId("52c2709235dd31988bc3e7c5"), "b" : 2 }

{ "_id" : ObjectId("52c2719035dd31988bc3e7c6"), "c" : 3 }


SECONDARY> db.test.find()

error: { "$err" : "not master and slaveok=false", "code" : 13435 }

错误解决办法:

首先这是正常的,因为SECONDARY是不允许读写的, 在写多读少的应用中,使用Replica Sets来实现读写分离。通过在连接时指定或者在主库指定slaveOk,由Secondary来分担读的压力,Primary只承担写操作。对于replica set 中的secondary 节点默认是不可读的


SECONDARY> db.getMongo()connection to 127.0.0.1:33333SECONDARY> db.getMongo().setSlaveOk();not master and slaveok=false

在主库上设置 slaveok=ok

PRIMARY> db.getMongo().setSlaveOk();

在从库进行测试SECONDARY> db.user.find(){ "_id" : ObjectId("4eb68b1540643e10a0000000"), "id" : 1, "name" : "zhangsan" }{ "_id" : ObjectId("4eb68b1540643e10a0000001"), "id" : 2, "name" : ";lisi" }


这时候你去看看辅节点上的日志,你将会看到内容被复制了。









相关内容

热门资讯

终于了解“全民内蒙古麻将辅助器... 有 亲,根据资深记者爆料全民内蒙古麻将是可以开挂的,确实有挂(咨询软件无...
【第一消息】“飞鹰炸/金/花怎... 网上科普关于“飞鹰炸/金/花有没有挂”话题很是火热,小编也是针对飞鹰炸/金/花作*弊开挂的方法以及开...
最新引进“胡乐麻将到底是不是挂... 有 亲,根据资深记者爆料胡乐麻将是可以开挂的,确实有挂(咨询软件无需打开...
【第一财经】“开心安徽比鸡有没... 家人们!今天小编来为大家解答开心安徽比鸡透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里...
终于懂了“新起点可以开挂吗?”... 终于懂了“新起点可以开挂吗?”(太坑了原来有挂)您好,新起点这个游戏其实有挂的,确实是有挂的,需要了...
【第一财经】“昆明文山麻将有挂... 网上科普关于“昆明文山麻将有没有挂”话题很是火热,小编也是针对昆明文山麻将作*弊开挂的方法以及开挂对...
【第一财经】“竞技圈究竟有挂吗... 网上科普关于“竞技圈有没有挂”话题很是火热,小编也是针对竞技圈作*弊开挂的方法以及开挂对应的知识点,...
最新引进“新青鸟大厅拼三张怎么... 网上科普关于“新青鸟大厅拼三张有没有挂”话题很是火热,小编也是针对新青鸟大厅拼三张作*弊开挂的方法以...
最新引进“新青鸟拼三张开挂器?... 最新引进“新青鸟拼三张开挂器?”(详细开挂教程)您好,新青鸟拼三张这个游戏其实有挂的,确实是有挂的,...
今日重磅消息“胡乐晋中麻将究竟... 今日重磅消息“胡乐晋中麻将究竟有挂吗?”(外卦神器下载)您好,胡乐晋中麻将这个游戏其实有挂的,确实是...