温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

mongodb副本集维护

发布时间:2020-07-22 12:58:14 来源:网络 阅读:948 作者:jalyzjs 栏目:MongoDB数据库

一、概述

mongodb副本集维护主要工作:

1、查看副本集状态(集群状态、同步延迟、单个库的运行状态mongostate)

2、增删节点、停节点shutdown


mongodb副本集集群同步机制

  1. 数据复制的目的是使数据得到最大的可用性,冗余,避免单点故障。

  2. 副本集中同一时刻只有一台服务器是可以写的,primary主库上写,从库同步数据

  3. 副本集主从复制也是异步同步的过程。slave从primary上获取日志,然后在自己身上完全顺序的执行日志记录的操作(该日志不记录查询操作,只记录更新操作)。被同步的日志就是local库中的oplog.rs表,这个表占空间比较大,磁盘大小5%。启动参数设置oplog.rs的大小:--oplogSize 1000,单位M。生产环境中建议设置大一些,防止无法同步情况发生。


二、查看集群状态

1.rs.status()

mongodb副本集维护

2.db.printSlaveReplicationInfo()

查看主从数据库延迟时间

mongodb副本集维护


3.mongodb监控工具- mongostat

mongodb副本集维护

3.1 如果发现DB突然变慢或者有其他问题,首先mongostat查看状态

mongostat -uxx -pyy -rowcount 12 300
mongostat -uxx -pyy -N 12 300
    ##每300秒输出一次DB状态,共输出12次


3.2 输出参数说明

inserts/s    每秒插入次数

query/s      每秒查询次数

update/s     每秒更新次数

delete/s     每秒删除次数

getmore/s    每秒执行getmore次数,查询时游标(cursor)的getmore操作,用处不大

command/s    每秒命令数,比以上插入、查找、更新、删除的综合还多,还包含了别的命令。比如批量插入,只认为一条命令,意义不大。

flushes/s    每秒执行fsync,将数据写入磁盘的次数。一般都是0,刷如磁盘时是1,可以通过两个1之间的间隔时间,判断多久刷新一次数据到磁盘。flush开销很大,如股票频繁刷新,可能有问题。

mapped/s     所有的被nmap的数据量,单位是MB

vsize        虚拟内存使用量,单位MB

res          物理内存使用量,单位MB。这个和top看到的状态一样,mapped/vsize一般不会有大变动,res会慢慢上升,如果res经常突然下降,查查是不是有别的程序狂吃内存。

faults/s     每秒访问失败数(只有linux有),数据被交换出物理内存,放入swap,如果经常不为0,就是服务器内存太小,造成频繁swap写入,此时要加大内存。

locked db %   被锁的时间百分比,尽量控制在50%以下。这个值过大(经常超过10%,可能出问题)

idx miss %    非常重要的参数,索引不命中所占百分比。正常情况下,查询都应该通过索引,也就是idx miss为0,如果太高的话就是索引太少了

qr|qw        queue lengths for clients waiting (read|write)客户端过来的读写请求的长度。

ar|aw        active clients(read|write)活跃的客户端过来的读写请求。即总共的读写请求。

             PS:当mongdb接收太多命令,而数据库被锁住无法执行完成,就会将命令加入到队列。都为0,表示mongodb毫无压力,高并发时,队列值会升高,表示DB的处理速度不及请求速度。看下是否有开销很大的慢查询。如果查询一切正常,确实负载很大,则考虑加服务器了。

net In/Out   网络带宽压力,一般网络不会成为mongdb瓶颈。

conn         当前连接数

set          副本集集群名称

repl         当前库在集群中的状态。PRI-master,SEC-second,REC-recovering,UNK-unkown

time         时间戳


 

4.web控制台

mongodb自带web控制台,默认和数据服务一起开启。默认端口28017(数据端口27017基础上+1000)

mongodb副本集维护

状态页显示信息:

4.1 当前db的所有连接

4.2 各个数据库dbs和collection的访问统计,包括reads/writes/queries/getmores/inserts/updates/removes

4.3 写锁的状态

4.4 日志文件的最后几百行

4.5 最上面两行,mongodb状态查询的其他命令



5.获取mongodb当前正在执行的操作db.currentOp()

>db.currentOp()
>{ "opid" : "shard3:466404288", "active" : false, "waitingForLock" : false, "op" : "query", "ns" : "sd.usersEmails", "query" : { }, "client_s" : "10.121.13.8:34473", "desc" : "conn" }

5.1 杀死执行时间过长的命令

>db.killOp("shard3:466404288")


6.MongoDB监控服务MongoDB Monitoring Service(MMS)

mongodb厂商提供的监控服务,可在网页和Andriod客户端查看

mongodb副本集维护






向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI