【MongoDB詳細使用教程】五、MongoDB的資料庫管理

来源:https://www.cnblogs.com/cbowen/archive/2019/10/30/11763463.html
-Advertisement-
Play Games

"【MongoDB詳細使用教程】一、Mac安裝MongoDB" "【MongoDB詳細使用教程】二、MongoDB基本操作" "【MongoDB詳細使用教程】三、高級查詢" "【MongoDB詳細使用教程】四、python操作MongoDB" "【MongoDB詳細使用教程】五、MongoDB的數據 ...


目錄

【MongoDB詳細使用教程】一、Mac安裝MongoDB
【MongoDB詳細使用教程】二、MongoDB基本操作
【MongoDB詳細使用教程】三、高級查詢
【MongoDB詳細使用教程】四、python操作MongoDB
【MongoDB詳細使用教程】五、MongoDB的資料庫管理

1、資料庫安全

為資料庫添加用戶和密碼

1.1、創建管理員賬號和密碼

  1. 登陸無密碼的資料庫
  2. 創建(或切換到)admin庫
  3. 創建管理員賬號和密碼
  4. 驗證管理員賬號和密碼

示例:

# 1
cbowendeMacBook-Pro:~ cbowen$ mongo
MongoDB shell version v4.0.9
connecting to: mongodb://127.0.0.1:27017/?gssapiServiceName=mongodb
...
>

# 2
> use admin
switched to db admin

# 3
> db.createUser({user:'admin',pwd:'123',roles:["root"]})
Successfully added user: { "user" : "admin", "roles" : [ "root" ] }

# 4
> db.auth('admin','123')
1

"roles" : [ "root" ] 意為分配超級管理員許可權

1.2、設置服務狀態為需要驗證用戶

正常開啟服務時是不需要驗證用戶信息的,即使已經創建了用戶。
這裡我們要先關閉資料庫服務,並以需要驗證用戶的模式啟動服務。

  1. 關閉服務
  2. 重啟新啟動服務,並設定為需要驗證
# 終端中輸入:
 mongod --dbpath data --logpath log/mongod.g --logappend --auth

正常開啟語句後面加上--auth。

(對於windows系統,如果已經將加入服務中,需要將服務卸載後重新以需驗證模式加入)

1.3、創建用戶賬戶和密碼

  1. 以管理員身份連接資料庫
  2. 切換到要創建賬號的資料庫,並創建用戶賬戶和密碼
  3. 登錄時先切換到該庫,再登陸

示例:

# 1、以管理員身份連接資料庫
cbowendeMacBook-Pro:~ cbowen$ mongo
MongoDB shell version v4.0.9
connecting to: mongodb://127.0.0.1:27017/?gssapiServiceName=mongodb
Implicit session: session { "id" : UUID("5316d74a-2148-43e9-a9e8-f501cc1d9781") }
MongoDB server version: 4.0.9
> use admin         # 驗證賬號前要先切換到admin庫
switched to db admin
> db.auth('admin','123')
1

# 2、切換到要創建賬號的庫,並創建賬號和密碼,以及設置許可權roles
> use mymongo
switched to db mymongo
> db.createUser({user:'mymongo',pwd:'123',roles:[{role:'dbOwner',db:'mymongo'}]})
Successfully added user: {
    "user" : "mymongo",
    "roles" : [
        {
            "role" : "dbOwner",
            "db" : "mymongo"
        }
    ]
}

# 3、退出管理員賬號,用剛創建的用戶登陸
> exit
bye
cbowendeMacBook-Pro:~ cbowen$ mongo
MongoDB shell version v4.0.9
connecting to: mongodb://127.0.0.1:27017/?gssapiServiceName=mongodb
Implicit session: session { "id" : UUID("47cb777a-d000-41be-a61c-1041faa31dc0") }
MongoDB server version: 4.0.9
> use mymongobu                 # 先切換資料庫
switched to db mymongobu
> db.auth('mymongobu','123')    # 再驗證賬號
1

註:
1、roles:[{role:'dbOwner',db:'mymongo'}] 意為該賬號僅對資料庫mymongo有效。
2、用戶的信息會作為數據保存在資料庫中,在創建用戶信息前切換到哪個資料庫,創建的用戶信息就會保存在哪個庫中,那麼在登陸的時候也要先切換到該庫,才可驗證成功。如果創建mymongo用戶時,是在admin庫中,那麼驗證時就要先切換到admin庫,驗證後效果一樣,mymongo賬號依然只對mymongo庫有效。

1.4、忘記密碼/修改密碼

以超級管理員連接資料庫 或 以無需驗證用戶的模式登陸 後,
使用以下命令更改用戶名:

db.changeUserPassword('用戶名','新密碼');

2、主從伺服器

從伺服器作為主伺服器的冗餘備份,提高了數據的可用性,並保證數據的安全性,可以用於在硬體故障和服務中斷時恢複數據。
主伺服器負責寫入,從伺服器負責讀取,主伺服器宕機後, 從伺服器自動切換為主伺服器。

2.1、創建伺服器目錄,用於分別存放主從伺服器數據

在MongoDB目錄下創建了LordSlave文件夾,併在LordSlave中創建了lord和slave文件夾。
(進入MongoDB目錄需要在finder中按shift + command + G來查詢/usr/local並前往。)

2.2、啟動服務

語法

# 終端中輸入 (IP地址、集群名稱要一致):
mongod --bind_ip IP地址 --port 埠1 --dbpath 主伺服器目錄 --replSet 集群名稱
mongod --bind_ip IP地址 --port 埠2 --dbpath 從伺服器目錄 --replSet 集群名稱

示例

mongod --bind_ip 127.0.0.1 --port 27017 --dbpath /usr/local/MongoDB/LordSlave/lord --replSet rps
mongod --bind_ip 127.0.0.1 --port 27018 --dbpath /usr/local/MongoDB/LordSlave/slave --replSet rps

開啟服務的終端視窗不要退出。

2.3、連接其中一臺伺服器並設置為主伺服器

在新的終端視窗中輸入如下命令,登陸27017埠

mongo --host 127.0.0.1 --port 27017

使用 "rs.initiate()" 命令進行初始化,顯示結果:

> rs.initiate()
{
    "info2" : "no configuration specified. Using a default configuration for the set",
    "me" : "127.0.0.1:27017",
    "ok" : 1,
    "operationTime" : Timestamp(1572401660, 1),
    "$clusterTime" : {
        "clusterTime" : Timestamp(1572401660, 1),
        "signature" : {
            "hash" : BinData(0,"AAAAAAAAAAAAAAAAAAAAAAAAAAA="),
            "keyId" : NumberLong(0)
        }
    }
}

2.4、在主伺服器上添加/刪除另一臺為從伺服器

繼續在當前設置完的主伺服器終端中輸入:

rs.add('127.0.0.1:27018')

顯示結果:

rps:PRIMARY> rs.add('127.0.0.1:27018')
{
    "ok" : 1,
    "operationTime" : Timestamp(1572402066, 1),
    "$clusterTime" : {
        "clusterTime" : Timestamp(1572402066, 1),
        "signature" : {
            "hash" : BinData(0,"AAAAAAAAAAAAAAAAAAAAAAAAAAA="),
            "keyId" : NumberLong(0)
        }
    }
}

使用 "rs.status()" 查詢伺服器狀態:

如需刪除從伺服器則使用

rs.remove('127.0.0.1:27018')

2.5、登陸並激活從伺服器

在新終端中登陸另一臺伺服器:

mongo --host 127.0.0.01 --port 27018

使用 "rs.slaveOk()" 激活從伺服器

rps:SECONDARY> rs.slaveOk()

至此,主從伺服器配置完成,可以配置多台從伺服器。

3、備份與還原

3.1、庫備份

語法:

mongodump -h dbhost -d dbname -o dbdirectory

# 如果賬號有密碼的話加上 -u 和 -p 屬性
mongodump -h dbhost -u user -p pass -d dbdirectory
  • -h:伺服器地址,也可以指定埠號
  • -d:需要備份的資料庫名稱
  • -o:備份的數據存放位置,此目錄中存放著備份出來的數據
  • -u:用戶名,要加引號
  • -p:密碼,要加引號

示例:

  • 先開啟資料庫服務
  • 創建備份目錄夾/usr/local/MongoDB/bu
  • 終端中輸入:
mongodump -h 127.0.0.1:27017 -d mymongo -o /usr/local/MongoDB/bu
  • 出現如下信息則備份成功
cbowendeMacBook-Pro:~ cbowen$ mongodump -h 127.0.0.1:27017 -d mymongo -o /usr/local/MongoDB/bu
2019-10-29T15:43:55.109+0800    writing mymongo.singer to 
2019-10-29T15:43:55.109+0800    writing mymongo.students to 
2019-10-29T15:43:55.114+0800    done dumping mymongo.singer (15 documents)
2019-10-29T15:43:55.115+0800    done dumping mymongo.students (9 documents)
  • 備份文件如下,系統自動創建了與資料庫同名的文件夾mymongo

3.2、庫還原

語法:

mongorestore -h dbhost -d dbname --dir dbdirectory

# 如果賬號有密碼的話加上 -u 和 -p 屬性
mongorestore -h dbhost -d dbname  -u user -p pass --dir dbdirectory
  • -h:伺服器地址
  • -d:需要恢復的資料庫實例(如果使用新名字,就會再重新創建一個庫)
  • --dir:備份數據所在位置,可省略--dir關鍵字,直接寫地址即可。
    (備份時會在指定備份目錄下自動創建一個與備份庫同名的文件夾,還原時要在路徑中加上這個文件夾,具體請看下麵示例。)

示例:

  • 開啟資料庫服務
  • 在終端中輸入
    mongorestore -h 127.0.0.1 -d mymongobu --dir /usr/local/MongoDB/bu/mymongo
    註:
    備份的地址是/usr/local/MongoDB/bu
    mymongo是備份時自動創建的與庫名相同的文件夾,還原時需要加上後面的/mymongo

  • 出現如下信息則還原成功
cbowendeMacBook-Pro:~ cbowen$ mongorestore -h 127.0.0.1 -d mymongobu --dir /usr/local/MongoDB/bu/mymongo
2019-10-29T16:03:32.386+0800    the --db and --collection args should only be used when restoring from a BSON file. Other uses are deprecated and will not exist in the future; use --nsInclude instead
2019-10-29T16:03:32.386+0800    building a list of collections to restore from /usr/local/MongoDB/bu/mymongo dir
2019-10-29T16:03:32.390+0800    reading metadata for mymongobu.singer from /usr/local/MongoDB/bu/mymongo/singer.metadata.json
2019-10-29T16:03:32.390+0800    reading metadata for mymongobu.students from /usr/local/MongoDB/bu/mymongo/students.metadata.json
2019-10-29T16:03:32.440+0800    restoring mymongobu.singer from /usr/local/MongoDB/bu/mymongo/singer.bson
2019-10-29T16:03:32.498+0800    no indexes to restore
2019-10-29T16:03:32.498+0800    finished restoring mymongobu.singer (15 documents)
2019-10-29T16:03:32.498+0800    restoring mymongobu.students from /usr/local/MongoDB/bu/mymongo/students.bson
2019-10-29T16:03:32.500+0800    restoring indexes for collection mymongobu.students from metadata
2019-10-29T16:03:32.538+0800    finished restoring mymongobu.students (9 documents)
2019-10-29T16:03:32.538+0800    done

3.3、集合的備份與還原

# 備份單個集合
mongodump -h dbhost -d dbname -c collectionname -o dbdirectory

# 還原單個集合
mongorestore -h dbhost -d dbname --dir dbdirectory

這裡還是要註意,備份時的dbdirectory為目錄,而還原時的dbdirectory要指定到具體的.bson文件。

示例:

# 備份集合
mongodump -h 127.0.0.1:27017 -d mymongo -c singer -o /usr/local/MongoDB/bu/collection

#還原集合
mongorestore -h 127.0.0.1:27017 -d mymongobu --dir /usr/local/MongoDB/bu/collection/mymongo/singer.bson

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

-Advertisement-
Play Games
更多相關文章
  • 問題登場: 使用sql developer 登錄oracle 時報錯,錯誤碼17002 解決辦法: 右鍵,點擊properties 屬性,檢查每一項配置,發現ip 是之前的ip,更改為database新的ip後,問題解決! ...
  • 今天在修改一個關於mybtis語句時,偶然發現的一個錯誤 There is no getter for property named 'id' in class 'java.lang.String', 糾結了許久,終於明白了為什麼。 原因:Mybatis預設採用ONGL解析參數,所以會自動採用對象樹 ...
  • 在安裝sql server 2017 時出現 彈框標題為 microsoft sql server 2012 native client 內容為需要sqlncli.msi文件 去本地目錄找本身的那個 發現沒有用,於是去網上尋找,也沒有解決,後面運氣好,解決了, 因為安裝成功沒有截圖 文件下載官方地址 ...
  • 一、關係型資料庫與非關係型資料庫 1.關係型資料庫的特點: 1)數據以表格的形式出現 2)每行為各種記錄名稱 3)每列為記錄名稱所對應的數據域 4)許多的行和列組成一張表單 5)若幹的表單組成資料庫 2.關係型資料庫的優勢: 2.1 複雜的查詢:可以使用SQL語句方便地在一個表以及多個表之間做非常復 ...
  • The listener supports no services 問題處理辦法 ...
  • Case Sensitive Check 1. Return names contain upper case 2. Return same name but diff case Case when https://blog.csdn.net/evilcry2012/article/details/ ...
  • 1、order by order by 欄位1 升序或者降序,欄位2 升序或者降序(dsc) 預設 升序(asc) 註意:如果是分組,則應該使用對分組欄位進行排序的groupby語法 group by 先執行 order by 後執行 group by 比order by先執行,order by不會 ...
  • SQL Server中的LEFT、RIGHT函數。 LEFT :返回字元串中從左邊開始指定個數字元。 RIGTH :返回字元串從右邊開始指定個數字元。 例: 本文來自 "木莊網路博客" "SQL Server中的LEFT、RIGHT函數" ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...