MongoDB
 sql >> Database >  >> NoSQL >> MongoDB

MongoDB come servizio Windows e configurazione di replicaSet

È 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/