草庐IT

mongodb - Mongodb 部分备份

coder 2023-10-31 原文

我们在开发服务器上设置了 5 节点复制。我们正在寻找一种方法,允许开发人员在 mongo 数据库中备份数据子集并将其恢复到他们的本地开发环境。

我们研究了 clonedb 和 mongodump 实用程序,但两者都只允许备份/转储完整的数据库。由于数据库的可能大小,我们需要一个允许我们限制正在备份或恢复的数据的选项。

是否知道实现此目的的实用程序或方法?

最佳答案

我刚刚再次偶然发现这个问题,并决定添加我们选择的备份策略的描述:

我们的 mongo 数据库的当前备份策略此服务器包含 2 个设置;通过延迟的被动辅助节点进行备份,并使用 mongodump 进行每日备份(使用日志记录和操作日志)。

除了我们正常的生产节点之外,我们还设置了另一个优先级为 0 的辅助节点(这可以在它自己的服务器上,也可以从另一个 mongo 服务器中获取,但使用单独的端口),隐藏为 true 并且延迟为7200 秒(2 小时)。这个奴隶是为了“黄油手指”,当有人不小心删除数据库或清除集合时,我们有 2 小时的时间将这些更改复制到这个被动辅助。被动次级不能用于阅读或写作。它的作用只是一个备份节点。我们还使用此节点进行夜间备份,以防止任何其他节点产生不必要的开销。

夜间备份设置为每晚 23:00 通过 cron 选项卡运行。该命令只是在 /opt/auto-mongo-backup 中执行脚本设置。此脚本可在 https://github.com/jaconel/automongobackup 找到(最初在 https://github.com/micahwedemeyer/automongobackup 找到它)。此脚本允许单个夜间 cron 涵盖每周备份和每月备份。备份保存在 /var/backups/mongodb

希望这对某些人有所帮助。

关于mongodb - Mongodb 部分备份,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9463076/

有关mongodb - Mongodb 部分备份的更多相关文章

  1. ruby - 如何使用部分字符串搜索数组并返回索引? - 2

    我想使用部分字符串搜索数组,然后获取找到该字符串的索引。例如:a=["Thisisline1","Wehaveline2here","andfinallyline3","potato"]a.index("potato")#thisreturns3a.index("Wehave")#thisreturnsnil使用a.grep将返回完整的字符串,使用a.any?将返回正确的true/false语句,但都不会返回匹配的索引找到了,或者至少我不知道该怎么做。我正在编写一段代码,该代码读取文件、查找特定header,然后返回该header的索引,以便它可以将其用作future搜索的偏移量。如果

  2. ruby-on-rails - 如何将数据传递给部分? - 2

    K伙计们,所以我创建了这个赞成/反对的投票脚本(基本上就像stackoverflow上的那个),我试图向其中添加一些Ajax,这样页面就不会在您每次投票时都重新加载。我有两个Controller,一个叫grinder,一个叫votes。(磨床基本都是帖子)所以这是所有研磨机的索引(看起来像这样)这是该页面的代码。Listinggrinders"grinders/grinders")%>这就是我在views/grinders/_grinders.erb中的内容true)do|u|%>grinder.id%>"up"%>'create')%>true)do|d|%>grinder.id%>

  3. ruby-on-rails - 将 restclient 与多部分帖子一起使用 - 2

    我将restclient用于多部分表单,以将数据发送到restfulweb服务(它是Panda视频编码服务)。不过,诀窍在于我传递给restclient(Technoweenie分支)的文件来自用户提交的我自己的表单。那么,让我们来看看这个。用户将文件发布到我的Rails应用程序。在我的Controller中,它从params[:file]接收文件。然后我想使用RestClient将params[:file]传递给Panda。我在Panda服务器上遇到的错误如下。我注意到堆栈跟踪中的文件参数也在一个字符串中(我假设Panda将其转换为字符串以获得更好的堆栈跟踪)。~Startedreq

  4. ruby-on-rails - 独立测试 Rails 部分 View - 2

    我在标准rails2.1项目中使用Test/Unit。我希望能够独立于任何特定的Controller/操作来测试分部View。好像ZenTest'sTest::Rails::ViewTestCase会有所帮助,但我无法让它工作,与view_testhttp://www.continuousthinking.com/tags/view_test类似Google出现的大部分内容似乎都已经过时了,所以我猜它并不真正适用于Rails2.1非常感谢任何帮助。谢谢,罗兰 最佳答案 我们正在使用RSpec在我们的Rails2.1项目中,我们可以做

  5. ruby - 如何在 ruby​​ 中实现 curry(部分函数) - 2

    我需要一些在ruby​​(1.8.6或1.8.7而不是1.9)中实现curry函数的示例。 最佳答案 下面是如何用block而不是方法来柯里化(Currying):defcurry(&block)arity=(block.arity>=0)?block.arity:-(block.arity+1)#returnanimmediatevalueiftheblockhasonereturnblock[]ifarity==0#otherwise,curryitargumentbyargumentargs=[]innermost=lambd

  6. ruby-on-rails - Rails 4 通过渲染部分传递多个变量 - 2

    这个问题已经被问过很多次了,但我无法让它工作。我想像这样将多个变量传递给我的部分...这是部分material_fields.html.erb中的一行,我希望f.select预先填充Yes选项或“true”值。(有些情况下我希望它是假的)f可用并且有效,而feed不可用......我不知道为什么这不起作用。我在select语句之外尝试了,但它仍然不起作用。在这两种情况下,我都得到未定义的局部变量或方法“feed”。有人知道我的语法有什么问题吗? 最佳答案 我想通了是什么问题。我有后来我在同一个View中显然,当从一个文件渲染相同的部

  7. ruby-on-rails - 是否可以在部分中只放置一个 rails 表单元素? - 2

    我的应用有一个选择框供用户选择“地点”。如您所料,此选择框位于一个表单中。我还在页面上的某处执行了一个操作,该操作通过AJAX创建了一个新场所。创建新field后,我想更新field选择框以反射(reflect)这一点。我的解决方案是将选择框放在局部中,并从Controller中的创建操作中呈现局部。'venue/venue_select_box'%>局部看起来像这样:'Selectavenue'%>其中f是表单引用:问题是f在部分中未定义,所以我得到一个错误。一种解决方案是包括整个表格,但我觉得没有必要这样做,因为我没有更新整个表格。关于如何解决这个问题有什么想法吗?

  8. ruby-on-rails - 在这部分代码中设置 klass = self 的动机是什么 - 2

    我正在查看讨论中的一些代码并偶然发现了这个并且想知道为什么klass=self.据我所知,他们是比我更好的ruby​​开发人员,这一定是有充分理由的。他们为什么不调用self.remove_from_cache!(message["key"],false)?该block是否正在创建一个新范围,其中self引用MessageBus类?是否有其他示例说明您需要在Ruby中创建此类构造,或者这是主要示例?如果MessageBus.subscribe是MessageBus的一个实例(比如说m_bus.subscribe)会自己引用block中的m_bus吗?ensure_class_liste

  9. ruby-on-rails - 缓存特定的部分 rails 3.0.x - 2

    我有一个主页,整个页面都呈现了一些部分。它也有sessionheader(登录)。部分包含已分页的书籍集。现在我想缓存这个部分,因为它每周更新一次。问题1:如何缓存特定的部分(不命中分贝)?问题2:更新时如何删除(过期)缓存内容那个书本模型? 最佳答案 您正在寻找fragmentcaching这里,发生在View层。片段缓存和存储内容的过期非常容易做到。您有一个图书list,假设您的View看起来有点像这样:要为这一位启用缓存,只需将其包装在cache中:当然,这不会为缓存命名或对它做任何特别的事情...虽然Rails会自动为这个缓

  10. ruby-on-rails - Ruby On Rails - 重用错误消息部分 View - 2

    问题我试图在我的View中重用错误消息block。下面是positions/_error_messages.html.erb中写的blockTheformcontains.*问题是我必须在每个模型中创建类似的部分View,这有点像用不同的对象重复相同的代码,即@user、@client等。补救措施我在共享文件夹shared/_error_messages.html.erb中创建了一个erb并编写了以下代码。Theformcontains.*然后在查看文件中。positions/new.html.erb我写了下面的代码这意味着现在我可以在所有创建和更新操作中使用相同的代码。我想知道,这样

随机推荐