mongodb 副本搭建(一主两备)
admin
2023-04-13 11:41:43
0

mongodb 副本搭建(一主两备)

主:192.168.0.237

备1:192.168.0.122

备2:192.168.0.123

三台机器同样操作

tar zxf mongodb-linux-i686-1.8.1.tgz

mv mongodb-linux-i686-1.8.1 /usr/local/mongodb

cd /usr/local/mongodb/

mkdir etc

mkdir logs

cd logs/

touch mongodb.log

cd ..

cd etc/

vi mongodb.cnf

加入

dbpath=/data/cc

mkdir /data/cc

/usr/local/mongodb/bin/mongod --dbpath=/data/cc --logpath=/usr/local/mongodb/logs/mongodb.log -f /usr/local/mongodb/etc/mongodb.cnf --replSet repset --fork

全部安装并启动成功

在三台机器上任意一台机器登陆mongodb

/usr/local/mongodb/bin/mongo


#使用admin数据库

use admin

#定义副本集配置变量,这里的 _id:”repset” 和上面命令参数“ –replSet repset” 要保持一样。

config = { _id:"repset", members:[

... {_id:0,host:"192.168.0.122:27017"},

... {_id:1,host:"192.168.0.123:27017"},

... {_id:2,host:"192.168.0.237:27017"}]

... }

#输出

{

       "_id" : "repset",

       "members" : [

               {

                       "_id" : 0,

                       "host" : "192.168.0.122:27017"

               },

               {

                       "_id" : 1,

                       "host" : "192.168.0.123:27017"

               },

               {

                       "_id" : 2,

                       "host" : "192.168.0.237:27017"

               }

       ]

}


#初始化副本集配置

rs.initiate(config);

#输出成功


1

{

       "info" : "Config now saved locally.  Should come online in about a minute.",

       "ok" : 1

}


#查看集群节点的状态

rs.status();

#输出


{

       "set" : "repset",

       "date" : ISODate("2014-05-05T10:51:50Z"),

       "myState" : 2,

       "members" : [

               {

                       "_id" : 0,

                       "name" : "192.168.0.122:27017",

                       "health" : 1,

                       "state" : 2,

                       "stateStr" : "SECONDARY",

                       "optime" : {

                               "t" : 1399286403000,

                               "i" : 1

                       },

                       "optimeDate" : ISODate("2014-05-05T10:40:03Z"),

                       "self" : true

               },

               {

                       "_id" : 1,

                       "name" : "192.168.0.123:27017",

                       "health" : 1,

                       "state" : 2,

                       "stateStr" : "SECONDARY",

                       "uptime" : 920,

                       "optime" : {

                               "t" : 1399286403000,

                               "i" : 1

                       },

                       "optimeDate" : ISODate("2014-05-05T10:40:03Z"),

                       "lastHeartbeat" : ISODate("2014-05-05T10:51:48Z")

               },

               {

                       "_id" : 2,

                       "name" : "192.168.0.237:27017",

                       "health" : 1,

                       "state" : 1,

                       "stateStr" : "PRIMARY",

                       "uptime" : 920,

                       "optime" : {

                               "t" : 1399286403000,

                               "i" : 1

                       },

                       "optimeDate" : ISODate("2014-05-05T10:40:03Z"),

                       "lastHeartbeat" : ISODate("2014-05-05T10:51:48Z")

               }

       ],

       "ok" : 1

}

整个副本集已经搭建成功了。


6、测试副本集数据复制功能


#在主节点192.168.0.237 上连接到终端:

mongo 127.0.0.1


#建立test 数据库。

use test;


往testdb表插入数据。

> db.testdb.insert({"test1":"testval1"})


#在副本节点 192.168.0.122、192.168.0.123 上连接到mongodb查看数据是否复制过来。

/usr/local/mongodb/bin/mongo 192.168.0.122:27017


#使用test 数据库。

repset:SECONDARY> use test;


repset:SECONDARY> show tables;

#输出

Sun Dec 29 21:50:48.590 error: { "$err" : "not master and slaveOk=false", "code" : 13435 } at src/mongo/shell/query.js:128

这是正常的,因为SECONDARY是不允许读写的,如果非要解决,方法如下:


repset:SECONDARY> rs.slaveOk();或者

repset:SECONDARY> db.getMongo().setSlaveOk();

可以看到数据已经复制到了副本集。

repset:SECONDARY> db.testdb.find();


#输出

{ "_id" : ObjectId("52c028460c7505626a93944f"), "test1" : "testval1" }




此方法出现故障需手动指定mongodb ip


相关内容

热门资讯

玩家分享攻略“微乐云南麻将有挂... 玩家分享攻略“微乐云南麻将有挂吗?”(其实是有挂)您好,微乐云南麻将这个游戏其实有挂的,确实是有挂的...
我来教教您“创乐缘真的有挂吗?... 我来教教您“创乐缘真的有挂吗?”(必胜开挂神器)您好,创乐缘这个游戏其实有挂的,确实是有挂的,需要了...
【第一消息】“乐禧乾安麻将真的... 有 亲,根据资深记者爆料乐禧乾安麻将是可以开挂的,确实有挂(咨询软件无需...
今日重大通报“成就联盟到底有挂... 有 亲,根据资深记者爆料成就联盟是可以开挂的,确实有挂(咨询软件无需打开...
凤凰晚报|被“斩杀”的美国童星... 今日人物【美国“斩杀线”斩落知名童星?】2025年9月的加州里弗赛德市,一名36岁的流浪男子引起一名...
玩家攻略科普“旺旺冲击麻将真的... 有 亲,根据资深记者爆料旺旺冲击麻将是可以开挂的,确实有挂(咨询软件无需...
网红罗大美遇害两年后下葬,妹妹... 据九派新闻,12月28日,罗大美妹妹发文:近日在亲属的陪伴下,哥哥的后事已经妥善完成。在一个小小的仪...
最新引进“数独大赛开挂神器?”... 家人们!今天小编来为大家解答数独大赛透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里买很...
【第一消息】“夜猫麻将是不是有... 网上科普关于“夜猫麻将有没有挂”话题很是火热,小编也是针对夜猫麻将作*弊开挂的方法以及开挂对应的知识...
【第一资讯】“微乐海南麻将辅助... 【第一资讯】“微乐海南麻将辅助器?”(其实是有挂)您好,微乐海南麻将这个游戏其实有挂的,确实是有挂的...