將 雲資料庫MongoDB(阿裡雲)物理備份文件下載恢復至本地自建資料庫 遇到的5個問題

来源:https://www.cnblogs.com/xuliuzai/archive/2019/08/08/11322152.html
-Advertisement-
Play Games

有時候我們可能需要將雲上資料庫下載到本地,下麵是我們在操作MongoDB資料庫時遇到的五個小問題。 其實現在RDS的 幫助文檔 寫的都比較詳細了,大家在第一次操作時,可以細讀一下,避免一些不必要的問題。 Problem 1 通過wget命令下載 雲MongoDB物理備份文件 時,url 中間有特殊字 ...


有時候我們可能需要將雲上資料庫下載到本地,下麵是我們在操作MongoDB資料庫時遇到的五個小問題。

其實現在RDS的 幫助文檔 寫的都比較詳細了,大家在第一次操作時,可以細讀一下,避免一些不必要的問題。

 

Problem 1

通過wget命令下載 雲MongoDB物理備份文件 時,url 中間有特殊字元&,需要把url放在‘’(單引號中)。

否則報錯;

[1] 193923
[2] 193924
[2]+  Done                    Expires=1565425103
..........................................................
..........................................................
..........................................................
HTTP request sent, awaiting response... 403 Forbidden
2019-08-05 16:19:50 ERROR 403: Forbidden.


[1]+  Exit 8 

 

Problem 2

啟動MongoDB服務時,報錯。查看啟動log,主要的報錯信息如下;

 

2019-08-05T15:30:12.099+0800 I STORAGE  [initandlisten] exception in initAndListen: 72 Requested option conflicts with current storage engine option for directoryPerDB; you requested false but the current server storage is already set to true and cannot be changed, terminating
2019-08-05T15:30:12.099+0800 I NETWORK  [initandlisten] shutdown: going to close listening sockets...
2019-08-05T15:30:12.099+0800 I NETWORK  [initandlisten] removing socket file: /tmp/mongodb-27017.sock
2019-08-05T15:30:12.099+0800 I NETWORK  [initandlisten] shutdown: going to flush diaglog...
2019-08-05T15:30:12.099+0800 I CONTROL  [initandlisten] now exiting
2019-08-05T15:30:12.099+0800 I CONTROL  [initandlisten] shutting down with code:100

從上面的錯誤提示中可以看出主要是 directoryPerDB 的配置問題。

提示需要將directoryperdb 設置為 true。

Problem 3

當我們將在mongodb 的配置文件中添加以下參數後。

directoryperdb=ture

報錯如下:

Aug 05 15:47:04 weixin-qq01 mongod[192116]: Error parsing INI config file: the argument ('ture') for option 'directoryperdb' is invalid. Valid choices are 'on|off', 'yes|no', '1|0' and 'true|false'

正確的設置如下;

directoryperdb=on

 

Problem 4

如果雲資料庫是副本集,那麼下載還原後的資料庫已也會含有副本集的信息。如果想將還原的資料庫配置成新的副本集,需要移除就的副本集信息。

移除前,添加時會報錯,報錯信息如下;

        "info" : "try querying local.system.replset to see current configuration",
        "ok" : 0,
        "errmsg" : "already initialized",
        "code" : 23,
        "codeName" : "AlreadyInitialized"

移除原因的副本信息,執行如下命令;

use local
db.system.replset.remove({})

[執行後,重新下服務]

 

Problem 5 

配置副本集時,設置的oplogSize 要和 雲資料庫 副本集 的一樣大。

小於雲上設置的oplog,會報錯,錯誤信息如下。[例如本地設置的是1024]

        "ok" : 0,
        "errmsg" : "cmdline oplogsize (1024) different than existing (25600) see: http://dochub.mongodb.org/core/increase-oplog",
        "code" : 13257,
        "codeName" : "Location13257"

大於雲上設置的的oplogsize,會報錯,錯誤信息如下。[例如本地設置的是1024]

        "ok" : 0,
        "errmsg" : "cmdline oplogsize (31024) different than existing (25600) see: http://dochub.mongodb.org/core/increase-oplog",
        "code" : 13257,
        "codeName" : "Location13257"

 

補充說明:

(1):設置為true,每個資料庫的文件存儲在DBPATH指定目錄的不同的文件夾中。使用此選項,可以配置的MongoDB將數據存儲在不同的磁碟設備上,以提高寫入吞吐量或磁碟容量。預設為false。

(2):說明 MongoDB RDS 實例將 directoryperdb 設置為了 ture。 也為我們本地其他MongodB實例的參數設置提供了參考,也建議將 directoryperdb 設置為ture。

(3):查看oplogsize大小的指令;

db.printReplicationInfo()

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1 電腦的基本硬體組成 早期,DIY一臺電腦,要先有三大件 CPU 記憶體 主板 1.1 CPU 電腦最重要的核心配件,中央處理器(Central Processing Unit)。 電腦的所有“計算”都是由CPU來進行的。 CPU是一個超級精細的印刷電路版 1.2 記憶體(Memory) 你撰 ...
  • 任何程式都需要載入到記憶體才能與CPU進行交流 同理, 位元組碼.class文件同樣需要載入到記憶體中,才可以實例化類 的使命就是提前載入.class 類文件到記憶體中 在載入類時,使用的是Parents Delegation Model(溯源委派載入模型) Java的類載入器是一個運行時核心基礎設施模塊, ...
  • 1.事件簡介 事件(event)是MySQL在相應的時刻調用的過程式資料庫對象。一個事件可調用一次,也可周期性的啟動,它由一個特定的線程來管理的,也就是所謂的“事件調度器”。 事件和觸發器類似,都是在某些事情發生的時候啟動。當資料庫上啟動一條語句的時候,觸發器就啟動了,而事件是根據調度事件來啟動的。 ...
  • 以下示例在 SQL Server 實例上創建了一個資料庫。該資料庫包括一個主數據文件、一個用戶定義文件組和一個日誌文件。主數據文件在主文件組中,而用戶定義文件組包含兩個次要數據文件。ALTER DATABASE 語句將用戶定義文件組指定為預設文件組。然後通過指定用戶定義文件組來創建表。 ...
  • 作者: Dominik Moritz, Bill Howe, Jeffrey Heer 發表於CHI 2019, 三位作者都來自於University of Washington Interactive Data Lab 項目代碼: 簡介 Linked Visualization(鏈接可視化系統)是 ...
  • 本文主要瞭解了MySQL關係型資料庫和SQL語言的基本知識。 ...
  • 在windows環境下!!!! 1.找到my.inc文件,不是你的安裝目錄路徑,是C:\ProgramData\MySQL\MySQL Server 5.7這個路徑,註意 ProgramData 文件夾是隱藏的需要顯示出來!!! C:\ProgramData\MySQL\MySQL Server 5 ...
  • 這次接著說MySQL存儲過程: 我們先看它的多分支控制結構case: case的語句很簡單: case 變數名 when 條件1 then 輸出結果1; when 條件2 then 輸出結果2; ...... end case; 那我們就來建立一個存儲過程實現它: 由於我們設置的是隨機數,所以它會根 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...