sunren 发表于 2018-10-27 10:06:28

MongoDB安装与副本集配置

副本集是一组,由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  # tar zxvf mongodb-linux-x86_64-2.0.4.tgz
  # mv mongodb-linux-x86_64-2.0.4 /usr/local/mongodb
  # cd /usr/local/mongodb/
  # mkdir -p mongodb_data/mongodb_db
  # mkdir mongodb_data/mongodb_logs
  以上3台服务器,一样的安装步骤
  2.设置启动配置文件
  # 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
  # /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" }  这时候你去看看辅节点上的日志,你将会看到内容被复制了。

页: [1]
查看完整版本: MongoDB安装与副本集配置