MongoDB作为windows服务和设置replicaSet

MongoDB作为windows服务和设置replicaSet,mongodb,replication,Mongodb,Replication,我已经安装了MongoDB,并将其设置为windows服务。当我尝试设置replicaSet时,我收到错误“每个套接字地址(协议/网络地址/端口)通常只允许使用一次。对于套接字:0.0.0.0:27017” 因此,我已停止windows服务并设置了replicaSet。这套设备现在运转良好。但是,我没有看到windows服务启动并运行。这是否意味着我不能同时设置replicaSet和MongoDB服务?您可以在Windows上同时设置replica set和MongoDB服务。因为您已经设置了副

我已经安装了MongoDB,并将其设置为windows服务。当我尝试设置replicaSet时,我收到错误“每个套接字地址(协议/网络地址/端口)通常只允许使用一次。对于套接字:0.0.0.0:27017”


因此,我已停止windows服务并设置了replicaSet。这套设备现在运转良好。但是,我没有看到windows服务启动并运行。这是否意味着我不能同时设置replicaSet和MongoDB服务?

您可以在Windows上同时设置replica set和MongoDB服务。因为您已经设置了副本集,所以您知道需要为每个副本集成员设置一个数据目录和一个日志文件。如果在一台计算机上运行所有副本集成员,则必须为每个副本集成员分配不同的端口号。提供的样本仅用于开发或功能测试。在一台计算机上设置所有副本集成员将构成一个单一的故障点,此外还会造成总体性能损失

为每个副本集成员创建一个配置文件,包括数据目录、日志文件、端口号和副本集名称。例如,我有一个包含3个成员的副本集,一个主要Mongodb运行在端口27017上,两个次要Mongodb运行在端口37017上,Mongodb1和47017上。副本集名称为rs1

下面是实例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
下面是其中一个辅助设备的配置文件

# 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
以下链接提供了配置文件选项的完整列表:

将所有三个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 shell中将出现以下提示,显示辅助状态

rs1:SECONDARY>
有关部署副本集的教程可在此处找到:
不包括维修零件

但是设置分片副本集。 尝试此博客在本地安装mongodb群集,它包含所有配置文件和windows脚本,用于创建所需的文件夹结构


我想这是属于你的。这不是一个与编程相关的问题。我已经为这个问题添加了“DBA”和“复制”标记。非常感谢。它起作用了。测试复制集的方法有哪些?一个例子是停止初级选举,看看是否有一个次级选举被选为初级选举。请让我知道你是否可以考虑其他测试用例。这对我帮助很大。请注意,在当前版本(4.0)中,mongod.conf文件略有不同,特别是复制部分现在是:
replication:replSetName:“replName”
。所提供的链接解释了这一点,但您可能需要考虑答案集成。