当前位置: 首页 > news >正文

丹徒网站建设哪家好企业战略规划方案

丹徒网站建设哪家好,企业战略规划方案,绿茵足球网站建设,做ppt的动图下载哪些网站MongoDB在不同主机间复制数据库和集合的教程 更新时间#xff1a;2016年07月04日 15:49:51 作者#xff1a;lucifercn MongoDB自带了clone一族JavaScript函数来进行数据的复制,这里我们总结了MongoDB在不同主机间复制数据库和集合的教程,列举出了一些主从复制操作中常用…MongoDB在不同主机间复制数据库和集合的教程 更新时间2016年07月04日 15:49:51   作者lucifercn   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 可选项源主机名用户名对应密码属性 1db.copyDatabase()运行在目标主机的mongod实例上。 2db.copyDatabase()会创建目标数据库如果其原来不存在。 3db.copyDatabase()需要目标机器上有足够的空间进行复制。 4db.copyDatabase()并不会产生目标数据库的即时快照。如果在复制过程中在源或目标库发生读写操作会导致数据库不一致。 5db.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 }需要注意的几点 1clone不能去操作slave节点或副本集的非主节点。 2clone并不支持数据库快照功能如果有客户端对数据更新过了可能造成结果不一致。 3clone命令必须运行在目标节点上。 4clone过程中目标主机没有锁定所以复制过程中可能出现暂时的中断来完成其他操作。 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 可选的远程主机的认证密码哈希属性 1copydb()运行在目标主机的mongod实例上。 2copydb()会创建目标数据库如果其原来不存在。 3copydb()需要目标机器上有足够的空间进行复制。 4copydb()并不会产生目标数据库的即时快照。如果在复制过程中在源或目标库发生读写操作会导致数据库不一致。 5copydb()在操作过程中并不会锁住目标主机所以复制过程中可能出现暂时的中断来完成其他操作。 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 }
http://wiki.neutronadmin.com/news/223161/

相关文章:

  • 青海旅游网站建设方案百度贴吧怎么发广告
  • c 教学网站开发深圳网站建设公司市场
  • 建网站商城在哪做湖南网站建设 莫道
  • 天津网站建设案例教程新动力网站建设
  • 网站设计 app开发免费企业网页申请制作步骤
  • 什么网站上面能接点小活做网上注册公司营业执照注册流程
  • 什么网站做ppt分销网站开发合同
  • 外贸网站建设 推广dede织梦做的网站 栏目页有切换js 怎么循环子栏目 调子栏目
  • 网站建设优化开发公司有固定ip自己做网站
  • 网站备案 地址wordpress如何设置成伪静态页面
  • 娄底市建设局网站wordpress 不显示评论
  • 模板堂网站源码加强网站网络安全建设方案
  • 营销软件网站什么是网络营销渠道中最重要的中间商
  • 小企业网站建设的小知识网站建设是半年的持久战
  • 网站建设销售合同广州南站在哪个区
  • 网上购物网站建设需求学校网页设计模板html代码免费
  • o2o商城网站建设方案前端网站开发心得体会
  • wordpress评论删除站点重庆渝云建设有限公司
  • 广东工程建设咨询有限公司网站建设网站要注意什么问题
  • 绿色学校网站模板wordpress 付款插件
  • 上线了怎么做网站东营+网站建设
  • 用服务器ip怎么做网站哈尔滨市建设工程交易信息网
  • 北京网站设计的公司企业网站管理系统用哪个好
  • 软文广告成功案例杭州百度百家号seo优化排名
  • 网站建设公司运营计划潍坊网站建设联系电话
  • 怎么做 niche网站wordpress 翻页电子书
  • 贵阳住房和城乡建设部网站用jsp做的网站源代码
  • 建网站服务公司南昌餐厅网站建设
  • 做平面的公司网站蒙城网站建设
  • 网站论坛制作抚州购物网站开发设计