2013-07-01 35 views
0

我已經安裝了MongoDB及其設置爲Windows服務。當我嘗試設置replicaSet時,出現錯誤「通常只允許使用每個套接字地址(協議/網絡地址/端口),對於套接字:0.0.0.0:27017」。MongoDB作爲Windows服務和設置副本集

因此,我已經停止了windows服務並設置了replicaSet。 replicaSet現在工作正常。但是,我沒有看到Windows服務正在運行。這是否意味着我無法同時設置replicaSet和MongoDB服務?

+2

我認爲這屬於http://dba.stackexchange.com。這不是一個與編程有關的問題。 –

+0

我爲這個問題添加了'DBA'和'replication'標籤。 – jmrio

回答

10

您可以在Windows上同時設置副本集和MongoDB服務。由於您已經設置了副本集,因此您知道每個副本集成員都需要有一個數據目錄和一個日誌文件。如果您在單臺計算機上運行所有副本集成員,則必須爲每個副本集成員分配不同的端口號。提供的樣本僅用於開發或功能測試。在一臺機器上設置所有副本集成員將會構成一個單一的故障點,並且會成爲一個完整的性能拖延。

爲每個副本集成員創建配置文件,包括數據目錄,日誌文件,端口號和副本集名稱。例如,我有一個由3個成員組成的副本集,一個在端口27017上運行的主Mongodb和兩個在MongoDB2端口上的Mongodb1,以及在端口47017上的Mongodb2。副本集名稱爲rs1。

這裏是Mongodb實例的配置文件。

# mongod.cong 

# 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 

以下是其中一個次級配置文件。

# 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 

以下鏈接提供了配置文件選項的完整列表。 http://docs.mongodb.org/manual/reference/configuration-options/

將所有三個MongoDB實例添加爲Windows服務。由於我沒有指定服務和服務顯示名稱,MongoDB的服務將使用默認的服務/服務顯示名稱的MongoDB

C:\mongodb-2.4.4\bin>mongod --config C:\mongodb-2.4.4\mongod.cfg --install 

安裝與服務名稱,服務顯示名稱另外兩個MongoDB的實例。

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 

開始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. 

的所有三個實例驗證使用與查詢選項sc命令所有三個Windows服務的狀態。

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 

從MongoDB shell配置副本集。在以下示例中,端口27017上的MongoDB實例將成爲主副本集成員。

C:\mongodb-2.4.4\bin>mongo --port 27017 

從MongoDB shell中設置副本集配置。

> config = { _id: "rs1", members:[ 
... { _id : 0, host : "localhost:27017"}, 
... { _id : 1, host : "localhost:37017"}, 
... { _id : 2, host : "localhost:47017"} 
... ] } 

在MongoDB shell中,初始化副本集並驗證其狀態。

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

您還可以檢查輔助者的狀態。在這裏,我連接到次級的一個在端口37017.

C:\mongodb-2.4.4\bin>mongo --port 37017 

以下提示將呈現MongoDB中殼表示二次狀態。

rs1:SECONDARY> 
+0

非常感謝。有用。測試replicaSet的方法有哪些?一個例子是停止小學,看看是否有一名中學被選爲主要。請讓我知道你是否可以考慮其他測試用例。 – jmrio