MongoDB安装与副本集配置
一旦mongod節點啟動,我們將發出一個命令,以正確地初始化設置。幾秒鐘后,將選舉產生一個主節點,你就可以開始寫和查詢集。
環境描述:
a.192.168.30.112:3306 ? 主節點
b.192.168.30.113:3306 ? 從節點
c.192.168.30.114:3306 ? 從節點
[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 節點默認是不可讀的
在主庫上設置?slaveok=ok
PRIMARY>?db.getMongo().setSlaveOk();
在從庫進行測試 SECONDARY> db.user.find() { "_id" : ObjectId("4eb68b1540643e10a0000000"), "id" : 1, "name" : "zhangsan" } { "_id" : ObjectId("4eb68b1540643e10a0000001"), "id" : 2, "name" : ";lisi" }
這時候你去看看輔節點上的日志,你將會看到內容被復制了。
? ? ?本文轉自ljl_19880709 51CTO博客,原文鏈接:http://blog.51cto.com/luojianlong/1347169,如需轉載請自行聯系原作者
總結
以上是生活随笔為你收集整理的MongoDB安装与副本集配置的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【移动开发】Android应用程序中实用
- 下一篇: java中读取Excel表格中的数据