日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

PHP系统管理mongodb,MongoDB的日常维护管理

發布時間:2025/3/15 php 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 PHP系统管理mongodb,MongoDB的日常维护管理 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

主要介紹了日常運行維護的管理工具 MongoDB的日常維護包括使用配置文件,設置訪問控制,Shell交互,系統監控和管理,數據庫日常備份和恢復 啟動和停止MongoDB 啟動后可以通過數據庫的IP加端口號訪問Web形式數據庫。配置文件 通過使用拂去配置文件的方式啟動

主要介紹了日常運行維護的管理工具

MongoDB的日常維護包括使用配置文件,設置訪問控制,Shell交互,系統監控和管理,數據庫日常備份和恢復

啟動和停止MongoDB

啟動后可以通過數據庫的IP加端口號訪問Web形式數據庫。配置文件

通過使用拂去配置文件的方式啟動數據庫實例,在bin文件夾下創建并編輯mongodb.config(名字可以隨意)

事例加上 dbpath =/data/db/

啟動時加上 --f 參數,并且指向配置文件即可。

使用Daemon方式啟動

為什么我們使用Daemon方式?當我們關閉數據庫服務的session端口的時候,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

//將服務端監聽端口修改為27018:

[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ ./mongod --bind_ip 192.168.1.61 --port 27018

//(報錯代碼)端戶訪問時不指定端口,會連接到默認端口27017,對于本例會報錯,代碼如下:

[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

使用用戶名和密碼登陸 ——啟動時使用--auth參數

//先啟用系統的登錄驗證模塊, 只需在啟動時指定 auth 參數即可,代碼如下:

[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ ./mongod --auth

啟動認證

默認有個admin數據庫,在admin.system.users中保存的用戶比其他的數據庫設置的用戶權限更大。在未添加admin.system.users用戶的權限的的情況下, 客戶端無需任何認證就可以連接到數據庫,并且可以對數據庫進行任何操作,只有在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命令可以獲取到運行中的MongoDB服務器統計信息,下面我們來執行命令,查看MongoDB服務器的統計信息(不同平臺或不同版本的鍵會有所不同),代碼如下:

> 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

本文原創發布php中文網,轉載請注明出處,感謝您的尊重!

總結

以上是生活随笔為你收集整理的PHP系统管理mongodb,MongoDB的日常维护管理的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。