mongodb数据管理

数据的导出、数据导入
数据导出 mongoexport [使用mongoexport -h查看参数] 
数据导入 mongoimport [使用mongoimport -h查看参数]

导入导出json数据实例

 
mongoexport -d mydb -c user -o d:/mongdbback/user.dat
--mydb是要导出的表所属的数据库
--user是要导出的集合名c表示collection
--user.dat是导出后的文件名 mongoimport -d mydb -c user d:/mongdbback/user.dat
--mydb 数据导入的目标数据库
--user 数据导入的目标集合
--d:/mongdbback/user.dat 待导入的数据文件存放路径
 

导入导出csv数据

CSV格式良好,主流数据库都支持导出为csv的格式,所以这种格式非常利于异构数据迁移.

 
mongoexport -d mydb -c user --csv -f  id,name,age  -o d:/mongodbback/user_csv.data
--导出csv格式
--f 指定要导出的列的名字 mongoimport -d mydb -c user --type csv --headerline --file d:/mongodbback/user_csv.data;
--mydb 数据导入的目标数据库
--user 数据导入的目标集合
--type表示导入的文件格式
--headerline 表明不导入第一行,因为第一行是列名
--d:/mongodbback/user_cvs.data 待导入的数据文件存放路径
 

数据备份、数据恢复
数据备份mongodump
数据恢复mongorestore

 
备份实例
mongodump -d mydb //备份mydb数据库
此时会在当前目录下默认创建一个dump目录,用于存放备份出来的文件,也可以指定备份存放的目录使用-o
mongodump -d mydb -o d:/databack/ 恢复实例
mongorestore -d mydb d:/databack/mydb/ 数据备份是为了发生灾难事件后可以恢复数据,但是不幸总是存在的,即没有数据备份,好在MongoDB内建了修复功能.可以尝试修复受损文件,如果Mongdb不正常关闭,启动服务时会看到一堆警告信息.
修复所有数据最简单的方法就是在mongod启动时加上--repaire参数.
修复单个数据库可以再mongodb的shell里边执行repaireDatabase命令,如
>use test
switched to db test
>db.repaireDatabase();
{“ok” : 1}
 

克隆collection

克隆collection是将一组数据从一个数据源拷贝到多个数据源的技术,是将一份数据发布到多个存储站点上的有效方式.

 
远程克隆
例如,将192.168.1.32上test下的user集合克隆到本地
db.runCommand({cloneCollection:”test.user”, from:”192.168.1.32:27017”});
本地克隆
由于mongoDB没有提供本地克隆collection的命令或方法,所以需要写一个循环插入的方案来完成这项工作.
例如,将user集合中的数据克隆一份到taruser中.
> db.user.find().forEach( function(x){ db.taruser.insert(x); } );
> db.taruser.find();
 

复制数据库

使用copyDatabase(fromdb,todb,fromhost)命令来实现复制数据库

远程复制数据库
> db.copyDatabase("from_db1","to_db2","192.163.1.167");
本地复制数据库
> db.copyDatabase("to_db1","to_db2","localhost");

刷新磁盘

在mongoDB中使用”db.runCommand({fsync:1})”命令将内存中尚未写入磁盘的信息写入磁盘,并锁住对数据库更新的操作,但读擦做可以继续.

数据压缩

repairDatabase命令是MongoDB内置的一个方法,调用这个方法MongoDB会扫描数据库中的所有数据,并将通过导入/导出来重新整理数据,整理磁盘碎片

mongoDB中可以使用db.collection.storageSize()和db.collection.totalSize()命令来搜集压缩命令执行前后集合所占用磁盘空间情况

 
> db.user.storageSize();
8192
> db.user.totalSize();
16384
> db.repairDatabase();
{ "ok" : 1 }
> db.user.storageSize();
8035
> db.user.totalSize();
9384
 

捕获异常

MongoDB的写是异步的,返回给客户端成功但写不一定成功,db.getLastError命令有2个功能,即当MongoDB在写操作时,默认不会等数据写完后才返回,这是可以通过这个命令来保证写入是否是成功的.

查看活动进程

 
> db.currentOp();
字段说明:
opid:操作进程号,可以使用db.killop(opid)
op:操作类型(查询、更新等)
ns:命名空间,指操作的是哪个对象
query:如果操作类型是查询的话,将显示具体的查询内容
inLock:指名锁定的类型.-1代表读锁,0代表无锁.1代表写锁.
 

用户安全和认证

限制特定IP地址访问

这样可以避免来自公网上的恶意攻击.

MongDB可以指定对外服务的绑定,默认设置为空,即绑定在本机所有可用IP上,对于商业系统,出于安全考虑,可以绑定内网,减少外网访问避免攻击.
只需要启动时加bind_ip即可.
>mongod --bind_ip 169.254.180.132 //启动mongodb时绑定ip169.254.180.132
此时客户端想访问169.254.180.132上的服务器,就需要显示地指定连接的IP地址是169.254.180.132.
eg. >mongo 169.254.180.132

设置监听端口

MongoDB默认的监听端口是27017,为了安全,一般都会修改这个监听端口.

eg.    >mongod --bind_ip 169.254.180.132 --port 9888    //启动mongodb时绑定ip 并修改端口
同理.客户端连接时需要指定ip跟端口
eg. >mongo 169.254.180.132:9888

设置登录用户名和口令

mongodb默认是没有用户名和口令的,启动后,可以直接用mongoDB连接,并且对所有的库具有root权限,为了安全,必须给其设置用户名和口令.

只需要再启动的时候,指定auth参数.就可以阻止客户端的访问和连接,如下

eg.>mongod -auth --dbpath=../data --logpath=../logs/mongodb.logs

想要登录验证模块生效,必须在admin库中添加一个用户,同时要指定auth参数.

 
D:\program files\mongo\bin>mongo
MongoDB shell version: 1.8.1
connecting to: test
> use admin
switched to db admin
> db.addUser("root","root123");
{
"user" : "root",
"readOnly" : false,
"pwd" : "81c5bca573e01b632d18a459c6cec418"
}
> db.auth("root","root123");
1
>
此时建立了系统root用户.
 

也可以对某个特定的数据库设置用户,这样权限的细粒度划分,也方便进行用户管理.

注意:建立指定权限的用户只能用系统用户来操作.

为mydb创建一个用户名为mydbusr口令为123的用户

 
D:\program files\mongo\bin>mongo -uroot -proot123 localhost:27017/admin
MongoDB shell version: 1.8.1
connecting to: localhost:27017/admin
> show dbs;
admin 0.03125GB
local (empty)
test (empty)
> use mydb;
switched to db mydb
> db;
mydb
> db.addUser("mydbusr","123");
{
"user" : "mydbusr",
"readOnly" : false,
"pwd" : "4dbfed60224bbcd7eccbd2da993a8029"
}system
> show tables;
system.indexes
.users
> db.system.users.find();
{ "_id" : ObjectId("50f6acdd22bc514e46426dda"), "user" : "mydbusr", "readOnly" : false,
60224bbcd7eccbd2da993a8029" }
> db.auth("mydbusr","123");
1
>
 

mongodb管理与安全认证的更多相关文章

  1. MongoDB安全及身份认证

    前面的话 本文将详细介绍MongoDB安全相关的内容 概述 MongoDB安全主要包括以下4个方面 1.物理隔离 系统不论设计的多么完善,在实施过程中,总会存在一些漏洞.如果能够把不安全的使用方与Mo ...

  2. 详解MongoDB管理命令

    MongoDB是一个NoSQL数据库系统:一个数据库可以包含多个集合(Collection),每个集合对应于关系数据库中的表:而每个集合中可以存储一组由列标识的记录,列是可以自由定义的,非常灵活,由一 ...

  3. MongoDB管理

    前几篇文章都是从开发和使用的角度了解了MongoDB的各个知识点,这篇文章将从MongoDB管理的角度入手,了解MongoDB管理所要了解的基本知识. 数据库命令 在前面几篇文章中,已经接触了一些数据 ...

  4. 【九】MongoDB管理之安全性

    要保证一个安全的MongoDB运行环境,DBA需要实施一些控制保证用户或应用程序仅仅访问它们需要的数据.这些措施包括但不限于: 认证机制 基于角色的访问控制 加密 审计 一.认证机制 认证是验证客户端 ...

  5. MongoDB 副本集+分片 认证方式搭建

    MongoDB 副本集+分片 认证方式搭建 参考资料: https://www.cnblogs.com/ityouknow/p/7344005.htmlhttps://jorwen-fang.itey ...

  6. MongoDB管理工具的插件系统

    MongoDB管理工具  MongoCola的开发已经进入第三个年头了. 官方对于C#驱动的投入不够导致了很多东西都必须自己实现,但是不管怎么样,工具现在已经很强大了. 最近准备着手插件系统的开发,简 ...

  7. MongoDB管理与开发精要 书摘

    摘自:<MongoDB管理与开发精要>         性能优化 创建索引 限定返回结果条数 只查询使用到的字段,而不查询所有字段 采用capped collection 采用Server ...

  8. mongodb管理工具rockmongo

    mongodb的图像管理工具非常之多,我用的是rockmongo. RockMongo 是一个PHP5写的MongoDB管理工具. 主要特征: 使用宽松的New BSD License协议 速度快,安 ...

  9. Nodejs mongodb 管理组件adminmongodb

    强大的 nodejs的mongodb管理工具,强大到即下即用: 安装需求: 1.git命令获取组件包,git clone https://github.com/mrvautin/adminMongo. ...

随机推荐

  1. C++回顾day02---<引用>---待补充

    一:引用概念---引用就是为一个变量起一个别名 每个变量都是指向一块内存空间的标识,引用就是重新设置一个标识,但是这个标识还是指向同一个内存空间 和指针类似(其实引用本质就是使用了一个常指针 cons ...

  2. for each循环(增强for循环)

    底层实现是使用了迭代器,简化了迭代器的书写 格式: for(集合/数组的数据类型 变量名: 数组名/集合名) { // body } char[] chars = {'c', 'd', 'd', 'e ...

  3. Web服务调试可用,发布之后访问出错

    今天重装了系统,然后发现之前的Web服务DataService不能用了.将其设置为启动项,运行的结果是 跟踪发现,是mysql.data.dll的版本不对.所以要找到所有版本不对的该dll,将其替换成 ...

  4. linux centos 7 nodejs 的安装

    先SSH 进到终端 随便一目录,或者/temp下 下载nodejs: (如果下载不了,官网 https://nodejs.org/en/download/复制LINUX版本的链接过来) wget ht ...

  5. ASP.NET Web API 2 使用 DelegatingHandler(委托处理程序)实现签名认证

    Ø  前言 在前一篇ASP.NET Web API 2 使用 AuthorizationFilter(授权过滤器)实现 Basic 认证文章中实现了采用 Basic 认证的方式,但是这种方式存在安全隐 ...

  6. 三十四、Linux 进程与信号——信号特点、信号集和信号屏蔽函数

    34.1 信号特点 信号的发生是随机的,但信号在何种条件下发生是可预测的 进程杠开始启动时,所有信号的处理方式要么默认,要么忽略:忽略是 SIGUSR1 和 SIGUSR2 两个信号,其他都采取默认方 ...

  7. bzoj 3620 暴力KMP

    十分暴力的KMP,枚举左端点,在向右侧推进的同时,取较小的la保证条件,n方暴力 #include<bits/stdc++.h> #define rep(i,j,k) for(int i= ...

  8. luogu 4145 花神游历各国 线段树/树状数组+并查集

    此题一看便是RMQ问题,但是由于开平方的特殊操作,tag操作失效 此时发现特性:sqrt最多执行6此便使值到达1/0,此时可以剪枝不进行该操作,利用并查集到达特性找根,根代表还可以进行操作的点,再利用 ...

  9. luogu 1268 树的重量

    打眼一看就是最小生成树嘛,但经过板子wa掉的经历后得知,,emmmm,原来是, 构造! (虽然不知是什么但觉得听起来很厉害的样子...手动微笑) n=2的情况 自然就是g(1,2) n=3的情况,由于 ...

  10. oracle行转列函数以及一些窗口函数(PIVOT ,OVER)

    可以查看博客园上传的文件 pivot  除了要转成列的字段(classnum,classid)值不一样,其他值都应该相同,否则转的数据有问题