在Linux系统中搭建MongoDB集群,通常需要以下几个步骤:
在每台服务器上安装MongoDB。以下是在CentOS 7上的示例:
# 导入MongoDB官方YUM仓库
wget -qO - https://www.mongodb.org/static/pgp/server-4.4.asc | sudo apt-key add -
echo "deb [ arch=amd64,arm64 ] https://repo.mongodb.org/apt/ubuntu focal/mongodb-org/4.4 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-4.4.list
sudo apt-get update
sudo apt-get install -y mongodb-org
编辑MongoDB配置文件(通常是/etc/mongod.conf),设置副本集参数。以下是一个示例配置:
storage:
dbPath: /var/lib/mongo
journal:
enabled: true
systemLog:
destination: file
logAppend: true
path: /var/log/mongodb/mongod.log
net:
port: 27017
bindIp: 0.0.0.0
replication:
replSetName: rs0
在每台服务器上启动MongoDB服务:
sudo systemctl start mongod
sudo systemctl enable mongod
连接到任意一台MongoDB实例,并初始化副本集:
mongo --host <hostname> --port 27017
在mongo shell中执行以下命令:
rs.initiate(
{
_id: "rs0",
members: [
{ _id: 0, host: "<hostname1>:27017" },
{ _id: 1, host: "<hostname2>:27017" },
{ _id: 2, host: "<hostname3>:27017" }
]
}
)
将<hostname>替换为每台服务器的主机名或IP地址。
在mongo shell中执行以下命令来验证副本集的状态:
rs.status()
你应该看到所有节点都处于SECONDARY或PRIMARY状态。
如果你需要搭建分片集群,还需要配置分片服务器和配置服务器。以下是简要步骤:
在每台配置服务器上启动MongoDB,并确保它们可以互相通信。
在每台分片服务器上启动MongoDB,并确保它们可以连接到配置服务器。
启动mongos进程,它将作为应用程序和分片集群之间的路由器:
mongos --configdb <config_replica_set>/<hostname>:<port>,<hostname>:<port>,<hostname>:<port>
将<config_replica_set>替换为配置服务器副本集的名称,<hostname>和<port>替换为配置服务器的地址和端口。
连接到mongos进程,并添加分片:
sh.addShard("<shard_name>/<hostname>:<port>")
将<shard_name>替换为分片的名称,<hostname>和<port>替换为分片服务器的地址和端口。
启用数据库和集合的分片:
sh.enableSharding("<database_name>")
sh.shardCollection("<database_name>.<collection_name>", { "<shard_key>": 1 })
将<database_name>替换为数据库名称,<collection_name>替换为集合名称,<shard_key>替换为分片键。
通过以上步骤,你应该能够在Linux系统中成功搭建MongoDB集群。