。尝试了两个解决办法:  1.登录"/>

记一次手误造成mongo数据库主副集全部变成的副集的处理

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了记一次手误造成mongo数据库主副集全部变成的副集的处理相关的知识,希望对你有一定的参考价值。

系统环境:CentOS6.5 

软件:mongodb2.8


原来是想到现在的数据进行添加副本集,方便读写的,没想到悲剧了,现在连原来的主数据都变成了从的数据库,怎么也换不过去技术分享


尝试了两个解决办法: 

  1 . 登录的原的主mongodb ,用rs.remove()的办法把后来添加的副本集从member里移掉,失败了。

   技术分享真的悲剧了,怎么都remove不掉,因为原来的master已经变成了slave,不能remove其它成员


2 . 更改config,修改member 0 的优先级,抢占master。


技术分享

执行也是失败,因为当前不是master 。


无奈,只能另找其它办法,因为对mongo数据的并不太熟悉。

后来看了一下网上的文章:https://segmentfault.com/q/1010000000532867 也是关于这个问题的。

大概想到了解决方法:关掉此mongo的服务,将此实例中的local配置目录移除,再重新启动,再用rs.initiate(cfg)的方法配置为master ,搞掂。原来的数据还在哈哈技术分享

step 1 . 关闭数据库:./bin/mongod --shutdown --dbpath /data/mongo/datacore


step 2 . 删除或移动原来的副本集数据中的local : #mv /data/mongo/datacore /tmp
         这里不删除,怕是有一些重要的配置在里面哈

step 3 . 启动mongo , 重做配置

[[email protected] mongodb]#/usr/local/mongodb/bin/mongod --directoryperdb --rest -replSet msbuset1 --dbpath=/data/mongo/datacore --port 27018 --fork --logpath /data/mongo/logs/datacorefile.log --logappend --maxConns 1600
[[email protected] mongodb]# ./bin/mongo --port 27017
MongoDB shell version: 2.4.9
connecting to: 127.0.0.1:27017/test
>
> show dbs;
eventDev        0.203125GB
local   0.078125GB
message 0.203125GB
ossDev  0.203125GB
p2f     0.203125GB
snsDev  0.203125GB
snsUser 0.203125GB
test    0.203125GB
todo    0.203125GB
> rs.stats()
Thu Mar 31 13:33:21.757 TypeError: Object function () { return "try rs.help()"; } has no method ‘stats‘
> rs.status()
{
        "startupStatus" : 3,
        "info" : "run rs.initiate(...) if not yet done for the set",
        "ok" : 0,
        "errmsg" : "can‘t get local.system.replset config from self or any seed (EMPTYCONFIG)"
}
> cfg={_id:‘msbuset0‘,members:[{_id:0,host:‘${mongo_add_master}:27017‘,priority:10}]}
{
        "_id" : "msbuset0",
        "members" : [
                {
                        "_id" : 0,
                        "host" : "${mongo_add_master}:27017",
                        "priority" : 10
                }
        ]
}
> rs.initiate(cfg)
{
        "ok" : 0,
        "errmsg" : "couldn‘t initiate : can‘t find self in the replset config"
}
> cfg={_id:‘msbuset0‘,members:[{_id:0,host:‘192.168.22.198:27017‘,priority:10}]}
{
        "_id" : "msbuset0",
        "members" : [
                {
                        "_id" : 0,
                        "host" : "192.168.22.198:27017",
                        "priority" : 10
                }
        ]
}
> rs.initiate(cfg)
{
        "info" : "Config now saved locally.  Should come online in about a minute.",
        "ok" : 1
}
>
>
>
>
>
>
>
>
>
> rs.status()
{
        "set" : "msbuset0",
        "date" : ISODate("2016-03-31T05:36:34Z"),
        "myState" : 1,
        "members" : [
                {
                        "_id" : 0,
                        "name" : "192.168.22.198:27017",
                        "health" : 1,
                        "state" : 1,
                        "stateStr" : "PRIMARY",
                        "uptime" : 234,
                        "optime" : Timestamp(1459402537, 5),
                        "optimeDate" : ISODate("2016-03-31T05:35:37Z"),
                        "self" : true
                }
        ],
        "ok" : 1
}
msbuset0:PRIMARY>

技术分享

哈哈,终于成功了。


这也许是一个比较笨的方法,因为现在对mongodb并不熟悉。

如果大家有好的办法,也可以说一下哈


本文出自 “海无涯” 博客,请务必保留此出处http://plong.blog.51cto.com/3217127/1758830

以上是关于记一次手误造成mongo数据库主副集全部变成的副集的处理的主要内容,如果未能解决你的问题,请参考以下文章

图解记一次手撕算法面试:字节跳动的面试官把我四连击了

MysqlMongoDB对比和使用场景

记一次思维转变的时刻

mongo连接数满问题处理

记一次Chocolatey造成的开发环境失误

记一次mongodb启动不了的解决方法