docker安装mongo

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"
}
]
}

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是主节点

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"
}
]
}

删除用户

db.dropUser("user_name")

故障案例

无法查看数据库

Error: listDatabases failed:{ "note" : "from execCommand", "ok" : 0, "errmsg" : "not master" }

处理方法:

rs.slaveOk()
show dbs

指定某一结点为主节点

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)

将会发生下面这些事件:

  • m3.example.netm2.example.netm1.example.net 复制数据 (一般在10秒内)。

  • m1.example.net 发现自己不是最高优先级的节点了,一般会辞职降级。当m3.example.net 的数据比其落后很多的时候,m1.example.net不会 降级。本次测试中,m1.example.net 会等到 m3.example.net 的optime 落后其小于10秒时降职。这是在没有主节点发生故障的时候最小的时间需求。

  • 由于m3.example.netpriority 设定,会降职选举 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.netm3.example.net 追赶的时候重新成为主节点,可以使用如下命令:

rs.freeze()

通过数据库命令强制某个节点成为主节点

在 1.8 版更改.

假设我们 replica set 中有如下成员:

  • mdb0.example.net - 现在的 primary

  • mdb1.example.net - 一个 secondary

  • mdb2.example.net - 一个 secondary 。

通过如下流程来强制某个节点成为主节点:

  1. mongo 窗口中,执行 rs.status() 来确定我们的复制集状态。

rs.status()

  1. 连接到 mdb2.example.net ,并在 mongo 窗口中 ,将 mdb2.example.net 冻结,使其无法在120秒内成为主节点。

rs.freeze(120)

  1. 连接到 mdb0.example.net ,并在 mongo 窗口中使其降职,并无法在120秒内成为主节点:

rs.stepDown(120)

`mdb1.example.net` 成为主节点。
注解:   在转变过程中,可能会有极短暂的时间会出现没有主节点的情况出现

你可能感兴趣的:(docker安装mongo)