MongoDB實戰系列之二:MongoDB的常用操作

jopen 12年前發布 | 17K 次閱讀 MongoDB NoSQL數據庫

#以服務方式啟動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導出的數據,可以完整導入數據。

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!