mongo实现高可用双机热备


docker环境下mongo配合keepalived实现双机热备功能

主服务器172.17.1.35
从服务器172.17.1.37
VIP 172.17.1.38

高可用搭建参考:
https://blog.csdn.net/qq_35719977/article/details/109199144

一、启动容器


docker run -d -p 27017:27017 --name="mongo_master" hub.c.163.com/library/mongo --noprealloc --smallfiles --replSet rs
docker run -d -p 27018:27017 --name="mongo_arbiter" hub.c.163.com/library/mongo --noprealloc --smallfiles --replSet rs

docker run -d -p 27017:27017 --name="mongo_slave" hub.c.163.com/library/mongo --noprealloc --smallfiles --replSet rs
docker run -d -p 27018:27017 --name="mongo_arbiter" hub.c.163.com/library/mongo --noprealloc --smallfiles --replSet rs


二、配置主服务器
登陆
docker exec -it mongo_master bash
mongo --port 27017
初始化配置文件
myconf = {"_id":"rs","members":[{"_id":0,"host":"172.17.1.35:27017",priority:99},{"_id":1,"host":"172.17.1.37:27017",priority:1},{"_id":2,"host":"172.17.1.38:27018",arbiterOnly:true}]}  
执行初始化配置
rs.initiate(myconf)  


三、设置从服务器节点
docker exec -it mongo_slave bash
mongo --port 27017
rs.slaveOk();  //承认自己是Secondary


四、看主节点状态
rs.isMaster();  //查看主节点配置信息
rs.status();     //查看状态
rs.conf();        //查看配置


六、测试

七、其他说明
当集群中的断开个数大于等于1/2时,整个集群都不可写

参考:

https://blog.csdn.net/luoni186/article/details/77369293

https://blog.csdn.net/jacson_bai/article/details/41941885

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
MongoTemplate 是 Spring Data MongoDB 提供的一个用于操作 MongoDB 的类。要实现类似于 SQL 中的 BETWEEN 操作,可以使用 MongoTemplate 的 Query 对象和 Criteria 条件来构建查询条件。 以下是使用 MongoTemplate 实现 BETWEEN 操作的示例代码: ```java import org.springframework.data.mongodb.core.MongoTemplate; import org.springframework.data.mongodb.core.query.Criteria; import org.springframework.data.mongodb.core.query.Query; import java.util.Date; import java.util.List; public class MyMongoTemplate { private final MongoTemplate mongoTemplate; public MyMongoTemplate(MongoTemplate mongoTemplate) { this.mongoTemplate = mongoTemplate; } public List<MyDocument> findDocumentsBetweenDates(Date startDate, Date endDate) { Criteria criteria = Criteria.where("dateField").gte(startDate).lte(endDate); Query query = Query.query(criteria); return mongoTemplate.find(query, MyDocument.class); } } ``` 上述代码中的 `dateField` 是指要进行 BETWEEN 操作的日期字段,`startDate` 和 `endDate` 分别是 BETWEEN 范围的起始日期和结束日期。在 `findDocumentsBetweenDates` 方法中,我们使用 `Criteria` 来定义查询条件,然后使用 `Query` 对象将该条件应用于查询,最后通过 `mongoTemplate.find` 方法执行查询并返回结果。 请注意,上述示例中的 `MyDocument` 是一个自定义的实体类,代表了 MongoDB 中的一条文档。你需要根据你的实际情况来修改和适应代码。 希望能够帮助到你!如果有任何问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

悠悠寻燕语

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值