yum 安裝mongodb 配置複製集 (主從複製)

一.配置yum 倉庫

vim /etc/yum.repos.d/mongodb-org-4.2.repo #新建倉庫文件mongodb

[mongodb-org-4.2]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/4.2/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-4.2.asc

yum 安裝mongodb 配置複製集 (主從複製)
幾個包的做用
1.mongodb-org-server: 主程序包含MongoDB守護進程和相關的配置和初始化腳本。
2.mongodb-org-mongos: 包含mongos的守護進程。(切片分庫使用的)
3.mongodb-org-shell: 包含mongo shell。
4.mongodb-org-tools: 包含MongoDB的工具: mongoimport, bsondump, mongodump, mongoexport, mongofiles, mongooplog, mongoperf, mongorestore, mongostat, and mongotop。shell

二.安裝

yum install mongodb-org -y

三.配置複製集
先安裝好兩個節點,在配置每一個節點的配置,配置除了監聽IP不同其均同樣配置
vim /etc/mongo.conf數據庫

systemLog:
  destination: file
  logAppend: true
  path: /var/log/mongodb/mongod.log

storage:
  dbPath: /var/lib/mongo
  journal:
    enabled: true

processManagement:
  fork: true  # fork and run in background
  pidFilePath: /var/run/mongodb/mongod.pid  # location of pidfile
  timeZoneInfo: /usr/share/zoneinfo

net:
  port: 27017
  bindIp: 192.168.0.11

replication:  #開啓複製集功能
    replSetName: test-rc #名稱注意不能頂格寫不然報錯

mongo -host 192.168.0.9 #進入節點json

rs.status() #查看複製集狀態
yum 安裝mongodb 配置複製集 (主從複製)
兩個節點都和上圖同樣說明覆制集正常啓動了
cfg={"_id":"test-rc","members":[{"_id":0,"host":"192.168.0.9:27017"},{"_id":1,"host":"192.168.0.11:27017"}]}
#定義初始化參數,將兩個host主機加入到test-rc複製集當中
rs.initiate(cfg) #啓動複製集功能(初始化配置時要保證從節點沒有數據)
rs.status() 查看複製集狀態
yum 安裝mongodb 配置複製集 (主從複製)vim

三,增長新節點,刪除節點

如今192.168.0.13 新節點上安裝好mongodb 配置里加入複製集並啓動起來
登陸主節點
rs.add("192.168.0.13:27017") #加入新的節點
yum 安裝mongodb 配置複製集 (主從複製)
re.status()
yum 安裝mongodb 配置複製集 (主從複製)
查看複製集狀態,能夠看到192.168.0.13節點已然在線了
rs.remove("192.168.0.13:27017") #刪除節點
yum 安裝mongodb 配置複製集 (主從複製)
再用rs.status()查看下,能夠發現已經沒有192.168.0.13節點的信息了ide

四,手動切換節點

rs.freeze(30) #暫停30s 不參與選舉
rs.stepDown(60,30) #交出主節點位置,維持從節點狀態很多於60秒,等待30秒使主節點和從節點日誌同步(用於切換)工具

五,設置從節點可讀

db.getMongo().setSlaveOk() #設置從節點可讀
yum 安裝mongodb 配置複製集 (主從複製)
主節點
yum 安裝mongodb 配置複製集 (主從複製)
從節點oop

六,備份恢復

mongodump --port 20000 --host 192.168.0.9 -d testdb -o /root/test
#只備份testdb 數據庫,備份到/root/test/ 路徑 注意 上面有兩個--
mongorestore -d k1 /root/test/testdb/
#把/root/test/testdb/ 裏的備份的數據,恢復成k1數據庫
mongodump --port 20000 --host 192.168.0.9 -o /root/all
#備份全部數據
mongoexport --port 20000 --host 192.168.0.9 -d testdb -c table1 -o /root/table1.json
#只備份testdb庫裏的 table1 表
mongoimport --host 192.168.0.14 -d k1 -c table2 --file=/root/table1.json
#把/root/table1.json 的數據恢復到k1庫 table2 表url

相關文章
相關標籤/搜索