溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

mongodb3.4.4安裝副本集,分片和遇到的一些問題(一

發(fā)布時間:2020-07-28 14:21:00 來源:網(wǎng)絡(luò) 閱讀:673 作者:wks97 欄目:MongoDB數(shù)據(jù)庫

廢話不多說

三臺機器

host1,host2,host3

查看官方安裝文檔https://docs.mongodb.com/manual/tutorial/install-mongodb-on-red-hat/

編輯源文件

vim /etc/yum.repos.d/mongodb-org-3.4.repo

[mongodb-org-3.4]
name=MongoDB 
Repositorybaseurl=gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-3.4.asc

安裝

yum install -y mongodb-org

由于我是在3臺虛擬機上做的,宿主機其實是一個,所以配置了3個端口,

注意:mongod的配置文件遵循yaml文件格式!

[root@vultr ~]# cat /etc/mongod.conf 
# mongod.conf

# for documentation of all options, see:
#   http://docs.mongodb.org/manual/reference/configuration-options/

# where to write logging data.
systemLog:
  destination: file
  logAppend: true
  path: /var/log/mongodb/mongod.log

# Where and how to store data.
storage:
  dbPath: /var/lib/mongo
  journal:
    enabled: true
#  engine:
#  mmapv1:
#  wiredTiger:

# how the process runs
processManagement:
  fork: true  # fork and run in background
  pidFilePath: /var/run/mongodb/mongod.pid  # location of pidfile

# network interfaces
net:
  port: 27017
#  bindIp: 127.0.0.1  # Listen to local interface only, comment to listen on all interfaces.


#security:
#keyFile = /opt/key/autokey
#operationProfiling:

#replication:
replication:
   oplogSizeMB: 1000
   replSetName: rstest
#sharding:

## Enterprise-Only Options

#auditLog:

#snmp:

基本上是默認配置,dbdata位置和log目錄看具體情況,酌情修改,bindip 默認是打開的,注銷了,不然mongo只會本地訪問

啟動

mongod -f /etc/mongod.conf

這時可以隨便進入一臺mongod 進行副本集的初始化

mongo 進入,默認是27017端口,但是如果改變端口,就要用mongo ip:port的方式了

首先加載配置

config={_id:"rstest",members:[{_id:0,host:"host1:port"},{_id:1,host:"host2:port"},{_id:2,host:"host3:port"}]}
##_id 必須是配置文件中副本集的名字

副本集初始化

rs.initiate(config)

這里有一點要注意,要保證每臺mongodb的之間的連通性,和每個mongo都是空數(shù)據(jù),不然在建立副本集的時候會報錯,如果數(shù)據(jù)庫不是空的,必須要先剔除副本集,然后刪除db.dropDatabase()

最后配置生效

rs.reconfig(config)

日常的橫向擴展和伸縮,以及手動配置主節(jié)點

PRIMARY> rs.add("127.0.0.1:27018");   //添加節(jié)點
PRIMARY> rs.remove("127.0.0.1:27018"); //刪除節(jié)
這兩個命令是不需要做rs.reconfig(config)配置生效的
rs.conf()// 查看配置
config=rs.conf() //讀取配置
config.members[1].priority = N // N = 1到100 越大越優(yōu)先變主節(jié)點
rs.reconfig(config) //讓配置生效,一會就host2 就會變成主節(jié)點

選舉的算法:

mongodb 集群的選擇局算法其實和zookeeper差不多,區(qū)別在于用的是bully算法,mongod 會先對比誰是最后一次進行數(shù)據(jù)操作的,也就是說,誰的數(shù)據(jù)最新,如果數(shù)據(jù)一樣,那么就會對比誰可以用最短的時間成為主節(jié)點,選舉過程和zookeeper一樣,只是對比k-v不太一樣。

另外,在集群的選舉過程中,不想讓某個從節(jié)點變成主節(jié)點,可以用

rs.freeze(120) //小括號里的數(shù)據(jù)是凍結(jié)時間,也就是說在120秒內(nèi)該節(jié)點不可以變成主節(jié)點,單位秒


向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI