mongodb中运维的示例分析

73次阅读
没有评论

共计 1982 个字符,预计需要花费 5 分钟才能阅读完成。

这篇文章主要介绍了 mongodb 中运维的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让丸趣 TV 小编带着大家一起了解一下。

我们以管理员的视角来看 mongodb,作为一名管理员,我们经常接触到的主要有 4 个方面:

1.  安装部署

2.  状态监控

3.  安全认证

4.  备份和恢复,

下面我们就一点一点的讲解。

一:安装部署

        我之前的文章都是采用 console 程序来承载,不过在生产环境中这并不是最佳实践,谁也不愿意在机器重启后满地找牙似找 mongodb,在 mongodb 里面提供了一个叫做“服务寄宿”的模式,我想如果大家对 wcf 比较熟悉的话很容易听懂。好了,我们实践一下,这里我开一下 D 盘里面的 mongodb。

这里要注意的有两点:

    1 logpath: 当我们使用服务寄宿的时候,用眼睛都能想明白肯定不会用 console 来承载日志信息了。

    2 install:   开启安装服务寄宿,很 happy 啊,把管理员的手工操作降低到最小,感谢 mongodb。

好了,console 程序叫我看 log 日志,那我就看看,发现 mongodb 已经提示我们如何开启 mongodb,接着我照做就是了。 

还要提醒大家一点的就是,这些命令参数很多很复杂也就很容易忘,不过没关系,数据库给我们提供了一个 help 方法,我们可以拿 mongod 和 mongo 说事。

mongod:

mongo:

二:状态监控

      监控可以让我们实时的了解数据库的健康状况以及性能调优,在 mongodb 里面给我们提供了三种方式。

1:http 监视器

      这个我在先前的文章中也提到了,这里就不赘述了。

2:serverStatus()

    这个函数可以获取到 mongodb 的服务器统计信息,其中包括:全局锁,索引,用户操作行为等等这些统计信息,对管理员来说非常重要。

    这里还是截个图混个眼熟。

3:mongostat

      前面那些统计信息再牛 X,那也是静态统计,不能让我观看实时数据变化,还好,mongodb 里面提供了这里要说的 mongodstat 监视器,这玩意会每秒刷新,在实际生产环境中大有用处,还是截张图,很有意思,是不是感觉大军压境了。

三:  安全认证

      作为数据库软件,我们肯定不想谁都可以访问,为了确保数据的安全,mongodb 也会像其他的数据库软件一样可以采用用户验证的方法,那么该怎么做呢?其实很简单,mongodb 提供了 addUser 方法,还有一个注意点就是如果在 admin 数据库中添加将会被视为“超级管理员”。

上面的 admin 用户将会被视为超级管理员,“jack”用户追加的第三个参数表示是否是“只读用户”,好了,该添加的我们都添加了,我们第一次登录时不是采用验证模式,现在我们使用 –reinstall 重启服务并以 –auth 验证模式登录。

好了,我们进入 test 集合翻翻数据看看情况,我们发现 jack 用户始终都是没有写入的权限,不管是授权或者未授权。

四:备份和恢复

      这玩意的重要性我想都不需要我来说了吧,这玩意要是搞不好会死人的,mongodb 里面常用的手段有 3 种。

1:直接 copy

        这个算是最简单的了,不过要注意一点,在服务器运行的情况下直接 copy 是很有风险的,可能 copy 出来时,数据已经遭到

        破坏,唯一能保证的就是要暂时关闭下服务器,copy 完后重开。

2:mongodump 和 mongorestore

      这个是 mongo 给我们提供的内置工具,很好用,能保证在不关闭服务器的情况下 copy 数据。

为了操作方便,我们先删除授权用户。

好了,我们转入正题,这里我先在 D 盘建立一个 backup 文件夹用于存放 test 数据库。

mongodb 中运维的示例分析

快看,数据已经备份过来了,太爽了,现在我们用 mongorestore 恢复过去,记住啊,它是不用关闭机器的。

提一点的就是 drop 选项,这里是说我将 test 数据恢复之前先删除原有数据库里面的数据,同样大家可以通过 help 查看。

mongodb 中运维的示例分析

3:主从复制

    其实上面的 1,2 两点都不能保证获取数据的实时性,因为我们在备份的时候可能还有数据灌在内存中不出来,那么我们想说能不能把数据暴力的刷到硬盘上,当然是可以的,mongodb 给我们提供了 fsync+lock 机制就能满足我们提的需求。

fsync+lock 首先会把缓冲区数据暴力刷入硬盘,然后给数据库一个写入锁,其他实例的写入操作全部被阻塞,直到 fsync+lock 释放锁为止。

这里就不测试了。

  加锁: db.runCommand({fsync :1, lock :1})
  释放锁:db.$cmd.unlock.findOne()

感谢你能够认真阅读完这篇文章,希望丸趣 TV 小编分享的“mongodb 中运维的示例分析”这篇文章对大家有帮助,同时也希望大家多多支持丸趣 TV,关注丸趣 TV 行业资讯频道,更多相关知识等着你来学习!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-08-03发表,共计1982字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)