国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - MongoDB - MongoDB在不同主機間復制數據庫和集合的教程

MongoDB在不同主機間復制數據庫和集合的教程

2020-05-07 15:46lucifercn MongoDB

MongoDB自帶了clone一族JavaScript函數來進行數據的復制,這里我們總結了MongoDB在不同主機間復制數據庫和集合的教程,列舉出了一些主從復制操作中常用的重要函數:

1. db.cloneCollection()
db.cloneCollection(from, collection, query)
在不同的mongodb實例間復制數據,db.cloneCollection是cloneCollection數據庫命令的一個外在體現。

function (from, collection, query) {
 assert( isString(from) && from.length );
 assert( isString(collection) && collection.length );
 collection = this._name + "." + collection;
 query = query || {};
 return this._dbCommand( { cloneCollection:collection, from:from, query:query
} );
}

參數:

from  string  包含需要復制的表的mongodb實例主機名
collection string  數據實例中需要復制的表名,該命令只可以復制遠程mongodb實例上相同數據庫名稱的表
query  document 可選的選項。標準的查詢語句過濾掉不需要的文檔

db.cloneCollection()不允許通過mongos來復制表,只能通過mongod實例來操作。
示例:
192.168.11.51 mongod實例mydb庫,bar集合:

{ "_id" : ObjectId("53687d9df433cf04b788c6d1"), "name" : "dog" }
{ "_id" : ObjectId("53687ff1f433cf04b788c6d2"), "name" : "cat" }
{ "_id" : ObjectId("53687ff4f433cf04b788c6d3"), "name" : "tiger" }

本地mongod實例mydb庫,復制遠程主機的bar集合中滿足查詢條件的文檔:

db.cloneCollection("192.168.11.52", "bar", {"name" : "tiger"})
db.bar.find();
{ "_id" : ObjectId("53687ff4f433cf04b788c6d3"), "name" : "tiger" }

 

2. db.cloneDatabase()
db.cloneDatabase("hostname")
復制遠程主機的數據庫到本地,該命令假設遠程mongodb實例中擁有與本地相同的數據庫名稱。

hostname  string  包含需要復制的數據庫的mongodb實例主機名

db.cloneDatabase是clone數據庫命令的一個外在體現。

function (from) {
 assert( isString(from) && from.length );
 return this._dbCommand( { clone: from } );
}

示例:
192.168.11.51 mongod實例mydb庫,
本機mongodb實例:

use mydb
db.dropDatabase();
db.cloneDatabase("192.168.11.52");

 

3. db.copyDatabase()
db.copyDatabase(fromdb, todb, fromhost, username, password)
從遠程主機復制數據庫到本地,或從本地復制數據庫到遠程主機。

db.copyDatabase是copydb數據庫命令的一個外在體現。
function (fromdb, todb, fromhost, username, password) {
 assert( isString(fromdb) && fromdb.length );
 assert( isString(todb) && todb.length );
 fromhost = fromhost || "";
 if ( username && password ) {
  var n = this._adminCommand( { copydbgetnonce : 1, fromhost:fromhost } );

  return this._adminCommand( { copydb:1, fromhost:fromhost, fromdb:fromdb,
 todb:todb, username:username, nonce:n.nonce, key:this.__pwHash( n.nonce, userna
me, password ) } );
 } else {
  return this._adminCommand( { copydb:1, fromhost:fromhost, fromdb:fromdb,
 todb:todb } );
 }
}

參數:

fromdb  string  源數據庫名稱
todb  string  目標數據庫名稱
fromhost string  可選項,源數據庫的主機名。如果是同一主機,忽略該選項
username string  可選項,源主機名用戶名
password string  可選項,源主機名用戶名對應密碼

屬性:
(1)db.copyDatabase()運行在目標主機的mongod實例上。
(2)db.copyDatabase()會創建目標數據庫,如果其原來不存在。
(3)db.copyDatabase()需要目標機器上有足夠的空間進行復制。
(4)db.copyDatabase()并不會產生目標數據庫的即時快照。如果在復制過程中在源或目標庫發生讀寫操作,會導致數據庫不一致。
(5)db.copyDatabase()在操作過程中并不會鎖住目標主機,所以復制過程中可能出現暫時的中斷來完成其他操作。
源數據庫(fromdb):
mongodb2.6需要在源主機和目標主機擁有以下權限來執行copydb。
(1)如果源主機數據庫不是admin,必須確保擁有以下權限:
{ resource: { db: "mySourceDB", collection: "" }, actions: [ "find" ] }
{ resource: { db: "mySourceDB", collection: "system.js" }, actions: [ "find" ] }
如果源主機是一臺遠程主機,必須確保擁有以下權限:

{ resource: { db: "mySourceDB", collection: "system.indexes" }, actions: [ "find" ] }
{ resource: { db: "mySourceDB", collection: "system.namespaces" }, actions: [ "find" ] }

(2)如果源主機數據庫是admin,必須確保擁有以下權限:

{ resource: { db: "admin", collection: "" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.js" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.users" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.roles" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.version" }, actions: [ "find" ] }

如果源主機是一臺遠程主機,必須確保擁有以下權限:

{ resource: { db: "admin", collection: "system.indexes" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.namespaces" }, actions: [ "find" ] }

(3)源數據庫在遠程主機
如果從一個擁有用戶認證的遠程主機復制數據庫,需要一個擁有恰當的權限的用戶認證。
目標數據庫(todb):
A、如果目標主機數據庫不是admin,必須確保擁有以下權限:

{ resource: { db: "myTargetDB", collection: "" }, actions: [ "insert", "createIndex" ] }
{ resource: { db: "myTargetDB", collection: "system.js" }, actions: [ "insert" ] }

B、如果目標主機數據庫是admin,必須確保擁有以下權限:

resource: { db: "myTargetDB", collection: "" }, actions: [ "insert", "createIndex" ] },
{ resource: { db: "myTargetDB", collection: "system.js" }, actions: [ "insert" ] },
{ resource: { db: "myTargetDB", collection: "system.users" }, actions: [ "insert" ] },
{ resource: { db: "myTargetDB", collection: "system.roles" }, actions: [ "insert" ] },
{ resource: { db: "myTargetDB", collection: "system.version" }, actions: [ "insert" ] }

示例:
192.168.11.51 mongod實例mydb庫,
復制到本地newmydb庫:

db.copyDatabase("mydb", "newmydb", "192.168.11.52");

 

4. cloneCollection
從遠程mongodb實例復制集合到當前mongodb實例。集合名稱是一致的:

{ cloneCollection: "<namespace>", from: "<hostname>", query: { <query> } }

cloneCollection擁有以下的域值:

cloneCollection  string  集合的命名空間,命名空間包含了數據庫名和集合名的組合
from    string  指定遠程主機名和可選的端口號
query    document  可選的,過濾選項

示例:
192.168.11.51 mongod實例mydb庫,bar集合:

{ "_id" : ObjectId("53687d9df433cf04b788c6d1"), "name" : "dog" }
{ "_id" : ObjectId("53687ff1f433cf04b788c6d2"), "name" : "cat" }
{ "_id" : ObjectId("53687ff4f433cf04b788c6d3"), "name" : "tiger" }

本地mongod實例:

db.runCommand({cloneCollection : "mydb.bar", from : "192.168.11.52:27017", query : {"name" : "tiger"}})
use mydb
db.bar.find()
{ "_id" : ObjectId("53687ff4f433cf04b788c6d3"), "name" : "tiger" }

cloneCollectionAsCapped可以利用數據庫中存在的非cpped集合創建出一個新的capped集合,操作對原來的集合沒有副作用。
指令的語法:
{ cloneCollectionAsCapped: <existing collection>, toCollection: <capped collection>, size: <capped size> }
新集合名稱在數據庫中是獨一無二的,如果要把一個已經存在的正常集合轉變為cpped集合,可以使用convertToCapped命令,在復制過程中,cloneCollectionAsCapped指令呈現出以下行為:
mongodb會已自然順序遍歷集合中的文檔。
如果size小于先前集合的尺寸,會以FIFO規則刪除早先的文檔。
實例:

db.runCommand({cloneCollectionAsCapped : "bar", toCollection : "barone", size : 100})
db.barone.isCapped();

true

5. clone
clone命令從遠程服務器mongodb實例復制一個數據庫到當前的mongodb實例,形式如下:

{ clone: "db1.example.net:27017" }

需要注意的幾點:
(1)clone不能去操作slave節點或副本集的非主節點。
(2)clone并不支持數據庫快照功能,如果有客戶端對數據更新過了,可能造成結果不一致。
(3)clone命令必須運行在目標節點上。
(4)clone過程中,目標主機沒有鎖定,所以復制過程中可能出現暫時的中斷來完成其他操作。

 

6. copydb
從遠程主機復制數據庫到本地,或從本地復制數據庫到遠程主機。
在本地admin庫里運行以下命令語法:

{ copydb: 1,
 fromhost: <hostname>,
 fromdb: <database>,
 todb: <database>,
 slaveOk: <bool>,
 username: <username>,
 nonce: <nonce>,
 key: <key> }

選項:

fromhost  string  運行mongodb實例的遠程源主機,如果是本地可以忽略
fromdb   string  源數據庫名稱
todb   string  目標數據庫名稱
slaveOk   boolean  可選的,設置為true,允許從從庫復制庫
username  string  可選的,遠程主機的用戶名。
nonce   string  可選的,遠程主機的共享密鑰
key    string  可選的,遠程主機的認證密碼哈希

屬性:
(1)copydb()運行在目標主機的mongod實例上。
(2)copydb()會創建目標數據庫,如果其原來不存在。
(3)copydb()需要目標機器上有足夠的空間進行復制。
(4)copydb()并不會產生目標數據庫的即時快照。如果在復制過程中在源或目標庫發生讀寫操作,會導致數據庫不一致。
(5)copydb()在操作過程中并不會鎖住目標主機,所以復制過程中可能出現暫時的中斷來完成其他操作。
mongodb2.6需要在源主機和目標主機擁有以下權限來執行copydb。
(1)如果源主機數據庫不是admin,必須確保擁有以下權限:

{ resource: { db: "mySourceDB", collection: "" }, actions: [ "find" ] }
{ resource: { db: "mySourceDB", collection: "system.js" }, actions: [ "find" ] }

如果源主機是一臺遠程主機,必須確保擁有以下權限:

{ resource: { db: "mySourceDB", collection: "system.indexes" }, actions: [ "find" ] }
{ resource: { db: "mySourceDB", collection: "system.namespaces" }, actions: [ "find" ] }

(2)如果源主機數據庫是admin,必須確保擁有以下權限:

{ resource: { db: "admin", collection: "" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.js" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.users" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.roles" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.version" }, actions: [ "find" ] }

如果源主機是一臺遠程主機,必須確保擁有以下權限:

{ resource: { db: "admin", collection: "system.indexes" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.namespaces" }, actions: [ "find" ] }

(3)源數據庫在遠程主機
如果從一個擁有用戶認證的遠程主機復制數據庫,需要一個擁有恰當的權限的用戶認證。
目標數據庫(todb):
A、如果目標主機數據庫不是admin,必須確保擁有以下權限:

{ resource: { db: "myTargetDB", collection: "" }, actions: [ "insert", "createIndex" ] }
{ resource: { db: "myTargetDB", collection: "system.js" }, actions: [ "insert" ] }

B、如果目標主機數據庫是admin,必須確保擁有以下權限:

resource: { db: "myTargetDB", collection: "" }, actions: [ "insert", "createIndex" ] },
{ resource: { db: "myTargetDB", collection: "system.js" }, actions: [ "insert" ] },
{ resource: { db: "myTargetDB", collection: "system.users" }, actions: [ "insert" ] },
{ resource: { db: "myTargetDB", collection: "system.roles" }, actions: [ "insert" ] },
{ resource: { db: "myTargetDB", collection: "system.version" }, actions: [ "insert" ] }

認證:
如果遠程主機需要安全認證,則需要使用username,nonce和key進行認證。
nonce是一個一次性的密碼,通過運行copydbgetnonce命令:

use admin
mynonce = db.runCommand( { copydbgetnonce : 1, fromhost: <hostname> } ).nonce

如果直接在遠程主機運行copydbgetnonce命令,可以忽略fromhost選項。
如下生成一個哈希鍵:

hex_md5(mynonce + username + hex_md5(username + ":mongo:" + password))

副本集:設置slaveOk為true,可以在從節點運行copydb。
分片集:不要在mongos實例上運行copydb;不要復制包含分片集合的庫。

實例:
(1)運行在同一主機上的copydb

(2)從遠程主機復制的copydb

db._adminCommand({
 copydb : 1,
 fromdb : "mydb",
 todb : "mydbtwo",
 formhost : "192.168.11.52"
})
{ "ok" : 1 }

(3)從需要安全驗證的遠程主機復制的copydb
遠程主機建立用戶test:caoqing/mydb

use admin
mynonce = db.runCommand( { copydbgetnonce : 1, fromhost: "192.168.11.51:27017" } ).nonce
mykey = hex_md5(mynonce + "test" + hex_md5("test" + ":mongo:" + "caoqing"))
db._adminCommand({
 copydb: 1,
 fromdb: "mydb",
 todb: "mydbthree",
 fromhost: "192.168.11.51",
 username: "test",
 nonce: mynonce,
 key: mykey
})
{ "ok" : 1 }

 

延伸 · 閱讀

精彩推薦
  • MongoDBMongoDB 內存使用情況分析

    MongoDB 內存使用情況分析

    都說 MongoDB 是個內存大戶,但是怎么知道它到底用了多少內存呢...

    MongoDB教程網10002020-09-29
  • MongoDB分布式文檔存儲數據庫之MongoDB分片集群的問題

    分布式文檔存儲數據庫之MongoDB分片集群的問題

    這篇文章主要介紹了分布式文檔存儲數據庫之MongoDB分片集群的問題,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋...

    Linux-18743072020-12-20
  • MongoDBMongoDB憑什么躋身數據庫排行前五

    MongoDB憑什么躋身數據庫排行前五

    MongoDB以比去年同期超出65.96分的成績繼續雄踞榜單前五,這個增幅在全榜僅次于PostgreSQL的77.99,而其相對于4月份的6.10分的增長也是僅次于微軟SQL Server排名...

    孫浩峰3892020-05-22
  • MongoDBMongodb實現定時備份與恢復的方法教程

    Mongodb實現定時備份與恢復的方法教程

    這篇文章主要給大家介紹了Mongodb實現定時備份與恢復的方法教程,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面...

    chenjsh364522020-05-13
  • MongoDBmongodb基本命令實例小結

    mongodb基本命令實例小結

    這篇文章主要介紹了mongodb基本命令,結合實例形式總結分析了MongoDB數據庫切換、查看、刪除、查詢等基本命令用法與操作注意事項,需要的朋友可以參考下...

    dawn-liu3652020-05-26
  • MongoDBMongoDB中javascript腳本編程簡介和入門實例

    MongoDB中javascript腳本編程簡介和入門實例

    作為一個數據庫,MongoDB有一個很大的優勢——它使用js管理數據庫,所以也能夠使用js腳本進行復雜的管理——這種方法非常靈活 ...

    MongoDB教程網6982020-04-24
  • MongoDB遷移sqlserver數據到MongoDb的方法

    遷移sqlserver數據到MongoDb的方法

    這篇文章主要介紹了遷移sqlserver數據到MongoDb的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下...

    聽楓xl9682021-01-03
  • MongoDBMongoDB安裝圖文教程

    MongoDB安裝圖文教程

    這篇文章主要為大家詳細介紹了MongoDB安裝圖文教程,分為兩大部分為大家介紹下載MongoDB和安裝MongoDB的方法,感興趣的小伙伴們可以參考一下 ...

    Yangyi.He6132020-05-07
Weibo Article 1 Weibo Article 2 Weibo Article 3 Weibo Article 4 Weibo Article 5 Weibo Article 6 Weibo Article 7 Weibo Article 8 Weibo Article 9 Weibo Article 10 Weibo Article 11 Weibo Article 12 Weibo Article 13 Weibo Article 14 Weibo Article 15 Weibo Article 16 Weibo Article 17 Weibo Article 18 Weibo Article 19 Weibo Article 20 Weibo Article 21 Weibo Article 22 Weibo Article 23 Weibo Article 24 Weibo Article 25 Weibo Article 26 Weibo Article 27 Weibo Article 28 Weibo Article 29 Weibo Article 30 Weibo Article 31 Weibo Article 32 Weibo Article 33 Weibo Article 34 Weibo Article 35 Weibo Article 36 Weibo Article 37 Weibo Article 38 Weibo Article 39 Weibo Article 40
主站蜘蛛池模板: 一区二区日韩 | av资源在线 | 久久极品 | а√在线中文在线新版 | 91丝袜 | 久久久www | 精品久久久久久久久久久久久久 | 久久久久久久国产精品 | 91电影在线观看 | 亚洲成人精选 | 成人欧美一区二区三区视频xxx | 淫片免费观看 | 综合色网站 | 国产一级一级特黄女人精品毛片 | 欧美在线a | 免费毛片a线观看 | 草草成人| 综合久久久 | 精品一区二区久久久久久久网站 | 日韩精品在线一区 | 免费一级毛片在线播放放视频 | 国产日韩欧美一二三区 | 亚洲97 | 日韩欧美在 | 激情五月婷婷 | a级片在线观看 | 国产伦精品一区二区三区四区视频 | av大全在线 | 久久美女视频 | 91春色 | 欧洲精品久久久 | 欧美日韩在线看 | 日日操视频 | 999在线观看精品免费不卡网站 | 欧美性猛交一区二区三区精品 | 国产精品日韩一区二区 | 亚洲精品成人在线 | 亚洲精品国产成人 | 中文字幕av第一页 | av一级毛片 | 久久久精品网站 |