MongoDB安装与副本集配置步骤
发布时间:2023-10-16 15:57:45 所属栏目:系统 来源:
导读:副本集是一组,由N个mongo节点组成并协同工作的,提供自动的故障集群转移。
建立一个副本集需要步骤,1、需要启动每个节点,2、然后进行初始化设置。在这里,我们将配置一组(三个节点),这是标准设置。
一
建立一个副本集需要步骤,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" } (编辑:聊城站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐