我已經安裝了MongoDB及其設置爲Windows服務。當我嘗試設置replicaSet時,出現錯誤「通常只允許使用每個套接字地址(協議/網絡地址/端口),對於套接字:0.0.0.0:27017」。MongoDB作爲Windows服務和設置副本集
因此,我已經停止了windows服務並設置了replicaSet。 replicaSet現在工作正常。但是,我沒有看到Windows服務正在運行。這是否意味着我無法同時設置replicaSet和MongoDB服務?
我已經安裝了MongoDB及其設置爲Windows服務。當我嘗試設置replicaSet時,出現錯誤「通常只允許使用每個套接字地址(協議/網絡地址/端口),對於套接字:0.0.0.0:27017」。MongoDB作爲Windows服務和設置副本集
因此,我已經停止了windows服務並設置了replicaSet。 replicaSet現在工作正常。但是,我沒有看到Windows服務正在運行。這是否意味着我無法同時設置replicaSet和MongoDB服務?
您可以在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>
非常感謝。有用。測試replicaSet的方法有哪些?一個例子是停止小學,看看是否有一名中學被選爲主要。請讓我知道你是否可以考慮其他測試用例。 – jmrio
我認爲這屬於http://dba.stackexchange.com。這不是一個與編程有關的問題。 –
我爲這個問題添加了'DBA'和'replication'標籤。 – jmrio