1、初始环境部署(node1&&node2):
export node1=192.168.170.149
export node2=192.168.170.150
openssl rand -base64 741 > mongodb-keyfile #在node1上面生成文件,并将文件传输到所有节点,且更改如下权限
chmod 600 mongodb-keyfile
chown 999 mongodb-keyfile #999可以是你喜欢的名字
2、mongo设置用户密码:node1
先启动容器
docker run --name mongo -v /home/core/mongo-files/data:/data/db -v /home/core/mongo-files:/opt/keyfile --hostname="node2.example.com" -p 27017:27017 -d mongo --smallfiles
再进入mongo容器添加账户密码
use admin
switched to db admin
db.createUser({user:"admin",pwd:"admin",roles:[{role:"userAdminAnyDatabase",db:"admin"}]});
Successfully added user: {
"user" : "admin",
"roles" : [
{
"role" : "userAdminAnyDatabase",
"db" : "admin"
}
]
}
db.createUser({user:"root",pwd:"123",roles:[{role:"root",db:"admin"}]});
Successfully added user: {
"user" : "root",
"roles" : [
{
"role" : "root",
"db" : "admin"
}
]
}</pre>
3、停止并删除容器:node1
docker stop mongo
docker rm mongo
4、再次创建容器,并加载密钥文件: node1
docker run --name mongo -v /home/core/mongo-files/data/:/data/db -v /home/core:/opt/keyfile --hostname="node1.example.com" --add-host node1.example.com:{node2} -p 27017:27017 -d mongo --smallfiles --keyFile /opt/keyfile/mongodb-keyfile --replSet "rs0"
--hostname 设置容器主机名
--add-host 添加hosts解析
--replSet 副本集名称,自定义
5、配置mongo开启副本集:node1
docker exec -it mongo bash #进入mongo容器
mongo #在任意目录下键入mongo
use admin #切换到admin数据库
db.auth('root','123') #身份验证,如果成功会显示个1
rs.initiate() #开启副本集
rs.conf() #验证配置
6、启动node2上的容器
docker run --name mongo -v /data1/db:/data/db -v /server/mongo:/opt/keyfile --hostname="node2.example.com" --add-host node1.example.com:{node2} -p 27017:27017 -d mongo --smallfiles --keyFile /opt/keyfile/mongodb-keyfile --replSet "rs0"
7、把node2加入副本集,在node1上执行
rs.add("node2.example.com") #官方文档提示,最好不要用ip
rs.status() #可以看到 id:0 和 id:1 就代表成功了
rs.isMaster() #可以看到node1是主节点</pre>
mongo常用命令
查看所有用户信息
db.system.users.find().pretty()
创建一个root用户
db.createUser({user:"root",pwd:"123456",roles:["root"]})
或者指定数据库创建:
db.createUser( {
user: "siteRootAdmin",
pwd: "password",
roles: [ { role: "root", db: "admin" } ]
});
成功会有如下信息:
Successfully added user: {
"user" : "siteRootAdmin",
"roles" : [
{
"role" : "root",
"db" : "admin"
}
]
}</pre>
删除用户
db.dropUser("user_name")</pre>
故障案例
无法查看数据库
Error: listDatabases failed:{ "note" : "from execCommand", "ok" : 0, "errmsg" : "not master" }
处理方法:
rs.slaveOk()
show dbs</pre>
指定某一结点为主节点
1、比如说有三个节点,id 分别为0,1,2
在 mongo
窗口中,使用如下的命令来让 m3.example.net
成为主节点。
cfg = rs.conf()
cfg.members[0].priority = 0.5
cfg.members[1].priority = 0.5
cfg.members[2].priority = 1
rs.reconfig(cfg)</pre>
将会发生下面这些事件:
m3.example.net
和m2.example.net
从m1.example.net
复制数据 (一般在10秒内)。m1.example.net
发现自己不是最高优先级的节点了,一般会辞职降级。当m3.example.net
的数据比其落后很多的时候,m1.example.net
将 不会 降级。本次测试中,m1.example.net
会等到m3.example.net
的optime 落后其小于10秒时降职。这是在没有主节点发生故障的时候最小的时间需求。由于
m3.example.net
的priority
设定,会降职选举m3.example.net
为新的主节点
2、如果 m3.example.net
落后于 m1.example.net
超过10秒,或者我们10秒内都不需要新的主节点,我们可以通过如下操作让 m1.example.net
辞职:
db.adminCommand({replSetStepDown: 86400, force: 1})
这将防止 m1.example.net
在86400秒(24小时)内成为主节点,即使没有其他节点成为主节点。当 m3.example.net
追上 m1.example.net
的时候,其将成为主节点。
如果我们希望让 m1.example.net
在 m3.example.net
追赶的时候重新成为主节点,可以使用如下命令:
rs.freeze()
通过数据库命令强制某个节点成为主节点
在 1.8 版更改.
假设我们 replica set 中有如下成员:
mdb0.example.net
- 现在的 primary 。mdb1.example.net
- 一个 secondary 。mdb2.example.net
- 一个 secondary 。
通过如下流程来强制某个节点成为主节点:
- 在
mongo
窗口中,执行rs.status()
来确定我们的复制集状态。
rs.status()
- 连接到
mdb2.example.net
,并在mongo
窗口中 ,将mdb2.example.net
冻结,使其无法在120秒内成为主节点。
rs.freeze(120)
- 连接到
mdb0.example.net
,并在mongo
窗口中使其降职,并无法在120秒内成为主节点:
rs.stepDown(120)
`mdb1.example.net` 成为主节点。
注解: 在转变过程中,可能会有极短暂的时间会出现没有主节点的情况出现