MongoDB作为Windows服务及设置复制集

11

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

所以,我停止了Windows服务并设置了replicaSet。 replicaSet现在可以正常工作。但是,我没有看到Windows服务正在运行。这是否意味着我不能同时设置replicaSet和MongoDB服务?


3
我认为这个问题应该发布在http://dba.stackexchange.com。这不是一个与编程有关的问题。 - Steve B
我已经为这个问题添加了“DBA”和“复制”标签。 - jmrio
2个回答

42
您可以在Windows上同时设置副本集和MongoDB服务。由于您已经设置了副本集,因此您需要为每个副本集成员设置数据目录和日志文件。如果您在单台计算机上运行所有副本集成员,则必须为每个副本集成员分配不同的端口号。提供的示例仅用于开发或功能测试。在单台计算机上设置所有副本集成员将构成单一故障点,并且会对性能造成总体拖延。
为每个副本集成员创建配置文件,包括数据目录、日志文件、端口号和副本集名称。例如,我有一个由3个成员组成的副本集,一个主要的Mongodb运行在端口27017上,两个次要的Mongodb1运行在端口37017上,Mongodb2运行在端口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

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

启动所有三个MongoDB实例

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>

这里有一个关于部署副本集的教程: https://docs.mongodb.com/manual/tutorial/deploy-replica-set/


非常感谢。它起作用了。有什么测试复制集的方法?一个例子是停止PRIMARY,看是否会有其中一个Secondary被选举为PRIMARY。如果您能想到其他测试案例,请告诉我。 - jmrio
1
这对我帮助很大。只需注意,在当前版本(4.0)中,mongod.conf文件略有不同,特别是复制部分现在是:replication: replSetName: "replName"。提供的链接解释了这一点,但您可能需要考虑答案集成。 - DLM
@DLM 负责指定哪个是主要的,哪个是次要的吗? - Royi Namir

2

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接