È possibile configurare il set di repliche e il servizio MongoDB contemporaneamente su Windows. Poiché è già stato impostato un set di repliche, è necessario disporre di una directory di dati e di un file di registro per ogni membro del set di repliche. Se si eseguono tutti i membri del set di repliche su una singola macchina, a ciascun membro del set di repliche deve essere assegnato un numero di porta diverso. Il campione fornito è solo per lo sviluppo o il test funzionale. L'impostazione di tutti i membri del set di repliche su una singola macchina costituirà un singolo punto di errore oltre a rappresentare un ostacolo totale alle prestazioni.
Creare un file di configurazione per ogni membro del set di repliche, inclusi directory dati, file di registro, numero di porta e nome del set di repliche. Ad esempio, ho un set di repliche di 3 membri, un Mongodb primario in esecuzione sulla porta 27017 e due secondari, Mongodb1 sulla porta 37017 e Mongodb2 sulla porta 47017. Il nome del set di repliche è rs1.
Ecco il file di configurazione per esempio Mongodb.
# mongod.conf
# data directory
dbpath=C:\data\db
# log file
logpath=C:\mongodb-win32-i386-2.4.4\log\mongo.log
logappend=true
#port number
port=27017
#replica set name
replSet=rs1
Ecco il file di configurazione per una delle secondarie.
# mongo.conf
# data directory
dbpath=C:\data\db2
# log file
logpath=C:\mongodb-win32-i386-2.4.4\log2\mongo.log
logappend=true
# port number
port=47017
# replica set name
replSet=rs1
Il seguente collegamento fornisce un elenco completo delle opzioni del file di configurazione:http://docs.mongodb.org/manual/reference/configuration-options/
Aggiungi tutte e tre le istanze MongoDB come servizio Windows. Poiché non ho specificato il servizio e il nome visualizzato del servizio, il servizio MongoDB utilizzerà il nome visualizzato del servizio/servizio predefinito MongoDB
C:\mongodb-2.4.4\bin>mongod --config C:\mongodb-2.4.4\mongod.cfg --install
Installa le altre due istanze MongoDB con il nome del servizio e il nome visualizzato del servizio.
C:\mongodb-2.4.4\bin>mongod --config C:\mongodb-2.4.4\mongod1.cfg --serviceName MongoDB1 --serviceDisplayName MongoDB1 --install
C:\mongodb-2.4.4\bin>mongod --config C:\mongodb-2.4.4\mongod2.cfg --serviceName MongoDB2 --serviceDisplayName MongoDB2 --install
Avvia tutte e tre le istanze di MongDB
C:\mongodb-2.4.4\bin>net start mongodb
The Mongo DB service is starting.
The Mongo DB service was started successfully.
C:\mongodb-2.4.4\bin>net start mongodb1
The MongoDB1 service is starting.
The MongoDB1 service was started successfully.
C:\mongodb-2.4.4\bin>net start mongodb2
The MongoDB2 service is starting.
The MongoDB2 service was started successfully.
Verifica lo stato di tutti e tre i servizi Windows utilizzando il comando sc con l'opzione query.
C:\mongodb-2.4.4\bin>sc query mongodb
C:\mongodb-2.4.4\bin>sc query mongodb1
C:\mongodb-2.4.4\bin>sc query mongodb2
Configura il set di repliche dalla shell MongoDB. Nell'esempio seguente, l'istanza MongoDB sulla porta 27017 sarà il membro del set di repliche primario.
C:\mongodb-2.4.4\bin>mongo --port 27017
Imposta la configurazione del set di repliche dalla shell di MongoDB.
> config = { _id: "rs1", members:[
... { _id : 0, host : "localhost:27017"},
... { _id : 1, host : "localhost:37017"},
... { _id : 2, host : "localhost:47017"}
... ] }
Nella shell di MongoDB, inizializza il set di repliche e verifica il suo stato.
> rs.initiate(config)
{
"info" : "Config now saved locally. Should come online in about a minute.",
"ok" : 1
}
> rs.status()
{
"set" : "rs1",
"date" : ISODate("2013-07-02T18:40:27Z"),
"myState" : 1,
"members" : [
{
"_id" : 0,
"name" : "localhost:27017",
"health" : 1,
"state" : 1,
"stateStr" : "PRIMARY",
"uptime" : 651,
"optime" : {
"t" : 1372790393,
"i" : 1
},
"optimeDate" : ISODate("2013-07-02T18:39:53Z"),
"self" : true
},
{
"_id" : 1,
"name" : "localhost:37017",
"health" : 1,
"state" : 2,
"stateStr" : "SECONDARY",
"uptime" : 31,
"optime" : {
"t" : 1372790393,
"i" : 1
},
"optimeDate" : ISODate("2013-07-02T18:39:53Z"),
"lastHeartbeat" : ISODate("2013-07-02T18:40:26Z"),
"lastHeartbeatRecv" : ISODate("1970-01-01T00:00:00Z"),
"pingMs" : 0,
"syncingTo" : "localhost:27017"
},
{
"_id" : 2,
"name" : "localhost:47017",
"health" : 1,
"state" : 2,
"stateStr" : "SECONDARY",
"uptime" : 31,
"optime" : {
"t" : 1372790393,
"i" : 1
},
"optimeDate" : ISODate("2013-07-02T18:39:53Z"),
"lastHeartbeat" : ISODate("2013-07-02T18:40:26Z"),
"lastHeartbeatRecv" : ISODate("1970-01-01T00:00:00Z"),
"pingMs" : 0,
"syncingTo" : "localhost:27017"
}
],
"ok" : 1
}
rs1:PRIMARY>
Puoi anche controllare lo stato delle secondarie. Qui mi sto collegando a uno dei secondari sulla porta 37017.
C:\mongodb-2.4.4\bin>mongo --port 37017
Il seguente prompt si presenterà nella shell di MongoDB mostrando lo stato secondario.
rs1:SECONDARY>
Un tutorial sulla distribuzione di un set di repliche è disponibile qui:https://docs.mongodb.com/manual/tutorial/deploy-replica-set/