MongoDB日常保养
它引入了程序来进行维护管理工具
启动和停止MongoDB
启动后能够通过数据库的IP加port号訪问Web形式数据库。
配置文件
通过使用拂去配置文件的方式启动数据库实例。在bin目录下创建并编辑mongodb.config(名字能够任意)
事例加上 dbpath =/data/db/
启动时加上 --f 參数,而且指向配置文件就可以。
使用Daemon方式启动
为什么我们使用Daemon方式?当我们关闭数据库服务的sessionport的时候。MongoDB的服务也随之终止,这样是十分不安全的。通过守护进程的方式,启动就可以。
加入 --fork 參数,这里必须指定存储日志的文件。即为启动 --logpath 參数。
事比例如以下
./mongod.exe --dbpath = D:\MongoDB --logpath = D:\MongoDB\log\mongodb50.log --fork
常见的mongod的參数说明
- dbpath:数据文件存放路径
- logpath: 存放的日志文件
- bind_ip :对外的服务绑定IP。一般为空,面对全部的IP开放
- port: fork 以后台Daemon的形式启动该服务,web管理端在其上加1000
- journal: 开启日志功能,通过保存操作日志来减少单机故障的恢复时间,
- config :当參数行十分多的时候。使用这个參数来设定參数文件的位置
关闭数据库
- 直接使用Control+C来中断
- 在connect连接状态下,能够切换到admin数据。后直接在库中发送db.shutdownServer()指令终止MongoDB实例。
- Unix下发送Kill -2 PID 或者 Kill -15 PID来终止进程
ps aux|grep mongod
kill -2 (yourPID)
ps aux|grep mongod
注意:不能使用kill -9 PID 杀死进程。这样可能导致MongoDB数据库损坏。
訪问数据库
- 绑定iP地址 ——bind_ip
//MongoDB 能够限制仅仅同意某一特定IP 来訪问。仅仅要在启动时加一个參数bind_ip 就可以,例如以下:
[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ ./mongod --bind_ip 192.168.1.61 - 设置监听端口 ——port
//将服务端监听port改动为27018:
[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ ./mongod --bind_ip 192.168.1.61 --port 27018
//(报错代码)端户訪问时不指定port,会连接到默认port27017,对于本例会报错,代码例如以下:
[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ ./mongo 192.168.1.50
MongoDB shell version: 2.0.2
connecting to: 192.168.1.61/test
Sun Apr 14 21:45:26 Error: couldn't connect to server 192.168.1.50 shell/mongo.js:81 exception: connect failed - 使用username和password登陆 ——启动时使用--auth參数
//先启用系统的登录验证模块, 仅仅需在启动时指定 auth 參数就可以。代码例如以下:
[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ ./mongod --auth
启动认证
默认有个admin数据库。在admin.system.users中保存的用户比其它的数据库设置的用户权限更大。
在未加入admin.system.users用户的权限的的情况下。 client无需不论什么认证就能够连接到数据库。而且能够对数据库进行不论什么操作,仅仅有在admin.system.users加入了用户。启动--auth參数才会起作用。
1.建立系统root用户
>db.addUser("root","123456")
>db.auth("root","123456")
2.建立仅仅读权限用户
>db.addUser("user_reader","1234567",true)
加入仅仅读权限的用户仅仅需加入第三个參数,true。
使用命令行操作
MongoDB不仅能够交互,还能够运行指定的JavaScript文件,运行指定的命令片段,使用Linux Shell。
1.通过eval參数运行指定的语句
查询test库的t1集合的记录有多少:
db.t1.find()
{ "_id" : ObjectId("4f8ac746b2764d3c3e2cafbb"), "num" : 1 }
{ "_id" : ObjectId("4f8ac74cb2764d3c3e2cafbc"), "num" : 2 }
{ "_id" : ObjectId("4f8ac74eb2764d3c3e2cafbd"), "num" : 3 }
{ "_id" : ObjectId("4f8ac751b2764d3c3e2cafbe"), "num" : 4 }
{ "_id" : ObjectId("4f8ac755b2764d3c3e2cafbf"), "num" : 5 }
db.t1.count()
5
通过使用--eval參数直接运行ti的集合中的数
$./mongo.exe --eval "printjson(db.t1.count())"
MongoDB shell version: 2.0.2
connecting to: test
5
2.使用js文件运行文件内容
$cat t1_count.js
var count = db.t1.count();
printjson('count of t1 is: '+count);
显示为:
$./mongo t1_count.js
MongoDB shell version: 2.0.2
connecting to: test
"count of t1 is: 5"
Tips:通过--quiet參数屏蔽部分登陆信息,使结果更清晰
$ ./mongo --quiet t1_count.js
"count of t1 is: 5"
进程管理
查看活动进程
> db.currentOp()
>db.$cmd.sys.inprog.findOne() //$cmd调用外部函数
显演示样例如以下:
> db.currentOp()
{
"inprog" : [
{
"opid" : 630385,
"active" : true,
"lockType" : "read",
"waitingForLock" : false,
"secs_running" : 0,
"op" : "query",
"ns" : "test",
"query" : {
"count" : "t1",
"query" : {
},
"fields" : {
}
},
"client" : "127.0.0.1:51324",
"desc" : "conn",
"threadId" : "0x7f066087f710",
"connectionId" : 7,
"numYields" : 0
}
]
}
>
代码解释:
- opid:操作进程号
- op: 操作类型(query ,update 。etc)
- ns: 命名空间(namespace)。操作对象
- query :显示操作的详细内容
- lockType: 锁的类型,指明是写锁还是读锁
结束进程
> db.killOp(630385)
{ "info" : "attempting to kill op" }
我们查看下:
> db.currentOp()
{ "inprog" : [ ] }
>
监控系统的状态和性能
使用serverStatus命令能够获取到执行中的MongoDBserver统计信息。以下我们来执行命令。查看MongoDBserver的统计信息(不同平台或不同版本号的键会有所不同)。代码例如以下:
> db.runCommand({"serverStatus":1})
{
"host" : "lindenpatservermongodb01",
"version" : "2.0.2",
"process" : "mongod",
"uptime" : 6003,
"uptimeEstimate" : 5926,
"localTime" : ISODate("2012-04-15T11:02:21.795Z"),
"globalLock" : {
"totalTime" : 6002811172,
"lockTime" : 24867,
"ratio" : 0.000004142559092311891,
"currentQueue" : {
"total" : 0,
"readers" : 0,
"writers" : 0
},
"activeClients" : {
"total" : 0,
"readers" : 0,
"writers" : 0
}
},
"mem" : {
"bits" : 64,
"resident" : 52,
"virtual" : 1175,
"supported" : true,
"mapped" : 160,
"mappedWithJournal" : 320
},
"connections" : {
"current" : 1,
"available" : 818
},
"extra_info" : {
"note" : "fields vary by platform",
"heap_usage_bytes" : 341808,
"page_faults" : 14
},
"indexCounters" : {
"btree" : {
"accesses" : 1,
"hits" : 1,
"misses" : 0,
"resets" : 0,
"missRatio" : 0
}
},
"backgroundFlushing" : {
"flushes" : 100,
"total_ms" : 13,
"average_ms" : 0.13,
"last_ms" : 1,
"last_finished" : ISODate("2012-04-15T11:02:19.010Z")
},
"cursors" : {
"totalOpen" : 0,
"clientCursors_size" : 0,
"timedOut" : 0
},
"network" : {
"bytesIn" : 1729666458,
"bytesOut" : 1349989344,
"numRequests" : 21093517
},
"opcounters" : {
"insert" : 5,
"query" : 8,
"update" : 0,
"delete" : 0,
"getmore" : 0,
"command" : 21093463
},
"asserts" : {
"regular" : 0,
"warning" : 0,
"msg" : 0,
"user" : 0,
"rollovers" : 0
},
"writeBacksQueued" : false,
"dur" : {
"commits" : 30,
"journaledMB" : 0,
"writeToDataFilesMB" : 0,
"compression" : 0,
"commitsInWriteLock" : 0,
"earlyCommits" : 0,
"timeMs" : {
"dt" : 3073,
"prepLogBuffer" : 0,
"writeToJournal" : 0,
"writeToDataFiles" : 0,
"remapPrivateView" : 0
}
},
"ok" : 1
}
>
数据导出与导入 mongoexport和mongoinport
使用mongoexport导出数据
先看数据:
> db.t1.find()
{ "_id" : ObjectId("4f8ac746b2764d3c3e2cafbb"), "num" : 1 }
{ "_id" : ObjectId("4f8ac74cb2764d3c3e2cafbc"), "num" : 2 }
{ "_id" : ObjectId("4f8ac74eb2764d3c3e2cafbd"), "num" : 3 }
{ "_id" : ObjectId("4f8ac751b2764d3c3e2cafbe"), "num" : 4 }
{ "_id" : ObjectId("4f8ac755b2764d3c3e2cafbf"), "num" : 5 }
>
使用代码:
./mongoexport.exe -d test -c t1 -o t1.dat
connected to: 127.0.0.1
exported 5 records
[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ ls
bsondump mongodump mongoimport mongosniff t1_count.js
mongo mongoexport mongorestore mongostat t1.dat
mongod mongofiles mongos mongotop testfiles.txt
[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ cat t1.dat
{ "_id" : ObjectId("4f8ac746b2764d3c3e2cafbb"), "num" : 1 }
{ "_id" : ObjectId("4f8ac74cb2764d3c3e2cafbc"), "num" : 2 }
{ "_id" : ObjectId("4f8ac74eb2764d3c3e2cafbd"), "num" : 3 }
{ "_id" : ObjectId("4f8ac751b2764d3c3e2cafbe"), "num" : 4 }
{ "_id" : ObjectId("4f8ac755b2764d3c3e2cafbf"), "num" : 5 }
./mongoexport.exe -d test -c t1 -o t1.dat 使用參数说明
- -d: 指明使用的数据库
- -c: 指明导出的集合,这里是t1
- -o: 导出的数据名,这里的数据名默认使用相对路径,也能够使用绝对路径。
导出的数据格式的是JSON方式。也可导出csv格式。
导出为CSV格式代码文件例如以下:
./mongoexport -d test -c t1 -csv -f num -o t1.dat
- -csv:指明了要导出的是CSV格式
- -f: 指明须要导出的是哪些样例
数据导入 mongoimport
现将ti删除:
> db.t1.drop()
true
> show collections
system.indexes
system.users
>
再导入数据,这里导入的是csv数据:
./mongoimport -d test -c t1 --type csv --headerline -file /home/t1.dat
connected to: 127.0.0.1
看看导入的数据是不是一样:
> db.t1.find()
{ "_id" : ObjectId("4f8ac746b2764d3c3e2cafbb"), "num" : 1 }
{ "_id" : ObjectId("4f8ac74cb2764d3c3e2cafbc"), "num" : 2 }
{ "_id" : ObjectId("4f8ac74eb2764d3c3e2cafbd"), "num" : 3 }
{ "_id" : ObjectId("4f8ac751b2764d3c3e2cafbe"), "num" : 4 }
{ "_id" : ObjectId("4f8ac755b2764d3c3e2cafbf"), "num" : 5 }
>
- --type csv 导入的数据格式为CSV,为什么导入CSV格式:CSV对各大主流的数据库支持更良好,而JSON作为轻量级的数据格式,还有些弊端。
- --file 指明导入的文件路径
数据备份和恢复
使用 数据备份 mongodump
./mongodump -d test -o /home/dump
- -o:表示输出的备份路径,假设没有使用这个选项的话,MongoDB会自己主动创建dump目录并将备份文件放于其内。
使用数据恢复 mongorestore
mongorestore获取mongodump的输出结果,并将备份的数据插入到执行的MongoDB中。
./mongorestore -d test dump/*
connected to: 127.0.0.1
Thu Apr 19 18:16:12 dump/test/system.users.bson
Thu Apr 19 18:16:12 going into namespace [test.system.users]
2 objects found
Thu Apr 19 18:16:12 dump/test/t1.bson
Thu Apr 19 18:16:12 going into namespace [test.t1]
5 objects found
Thu Apr 19 18:16:12 dump/test/system.indexes.bson
Thu Apr 19 18:16:12 going into namespace [test.system.indexes]
Thu Apr 19 18:16:12 { key: { _id: 1 }, ns: "test.system.users", name: "_id_" }
Thu Apr 19 18:16:13 { key: { _id: 1 }, ns: "test.t1", name: "_id_" }
2 objects found
版权声明:本文博客原创文章,博客,未经同意,不得转载。
MongoDB日常保养的更多相关文章
- MongoDB日常运维操作命令小结
总所周知,MongoDB是一个NoSQL非数据库系统,即一个数据库可以包含多个集合(Collection),每个集合对应于关系数据库中的表:而每个集合中可以存储一组由列标识的记录,列是可以自由定义的, ...
- mongoDB - 日常操作三
MongoDB 进程控制 进程控制 db.currentOp() # 查看活动进程 db.$cmd.sys.inprog.findOne() # 查看活动进程 与上面一样 opid # 操作进程号 o ...
- MongoDB - 日常操作二
MongoDB 开启认证与用户管理 ./mongo # 先登录 use admin # 切换到admin库 db.addUser(") # 创建用户 db.addUser('zhansan ...
- mongoDB - 日常操作一
mongodb 启动方式 # 不启动认证 ./mongod --bind_ip 172.16.2.17 --port --fork --logpath=/opt/mongodb/mongodb.log ...
- mongoDB - 日常操作四
python 使用 mongodb easy_install pymongo # 安装(python2.+) import pymongo connection=pymongo.Connection( ...
- MongoDB入门(4)- MongoDB日常操作
MongoDB客户端 MongoDB有很多客户端 MongoVue Robomongo MongoDB命令行 启动mongo shell 在windows下,双击mongo.exe可以启动mongo ...
- Mongodb日常管理
用户管理: MongoDB Enterprise > db.version()3.4.10 1.创建超级管理员:MongoDB Enterprise > use admin MongoDB ...
- MongoDB之基本操作与日常维护
MongoDB基本操作 MongoDB的基本操作主要是对数据库.集合.文档的操作,包括创建数据库.删除数据库.插入文档.更改文档.删除文档.和查询文档. 操作 描述 show dbs 查看当前实例下的 ...
- SAP一句话入门 .
SD是Sales and Distribution的简称.在SAP系统中,销售与分销模块处在供应链下游,关注从客户订单到向客户收款的全过程. SD模块中的Sales好理解,而Distribution却 ...
随机推荐
- 在ubuntu安装Phabricator(转)
前言: Phabricator是facebook团队进行codereview的一个工具,是基于php进行开发的.界面简洁优雅,是团队做代码评审的好帮手.个人认为,是当前最好的code review平台 ...
- SWT的文件选择对话框I的使用
swt文件选择框 FileDialog fileselect=new FileDialog(shell,SWT.SINGLE); fileselect ...
- gwt CellTable中的控件按Tab键切换
默认是 cellTable.setKeyboardSelectionPolicy(KeyboardSelectionPolicy.ENABLED); 如果要Tab,则设置为DISABLED; 并将其t ...
- 批处理程序:自动上传FTP,再登陆linux服务器执行更新
----转载请注明出处:博客园-邦邦酱好 最近在学批处理程序,一直没找到能够结合工作来使用它的地方,前几天测试服务端的时候突然想到可以这样做: 写一个批处理程序,自动通过FTP上传软件包到指定的地方, ...
- windows phone 页面导航(6)
原文:windows phone 页面导航(6) 页面导航的例子我们使用的是两个页面,从第一个页面(MainPage)导航到第二个页面(SecondPage),然后可以从第二个页面导航到第一个页面 , ...
- Windows Phone开发(47):轻松调用Web Service
原文:Windows Phone开发(47):轻松调用Web Service 众所周知(除了没用过VS的),在VS里面调用Web Service是一件很愉快的事情,不解释,相信很多朋友在以前的项目中肯 ...
- [HDU 1427]速度计算24点(DFS暴力搜索)
主题连接: pid=1427">http://acm.hdu.edu.cn/showproblem.php?pid=1427 思路:简单的DFS.dfs(sum,next,p)表 ...
- 使用AngularJS开发下一代Web应用
原版的:https://github.com/edagarli/AngularJSWeb 来源书:https://github.com/shyamseshadri/angularjs-book 版权声 ...
- 解决wordpress发表文章,照片不能居中的问题
最近,随着一个年轻漂亮的女人的帮助(简直美极了.图相当火爆,性格非常好.大家闺秀型,照片给大家看看下一个突发.哈哈)获取她的个人博客,地址似乎是www.okaaok.com遇到发表文章.照片不能反正水 ...
- cocos2D(八)---- CCMenu && CCMenuItem
些菜单项让用户開始游戏.暂停\继续游戏.打开\关闭音乐或者是返回到上一个界面,比方以下两张图中用红色线框标记的菜单项 我们能够使用CCMenu和CCMenuItem实现上述的菜单功能,CCMe ...