MongoDB实战系列之二:MongoDB的常用操作

jopen 12年前

#以服务方式启动mongodb,要求验证

/elain /apps /mongodb /bin /mongod  --fork  --port  27001  --auth  --dbpath /elain /data /mongodb /db /  --logpath  /elain /logs /mongodb /mongodb.log

#注:参数中用到的目录需创建

#停止

kill  -2  ` ps  -ef | grep mongod | grep  -v  grep | awk  '' {print  $2 } '' `

#验证启动

[root @md01 ~ ] # netstat -ln
Active Internet connections  (only servers )
Proto Recv-Q Send-Q Local Address               Foreign Address             State
tcp         0       0 0.0.0.0: 28001               0.0.0.0: *                   LISTEN
tcp         0       0 0.0.0.0: 27001               0.0.0.0: *                   LISTEN

还可以通过访问:http://ip:28001/ 浏览

#远程登录:

mongo  --host serverip: 27001

#本机登录:

mongo  --port  27001
[root @md01 ~ ] # mongo --host localhost:27001
MongoDB shell version: 2.0.0
connecting to: localhost: 27001 / test
>

#获取MongoDB服务器统计信息

> db.runCommand ( { "serverStatus" :  1 } )

#使用实时监控工具

mongostat  -h localhost: 27001

#查看版本

> db.version ( )
2.0.0

用户管理:

> db.addUser ( "root", "123456" );     #添加管理员root
> use  test
switched to db  test
> db.addUser ( "test_w", "123456" );   #为TEST库添加普通用户test_w
> use  test
switched to db  test
> db.addUser ( "test_r""123456"true );    #为TEST库添加只读用户test_r
> db.system.users.remove ( { "user""test_w" } );     #删除名为test_w的用户
> db.auth ( "test_w""123456" );             #验证并切换用户身份
> db.system.users.find ( );                  #查看当前库的所有用户
> show  users;                              #查看当前库的所有用户
> use admin
> db.runCommand ( { "buildInfo": 1 } )           #查看系统信息与mongodb版本

数据管理:

>use elain          #建库
>db.elain.insert ( {name: ''elain '' } );     #数据插入
>db.elain.remove ( {name: ''elain '' } );     #数据删除
>db.elain.remove ( {name: ''elain '' } );     #数据删除(永久删除)
>show dbs;            #显示数据库
>show collections;    #显示表
>db.elain.find ( );     #数据查询
>db.elain.findOne ( )#只查一行
>db                   #查看当前所在库
>db.collection.count ( );   #统计colleciton的数量
>db.collection.drop ( );    #删除此colleciton
>db.foo.find ( ).count     #某个数据的数量
>db.deliver_status.dataSize ( );          #查看collection数据的大小
>db.deliver_status.stats ( );             #查看colleciont状态
>db.deliver_status.totalIndexSize ( );    #查询所有索引的大小

#删除数据库

use elain;
db.dropDatabase ( );

#修复数据库

db.repairDatabase ( );

#删除表

db.elain.drop ( );

#查看profiling

show profile
>db.test.find ( { }, { "_id": 0 } );   #不显示id列
>db.test.find ( { ''name '': /mp /i } );   #正则查找忽略大小写
db.elain.ensureIndex ( { "name": 1 } );         #建立索引
db.elain.dropIndex ( { "name": 1 } );                 #删除索引
db.elain.find ( { "name": "elain" } ).explain ( );   #查看索引

—————————————

"$lt"           <
"$lte"          <=
"$gt"           >
"$gte"          >=
"$ne"           < >
"$in"          一个键匹配多个值
"$nin"         一个键不匹配多个值
$not           不匹配
$all           匹配数组全值
$size          数组长度
$slice         返子集合  { "$slice”:10}  -10   [10,20]
.              内嵌文档 {“name.first”:“xxx”}
$where         *通常情况下不建议使用

—————————————–

备份恢复:
数据导出:

/elain /apps /mongodb /bin /mongoexport  -h 127.0.0.1: 27001  -uroot  -p  -d elain -c  -o elain elain_con.csv

数据导入:

/elain /apps /mongodb /bin /mongoimport  -h 127.0.0.1: 27001  -uroot  -p  -d elain -c elain elain_con.csv

备份数据库:

mongodump  -h 127.0.0.1: 27001  -uroot  -p  -d elain  -o  /elain /backup /mongodb

恢复数据库:

mongorestore  -h 127.0.0.1: 27001  -uroot  -p  -d elain /elain /backup /mongodb /elain

恢复数据库(恢复前清除已有数据):

mongorestore  -h 127.0.0.1: 27001  -uroot  -p  -d elain  --drop /elain /backup /mongodb /elain

性能测试:
备份方面:mongodump的速度和压缩率都最好,每秒125M的数据,压缩率达28%
恢复方面:
mongoimport速度较快,但不保证数据完整导入
mongorestore,速度较慢,比mongoimport慢2.5倍左右,但是根据mongodump导出的数据,可以完整导入数据。