1. 副本集基础概念:
- 一个副本集是由多个 MongoDB 实例组成的集群,其中一个是主节点(Primary),其余的是从节点(Secondary)。
- 主节点处理所有的写操作,从节点复制主节点的数据,并可用于读取操作。
- MongoDB 复制提供了自动故障转移功能,如果主节点不可用,系统会自动选择一个从节点作为新的主节点。
2. 创建副本集:
- 要创建副本集,首先需要启动多个 MongoDB 实例,并配置它们以形成副本集。
- 示例:
rs.initiate(
{
_id: "myReplicaSet",
members: [
{ _id: 0, host: "mongo1:27017" },
{ _id: 1, host: "mongo2:27017" },
{ _id: 2, host: "mongo3:27017" }
]
}
)
- 在上面的示例中,myReplicaSet 是副本集的名称,包含三个成员,每个成员的 _id 和 host 分别指定成员的唯一标识和主机地址。
3. 添加和移除成员:
- 可以在运行时添加或移除副本集的成员。
- 示例:
rs.add("newMember:27017")
rs.remove("oldMember:27017")
4. 读写操作:
- 写操作只能在主节点上执行,而读操作可以在主节点和从节点上执行。
- 应用程序可以通过读写分离来利用从节点进行读取操作,减轻主节点的负载。
5. 监控副本集:
- 可以使用 rs.status() 命令来查看副本集的状态,包括各个成员的健康状况和复制状态。
rs.status()
上述是 MongoDB 复制和副本集的一些基本概念和操作。副本集提供了数据冗余、高可用性和自动故障转移等功能,使得 MongoDB 在面对硬件故障或维护时能够保持服务的可用性。
转载请注明出处:http://www.pingtaimeng.com/article/detail/14230/MongoDB