加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 服务器 > 系统 > 正文

MongoDB安装与副本集配置步骤

发布时间:2023-10-16 15:57:45 所属栏目:系统 来源:
导读:副本集是一组,由N个mongo节点组成并协同工作的,提供自动的故障集群转移。

建立一个副本集需要步骤,1、需要启动每个节点,2、然后进行初始化设置。在这里,我们将配置一组(三个节点),这是标准设置。

副本集是一组,由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:33333
 
SECONDARY> 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" }
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章