【NoSQL】mongo_detail.py中均衡器信息的处理思路

发布时间:2020-08-07 发布网站:编程之家
编程之家收集整理的这篇文章主要介绍了【NoSQL】mongo_detail.py中均衡器信息的处理思路编程之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
【ToolsForMongo】mongo_detail.py中均衡器信息的处理思路

先看下几种典型状况下的db.settings.find({‘_id‘:‘balancer‘})输出:

1.创建mongos之后,从未设置balancer时:

mongos> var x = db.settings.findOne({‘_id‘:‘balancer‘})
mongos> x == null
true
mongos> sh.getBalancerState()
true

2.创建了mongos之后,因故手动关闭了balancer

mongos> db.settings.findOne({‘_id‘:‘balancer‘})
{ "_id" : "balancer","mode" : "off","stopped" : true }
mongos> sh.getBalancerState()
false

3.设置了balancer的运行时间段,但当前时间不在其中

mongos>  var x = db.settings.findOne({‘_id‘:‘balancer‘})
mongos> x
{
    "_id" : "balancer","stopped" : true,"activeWindow" : {
        "start" : "00:00","stop" : "06:00"
    }
}
mongos> sh.getBalancerState()
false

4.设置了balancer的运行时间段,当前时间在其中

mongos> var x = db.settings.findOne({‘_id‘:‘balancer‘})
mongos> x
{
    "_id" : "balancer","stopped" : false,"stop" : "22:00"
    }
}
mongos> sh.getBalancerState()
true

再看下官方mongo shell中的js代码

mongos> sh.getBalancerState
function (configDB) {
    if (configDB === undefined)
        configDB = sh._getConfigDB();
    var x = configDB.settings.findOne({_id: "balancer"});
    if (x == null)
        return true;
    return !x.stopped;
}

1.先处理了configDB不是默认的config库的情况

2.x == null代表了上面的从未设置balancer,默认开启的状况

3.对返回值中的.stopped项进行取反,得到是否正在运行

mongos> sh.isBalancerRunning
function (configDB) {
    if (configDB === undefined)
        configDB = sh._getConfigDB();
    var x = configDB.locks.findOne({_id: "balancer"});
    if (x == null) {
        print("config.locks collection empty or missing. be sure you are connected to a mongos");
        return false;
    }
    return x.state > 0;
}

总结

以上是编程之家为你收集整理的【NoSQL】mongo_detail.py中均衡器信息的处理思路全部内容,希望文章能够帮你解决【NoSQL】mongo_detail.py中均衡器信息的处理思路所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您喜欢交流学习经验,点击链接加入编程之家官方QQ群:1065694478
编程之家官方公众号

微信公众号搜索 “ 程序精选 ” ,选择关注!

微信公众号搜索 “ 程序精选 ”
精选程序员所需精品干货内容!