您好,登錄后才能下訂單哦!
實戰MongoDB
Master-Slave
MongoDB支持不同服務之間的異步的數據復制,來實現failover(故障轉移,故障切換,故障恢復) and redundancy(數據冗余)。
同一時間,只有一個服務節點(primary或者master)支持寫入。
MongoDB支持兩種復制的模式:
介紹Master/Slave的官方地址:
http://www.mongodb.org/display/DOCS/Master+Slave
介紹Replica Set的官方地址:
http://www.mongodb.org/display/DOCS/Replica+Sets
今天實戰的是replica set,也就是復制集復制。
通常用于下面幾個場景
首先還是啟動mongod,用于replica set的參數有兩個:
--replSet <setname>,復制集的名稱。
--oplogSize <MB>,操作日志的大小,單位為MB。
這回我們在ubuntu下面配置replica set,先啟動兩個mongod節點。
- mongod --dbpath /home/andyshi/mongo1/ --logpath /home/andyshi/mongo1/log.log --replSet shard1 --port 10001 --bind_ip 192.168.0.21
- mongod --dbpath /home/andyshi/mongo2/ --logpath /home/andyshi/mongo2/log.log --replSet shard1 --port 10002 --bind_ip 192.168.0.21
你會注意到,上面兩個mongod的啟動參數replSet指定了相同的值shard1,也就是兩個個mongod節點處于同一個replica set中。
Replica Set的初始化
光啟動了兩個個mongod節點,還不能提供任何的服務,這時候你使用mongo連接之后,進行db.book.insert會提示你no master,也就是說沒有primary節點,所以他不知道往哪一個節點寫入數據。
在啟動了兩個個mongod節點之后,需要進行初始化。
首先用mongo連接到任意一個mongod節點,然后執行下面的命令。
- cfg={_id:'shard1',members:[
- {_id:0,host:'192.168.0.21:10001'},
- {_id:1,host:'192.168.0.21:10002'}]
- }
- rs.initiate(cfg)
出現下面的提示信息就代表成功了,如果沒有成功,可以google一下錯誤提示,會找到很多的答案的。
- {
- "info" : "Config now saved locally. Should come online in about a minute.",
- "ok" : 1
- }
繼續執行
- rs.status()
可以查看replica set的狀態,包括名稱,時間,當前登錄的mongod是primary還是secondary,以及成員的信息等。
在replica set的信息中,其中重要的是:
成員信息中包括地址,健康狀態,是primary還是secondary等。
成員信息中比較重要的是
這時候登錄primary的mongod,插入一條數據。
- //假設10001是primary,可以通過查詢rs.status來獲取
- mongo 192.168.0.21:10001
- use test
- db.book.insert({'title':'computer'})
然后查看secondary的log文件,會發現發生了復制行為。
這時候登錄secondary,use test,db.book.find(),可以報錯了。
- error: { "$err" : "not master and slaveok=false", "code" : 13435 }
沒有關系,在secondary讀取數據還需要我們做最后的一步,在需要讀取數據的secondary上執行。
- rs.slaveOK()
這時候再次db.book.find(),正常顯示結果了,沒有問題了。
添加節點
啟動新mongod節點
- mongod --dbpath /home/andyshi/mongo3/ --logpath /home/andyshi/mongo3/log.log --replSet shard1 --port 10003 --bind_ip 192.168.0.21
連接primary節點,執行下面的命令。
- rs.add('192.168.0.21:10003')
- rs.addArb('192.168.0.21:10003')
- //重新配置
- rs.reconfig(rs.conf())
強制一個節點成為primary
在mongodb2.0之后可以使用下面
相比master-slave,replica set的優點就是沒有單點故障,primary故障之后,整個replica set會自動選擇一個健康的節點成為primary,承擔寫的任務,可用性比master-slave的高,提供更高的可用性。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。