中文字幕第五页-中文字幕第页-中文字幕韩国-中文字幕最新-国产尤物二区三区在线观看-国产尤物福利视频一区二区

MongoDB復制集配置步驟

1.      配置三個節點的配置文件(/etc/28001.conf)

在廣州等地區,都構建了全面的區域性戰略布局,加強發展的系統性、市場前瞻性、產品創新能力,以專注、極致的服務理念,為客戶提供成都做網站、網站設計 網站設計制作按需開發,公司網站建設,企業網站建設,高端網站設計,營銷型網站,成都外貿網站建設,廣州網站建設費用合理。

 

28002.conf

 

#bind_ip=192.168.20.144

port=28001

logpath=/data/db/MongoDB_log/28001.log

logappend=true

pidfilepath=/data/db/mongodb_data28001/28001.pid

oplogSize=500

dbpath=/data/db/mongodb_data28001

replSet=imooc

fork=true

 

 

28002.conf

 

#bind_ip=192.168.20.144

port=28002

logpath=/data/db/mongodb_log/28002.log

logappend=true

pidfilepath=/data/db/mongodb_data28002/28002.pid

oplogSize=500

dbpath=/data/db/28002

replSet=imooc

fork=true

 

 

28003.conf

 

#bind_ip=192.168.20.144

port=28003

logpath=/data/db/mongodb_log/28003.log

logappend=true

pidfilepath=/data/db/mongodb_data28003/28003.pid

oplogSize=500

dbpath=/data/db/28003

replSet=imooc

fork=true

 

 

2.      使用配置文件啟動mongod服務

/usr/local/mongodb/bin/mongod -f /usr/local/mongodb/conf/28001.conf

/usr/local/mongodb/bin/mongod -f /usr/local/mongodb/conf/28002.conf

/usr/local/mongodb/bin/mongod -f /usr/local/mongodb/conf/28003.conf

 

 

3.      登錄到運行的monogd機器

/usr/local/mongodb/bin/mongo 127.0.0.1:28001/admin

 

 

4.      配置復制集節點配置文件

config={_id : "imooc",members : [{_id : 1, host : "127.0.0.1:28001"},{_id : 2, host : "127.0.0.1:28002"},{_id : 3, host : "127.0.0.1:28003"}]} 

 

5.      查看節點成員

config.members

 

6.      設置3節點為仲裁節點

config.members[3] ={"_id":3,"host":"127.0.0.1:28003",arbiterOnly:true}

 

或在主節點中輸入:

rs.addArb("127.0.0.1:28003")

 

7.      初始化副本集

rs.initiate(config)  (如果初始化一直報已經初始化過,需要將數據備份后,重新創建主節點。)

 

8.      重新加載config參數(每次修改config之后都要reconfig一次,但reconfig會使復制集的連接短暫斷開,要避免在生產環境中隨便執行,需要維護時間窗口才可執行)

rs.reconfig(cnf,{force:true})

(運行此命令必須在primary節點,如果不是顯示primary,可能是other,則需要加上force的參數)

 

9.      查看復制集狀態

rs.status()

 

10. mongodb的前端引用程序是通過isMaster命令來區分主從節點的(隱藏節點可以通過rs.status()看到其信息,而rs.isMaster是沒法看到的)

rs.isMaster()

 

 

維護:

添加副本,在登錄到主節點下輸入:

rs.add("ip:port")

 

刪除副本

rs.remove("ip:port")

(前提是這個ip:port必須是使用了同一個relpSet名稱的mongodb實例即可)

 

 

導入原有數據后,導入命令

mongorestore -h 127.0.0.1:12345 -d syt --directoryperdb /mnt/mongo_data/

其中/mnt/mongo_data為要導入的json文件,后發現從節點都變成recovering狀態。

問題原因
出現這個問題的原因主要是secondary節點同步oplog的速度追不上primary幾點的速度,造成一直處于recovering狀態。

 

解決辦法:
    首先停掉從節點mongod進程,然后刪除目錄(rs)下面所有的數據,然后重啟mongod進程,這里有一點需要注意,如果有arbiter的mongod進程也需要停掉,啟動的時候,先啟動replSet的mongod進程,再啟動arbiter的mongod進程,啟動之后,會自動由recovering狀態切換為startup2狀態,最后切換為secondary狀態

第二種辦法就是先將recovering節點下的data目錄刪除,再將primary里的data都拷貝到該節點下,再重啟就好了!操作前,務必要停止所有的mongodb數據庫!

 

 

可以看到,在從節點使用show tables 報錯,顯示“此節點非主節點,從節點的ok狀態是失敗的”。如果需要在從節點讀取數據的話,需要將slave做設置:

rs.slaveOk(true)

再執行show tables就可以成功了。

 

 

模擬宕機:

在主節點執行:db.shutdownServer()

出現報錯"errmsg" : "shutdown must run from localhost when running db without auth",

此報錯說明在沒有開啟驗證的情況下需要到localhost下執行,如果啟動配置文件里指定了bin_ip,則只能通過bin_ip去執行,這里我們沒法登錄localhost執行,只能通過kill的方式。

 

通過查看ps –ef|grep ****查找到對應進程號

使用kill -2 **** (不到萬不得已不建議使用kill來關閉進程實例,即使是要使用,也要用較溫和的方式kill -2 {SIGINT} 的方式來關閉, kill -2 會把實例中所有隊列的進程都關閉后再關閉實例)

 

關閉之后測試:

查看原先主節點,敲enter已經出現報錯

查看原先從節點,在兩個從節點中敲enter,可發現有一個節點已經變為PRIMARY

 

通過show log rs可以看到節點的切換情況。

MongoDB Enterprise imooc:PRIMARY> show log rs

2017-10-30T01:53:15.617-0700 I REPL     [replExecDBWorker-0] New replica set config in use: { _id: "imooc", version: 1, protocolVersion: 1, members: [ { _id: 1, host: "127.0.0.1:28001", arbiterOnly: false, buildIndexes: true, hidden: false, priority: 1.0, tags: {}, slaveDelay: 0, votes: 1 }, { _id: 2, host: "127.0.0.1:28002", arbiterOnly: false, buildIndexes: true, hidden: false, priority: 1.0, tags: {}, slaveDelay: 0, votes: 1 }, { _id: 3, host: "127.0.0.1:28003", arbiterOnly: false, buildIndexes: true, h

2017-10-30T01:53:15.617-0700 I REPL     [replExecDBWorker-0] transition to STARTUP2

2017-10-30T01:53:15.618-0700 I REPL     [rsSync] transition to RECOVERING

2017-10-30T01:53:15.619-0700 I REPL     [rsSync] transition to SECONDARY

2017-10-30T01:53:15.621-0700 I REPL     [ReplicationExecutor] Member 127.0.0.1:28001 is now in state SECONDARY

2017-10-30T01:53:20.624-0700 I REPL     [ReplicationExecutor] Member 127.0.0.1:28003 is now in state SECONDARY

2017-10-30T01:53:25.625-0700 I REPL     [ReplicationExecutor] Member 127.0.0.1:28001 is now in state PRIMARY

2017-10-30T02:13:53.329-0700 I REPL     [rsBackgroundSync] could not find member to sync from

2017-10-30T02:14:01.816-0700 I REPL     [ReplicationExecutor] transition to PRIMARY

2017-10-30T02:14:03.033-0700 I REPL     [rsSync] transition to primary complete; database writes are now permitted

 

 

 

(待驗證)

如果出現有一個節點找不到oplog(通過日志看出),可通過將主節點的oplog復制到從節點上

 

1.      備份出來:
./mongodump --port 28011 -d local -c oplog.rs  -o  /opt/backup/0706local/

 

2.      恢復到另外一臺單節點MONGODB服務器

 

./mongorestore --port 28011 -d temp_local -c shard1_oplog  --dir /opt/backup/0706local/local/oplog.rs.bson

 

如果恢復時出現報錯Failed: error connecting to db server: no reachable servers

…………….

…………..

 

 

如果出現有一個節點有問題,刪除monogd.lock, 在啟動時加上—repair,再啟動還是啟動不了,而且只是作為一個不存儲數據的仲裁節點的話,最簡單粗暴的方法是通過將節點下的data數據都刪除,然后再重啟,則可啟動成功。

 

本文標題:MongoDB復制集配置步驟
URL標題:http://m.2m8n56k.cn/article18/pccgdp.html

成都網站建設公司_創新互聯,為您提供外貿網站建設微信小程序微信公眾號建站公司軟件開發品牌網站制作

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:[email protected]。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都定制網站網頁設計
主站蜘蛛池模板: 久久久久999 | 亚洲字幕波多野结衣作品 | 久久精品免观看国产成人 | 国产97公开成人免费视频 | 国产人成免费视频 | 在线观看国产情趣免费视频 | 久久亚洲国产成人亚 | 欧美日韩亚洲精品一区 | 成人欧美一区二区三区黑人免费 | 爱视频福利广场 | 精品国产1区 | 欧美另类视频videosbest18 | 国产视频手机在线 | 毛片在线免费观看网站 | 香蕉国产人午夜视频在线 | 成人免费影视网站 | 色丁香久久 | 91精品综合久久久久m3u8 | 国产精品永久免费视频观看 | 免费看一片 | 欧美成人性色区 | 免费看黄色的网址 | 亚洲欧美一二三区 | 国产黄色片在线免费观看 | 成人区在线观看免费视频 | 色涩五月天 | 亚洲高清在线播放 | 亚洲精品黄色 | 日韩一级一欧美一级国产 | 99国产欧美久久精品 | 老司机成人免费精品视频 | 成年人视频在线免费 | 亚洲精品国产一区二区 | 国产欧美日韩在线人成aaaa | 亚州一二区 | 欧美成人特黄级毛片 | 国产三级精品三级国产 | 国产一区精品在线观看 | 亚洲国产精选 | 国产国产人免费视频成69堂 | 亚洲国产欧美自拍 |