MongoDB支持几种不同的集群架构,包括副本集、分片集群和分布式集群。
- 副本集: 副本集是一组维护相同数据副本的MongoDB服务器。副本集有一个主节点(primary)和多个从节点(secondary),可以进行自动故障转移。
# 启动MongoDB实例
mongod --replSet rs0 --port 27017 --dbpath /srv/mongodb/db0
mongod --replSet rs0 --port 27018 --dbpath /srv/mongodb/db1
mongod --replSet rs0 --port 27019 --dbpath /srv/mongodb/db2
# 初始化副本集
rs.initiate(
{
_id: "rs0",
members: [
{ _id: 0, host: "localhost:27017" },
{ _id: 1, host: "localhost:27018" },
{ _id: 2, host: "localhost:27019" }
]
}
)
- 分片(Sharding): 分片是指将数据分散到不同的服务器(分片服务器)上,可以提高数据库的数据处理能力。
# 启动分片(shard)服务器
mongod --shardsvr --port 27017 --dbpath /srv/mongodb/db0
mongod --shardsvr --port 27018 --dbpath /srv/mongodb/db1
mongod --shardsvr --port 27019 --dbpath /srv/mongodb/db2
# 启动配置服务器
mongod --configsvr --port 27017 --dbpath /srv/mongodb/configdb0
# 启动路由服务器
mongos --port 27017 --configdb localhost:27017
- 分布式集群(Cluster): 分布式集群是MongoDB的高可用性解决方案,它提供了数据的异地备份。
# 在各自的服务器上启动MongoDB实例
mongod --port 27017 --dbpath /srv/mongodb/db0
# 使用mongos启动分布式集群
mongos --configdb localhost:27017 --chunkSize 1
以上是搭建MongoDB集群的基本方法,具体配置可能需要根据实际需求进行调整。