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"
}
]
}</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:{node1} --add-host node2.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:{node1} --add-host node2.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.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` 成为主节点。
注解:   在转变过程中,可能会有极短暂的时间会出现没有主节点的情况出现
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容