返回顶部
首页 > 资讯 > 数据库 >MongoDB如何查oplog.rs集合里的操作日志
  • 549
分享到

MongoDB如何查oplog.rs集合里的操作日志

2024-04-02 19:04:59 549人浏览 八月长安
摘要

首先需要介绍一下mongoDB local库的作用 local库是MonGoDB的系统库,记录着时间戳和索引和复制集等信息 test:PRIMARY> use local switched to

首先需要介绍一下mongoDB local库的作用
local库是MonGoDB的系统库,记录着时间戳和索引和复制集等信息


test:PRIMARY> use local
switched to db local


test:PRIMARY> show tables;
system.replset
me
startup_log
replset.minvalid
oplog.rs
replset.election
test:PRIMARY>


local库下的每个集合分别记录的内容


local库下面的me集合保存了服务器名称


local库下面的replset.minvalid集合保存了数据库最新操作的时间戳


local库下面的startup_log集合记录这mongod每一次的启动信息


local库下面的system.indexes集合记录当前库的所有索引信息


local库下面的system.replset记录着复制集的成员配置信息rs.conf()读取这个集合


local库下面的oplog.rs集合记录着所有操作,MongoDB就是通过oplog.rs来实现数据同步的。当Primary节点插入一条数据后,oplog.rs集合中就会多一条记录




op:操作类型,插入对应i;更新对应u;删除对应d;但有一种情况是n,它表示无操作(no-op),紧紧代表一个消息信息。
例如:
查询oplog里的insert记录,对应op为i的记录:
test:PRIMARY> db.oplog.rs.find({"op" : "i"}).pretty().limit(3)


查update操作命令:
test:PRIMARY> db.oplog.rs.find({"op" : "u"}).pretty().limit(3)
test:PRIMARY>
查delete操作命令:
test:PRIMARY> db.oplog.rs.find({"op" : "d"}).pretty().limit(3)




根据时间范围查操作:
例如:
查找2017年9月1日之后的操作记录:
test:PRIMARY> db.oplog.rs.find({"o.createTime": {$gte:new Date(2017,9,1)}}).limit(3)




查2017年9月1日到10月31日之间的操作记录:
test:PRIMARY> db.oplog.rs.find({"o.createTime": {$gte:new Date(2017,9,1),$lte:new Date(2017,10,31)}}).limit(3)


我们查查对chenfeng表进行操作的所有的 oplog 记录
test:PRIMARY> db.oplog.rs.find({ns : "testdb.chenfeng"})


查操作的时间戳:
 db.oplog.rs.find({"op" : "i","ns" : "testdb.chenfeng",},{ts:1}).pretty()
{ "ts" : Timestamp(1509246747, 1) }
{ "ts" : Timestamp(1509246747, 2) }
{ "ts" : Timestamp(1509246747, 3) }
{ "ts" : Timestamp(1509246747, 4) }
{ "ts" : Timestamp(1509246747, 5) }




当前操作时间点的时间戳:
test:PRIMARY> rs.status().members[0].optime.ts
Timestamp(1509247609, 3001)




如何备份oplog集合:
[root@192 new]# mongodump --host localhost --port 9336 -uadmin -padmin  --authenticationDatabase=admin  -d local -c oplog.rs -o /root/new
2017-10-29T12:36:45.605+0800    writing local.oplog.rs to local/oplog.rs.bson
2017-10-29T12:36:48.606+0800    [#.......................]  local.oplog.rs  398917/4937240  (8.1%)
2017-10-29T12:36:51.610+0800    [###.....................]  local.oplog.rs  812569/4937240  (16.5%)
2017-10-29T12:36:54.611+0800    [#####...................]  local.oplog.rs  1208741/4937240  (24.5%)
2017-10-29T12:36:57.607+0800    [#######.................]  local.oplog.rs  1570342/4937240  (31.8%)
2017-10-29T12:37:00.617+0800    [#########...............]  local.oplog.rs  1948323/4937240  (39.5%)
2017-10-29T12:37:03.606+0800    [###########.............]  local.oplog.rs  2346269/4937240  (47.5%)
2017-10-29T12:37:06.606+0800    [#############...........]  local.oplog.rs  2741569/4937240  (55.5%)
2017-10-29T12:37:09.609+0800    [###############.........]  local.oplog.rs  3137392/4937240  (63.5%)
2017-10-29T12:37:12.606+0800    [#################.......]  local.oplog.rs  3533685/4937240  (71.6%)
2017-10-29T12:37:15.610+0800    [##################......]  local.oplog.rs  3897290/4937240  (78.9%)
2017-10-29T12:37:19.672+0800    [###################.....]  local.oplog.rs  3947430/4937240  (80.0%)
2017-10-29T12:37:21.609+0800    [####################....]  local.oplog.rs  4147978/4937240  (84.0%)
2017-10-29T12:37:24.607+0800    [#####################...]  local.oplog.rs  4518546/4937240  (91.5%)
2017-10-29T12:37:27.606+0800    [#######################.]  local.oplog.rs  4910376/4937240  (99.5%)
2017-10-29T12:37:27.758+0800    writing local.oplog.rs metadata to local/oplog.rs.metadata.JSON
2017-10-29T12:37:27.770+0800    done dumping local.oplog.rs (4937240 documents)


用bsondump查操作记录:
查插入操作:
# bsondump oplog.rs.bson | grep "\"op\":\"i\"" | head




查删除操作:
# bsondump oplog.rs.bson | grep "\"op\":\"d\"" | head


查更新操作:
[root@192 local]# bsondump oplog.rs.bson | grep "\"op\":\"u\"" | head




恢复oplog集合命令:
mongorestore --host localhost --port 9336 -uadmin -padmin  --authenticationDatabase=admin  -d local -c oplog.rs /root/new/local/oplog.rs.bson
您可能感兴趣的文档:

--结束END--

本文标题: MongoDB如何查oplog.rs集合里的操作日志

本文链接: https://lsjlt.com/news/47056.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MongoDB如何查oplog.rs集合里的操作日志
    首先需要介绍一下mongodb local库的作用 local库是MongoDB的系统库,记录着时间戳和索引和复制集等信息 test:PRIMARY> use local switched to ...
    99+
    2024-04-02
  • MongoDB日志是如何工作的
    MongoDB日志是如何工作的,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Good idea, Patrick!那么, Mo...
    99+
    2024-04-02
  • MYSQL如何查看操作日志详解
    目录前言一、文件记录数据库操作日志二、数据库表记录操作日志附:按时间段查看mysql的操作日志总结前言 mysql操作日志分为文件记录日志和数据库记录日志两种方式,最终效果一样 一、...
    99+
    2024-04-02
  • 如何查看阿里云服务器的操作日志文件
    1. 登录到阿里云控制台 首先,打开浏览器并登录到阿里云控制台。输入您的用户名和密码,然后点击登录。 2. 进入云服务器管理页面 在阿里云控制台的首页,点击左侧导航栏中的 "云服务器 ECS",然后选择您要查看操作日志的服务器实例。 3....
    99+
    2023-10-27
    阿里 操作 服务器
  • mongodb如何查询所有集合
    在MongoDB中,可以使用以下命令查询所有的集合: 使用show collections命令可以列出当前数据库中所有的集合,例如...
    99+
    2024-04-10
    mongodb
  • 如何查看redis集群日志
    要查看Redis集群的日志,可以按照以下步骤进行操作:1. 打开Redis集群的配置文件redis.conf(或者使用其他自定义的配...
    99+
    2023-08-23
    redis
  • MongoDB中如何实现创建、删除集合操作
    这篇文章给大家分享的是有关MongoDB中如何实现创建、删除集合操作的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。创建集合语法格式db.createCollection(name...
    99+
    2024-04-02
  • python如何操作集合
    这篇文章给大家分享的是有关python如何操作集合的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。操作集合>>> A = {1,&n...
    99+
    2024-04-02
  • 如何使用Journalctl查看并操作Systemd日志
    作为最具吸引力的优势,systemd拥有强大的处理与系统日志记录功能。在使用其它工具时,日志往往被分散在整套系统当中,由不同的守护进程及进程负责处理,这意味着我们很难跨越多种应用程序对其内容进行解读。相比之下,systemd尝试提供一套集中...
    99+
    2023-06-05
  • MySQL操作日志查看的实际操作步骤
    本篇内容介绍了“MySQL操作日志查看的实际操作步骤”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  对m...
    99+
    2024-04-02
  • Python集合如何实现增删改查操作
    这篇文章主要介绍Python集合如何实现增删改查操作,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1.集合新增集合元素set1 = {'name', 19, &...
    99+
    2023-06-29
  • 阿里云服务器操作日志怎么查看的
    要查看阿里云服务器操作日志,您可以按照以下步骤操作: 登录云服务器管理平台。在平台的首页,点击“系统管理”按钮并进入系统管理界面。 在系统管理界面中,找到“操作日志”选项卡。在操作日志中,您可以查看服务器的操作日志。 在操作日志中,您可...
    99+
    2023-10-27
    阿里 操作 服务器
  • Python集合的增删改查操作
    目录1.集合新增集合元素2.删除可变集合元素3.修改可变集合4.集合元素查询方法前言: 集合分为可变集合和不可变集合两种,所以对其的增删改查操作要看集合的类型来决定。不可变的数据当然...
    99+
    2024-04-02
  • 阿里云服务器操作日志怎么查看
    要查看阿里云服务器操作日志,您可以按照以下步骤操作: 打开客户端应用程序并登录。在客户端应用程序上点击“服务日志”按钮以打开日志记录。 进入日志记录页面后,您可以选择要查看的具体日志内容,如操作时间、访问IP、操作系统信息等。 如果选择...
    99+
    2023-10-26
    阿里 操作 服务器
  • 阿里云服务器操作日志在哪查看
    阿里云服务器操作日志通常会以日志文件的形式保存在服务器上,您可以通过以下方法在阿里云官网上查看操作日志: 使用阿里云官方提供的日志管理工具,如:Apache Commons、Apache Live Logs等; 使用阿里云托管服务提供商...
    99+
    2023-10-27
    阿里 操作 服务器
  • MySQL 5.5 NDB集群如何查看日志
    这篇文章主要介绍了MySQL 5.5 NDB集群如何查看日志,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 在管理节点查看日志~> ...
    99+
    2024-04-02
  • 阿里云服务器操作日志怎么查看的啊
    一、查看阿里云服务器操作日志的步骤 登录阿里云控制台(Logs.aliyun.com),进入服务器配置页面。 在左侧导航栏中选择“操作日志”选项。 在弹出的“操作日志”页面中,您可以查看所有记录的操作系统、应用程序、网络等各种信息。 点...
    99+
    2023-10-28
    阿里 操作 服务器
  • python如何操作多重集合
    这篇文章给大家分享的是有关python如何操作多重集合的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 操作多重集合>>> A =&...
    99+
    2024-04-02
  • 阿里云服务器操作日志在哪查看啊
    首先打开阿里云控制台应用程序。 进入服务器的配置页面,可以看到当前服务器的状态、配置信息等信息。 在服务器配置页面中,可以看到所有与操作系统相关的信息,例如操作系统版本、操作系统的名称、操作系统的版本等。 在服务器配置页面中,可以看到服务...
    99+
    2023-10-27
    阿里 看啊 操作
  • MongoDB常用的操作(服务器、数据库、集合)
    MongoDB常用的操作 前面两篇已经介绍了MongoDB系统架构及其BSON数据类型。本文将讲解基本的MongoDB操作。 一、MongoDB启动命令 启动MongoDB systemctl st...
    99+
    2023-09-08
    mongodb 数据库 sql
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作