MongoDB的啟動與停止(一)
1:啟動和停止Mongodb
1)從命令列啟動
執行mongod,啟動MongoDB伺服器,mongod有很多可配置的啟動選項,可以使用mongod --help檢視所有選項
--dbpath:
指定資料目錄,預設是/data/db下,每個mongod程序都需要獨立的資料目錄,加入有3個mongod例項,就必須要有3個獨立的資料目錄。當mongod啟動時,會在資料目錄中建立mongod.lock檔案。這個檔案用於防止其他mongod程序使用該資料目錄。若當有一個mongd啟動後,再啟動另一個mongod時,若再使用剛剛已經啟動mongod的目錄,那麼會報錯:
2017-07-06T16:03:09.703+0800 I STORAGE [initandlisten] exception in initAndListen: 98 Unable to lock file: mongodb/0706/mongod.lock Resource temporarily unavailable. Is a mongod instance already running?, terminating
--port:
指定伺服器監聽的埠號。預設埠號為27017,要是執行多個mongod,必須指定不同的埠號
若有一個27017的埠已經使用了,那麼如果啟動第二個mongod的時候,若還指定27017的話,會報錯:
2017-07-06T16:13:07.215+0800 E NETWORK [initandlisten] listen(): bind() failed Address already in use for socket: 0.0.0.0:27017
--fork:
以守護程序的方式執行MongoDB,建立服務程序,相當於nohup ... &
nohup mongodb/bin/mongod --dbpath mongodb/0706 &
與
mongodb/bin/mongod --dbpath mongodb/0706 --fork
一樣的效果
--logpath:
指定輸出日誌的路徑,而不是輸出到命令列。如果對資料夾有寫許可權的話,系統會在檔案不存在時建立它。它將會已有檔案覆蓋掉,清除原來所有的日誌記錄。如果想保留原來的日誌,還需要使用--logappend
--config:
指定配置檔案,載入命令列未指定的各種選項
--directoryperdb:
使用該引數可以將每個資料庫存放在單獨的目錄中
比如我新建兩個資料庫,那麼在資料目錄下會自動建立資料庫名一樣的資料夾
啟動資料庫時,MongoDB會將一個檔案寫入local資料庫的startup_log集合中,該集合包含了MongoDB的版本,所基於的系統等
> use local
switched to db local
> db.startup_log.findOne()
{
"_id" : "vst2-1499343744092",
"hostname" : "vst2",
"startTime" : ISODate("2017-07-06T12:22:24Z"),
"startTimeLocal" : "Thu Jul 6 20:22:24.092",
"cmdLine" : {
"storage" : {
"dbPath" : "mongodb/0707",
"directoryPerDB" : true
}
},
"pid" : NumberLong(15613),
"buildinfo" : {
"version" : "3.4.5",
"gitVersion" : "520b8f3092c48d934f0cd78ab5f40fe594f96863",
"modules" : [ ],
"allocator" : "tcmalloc",
"javascriptEngine" : "mozjs",
"sysInfo" : "deprecated",
"versionArray" : [
3,
4,
5,
0
],
"openssl" : {
"running" : "OpenSSL 1.0.1f 6 Jan 2014",
"compiled" : "OpenSSL 1.0.1f 6 Jan 2014"
},
"buildEnvironment" : {
"distmod" : "ubuntu1404",
"distarch" : "x86_64",
"cc" : "/opt/mongodbtoolchain/v2/bin/gcc: gcc (GCC) 5.4.0",
"ccflags" : "-fno-omit-frame-pointer -fno-strict-aliasing -ggdb -pthread -Wall -Wsign-compare -Wno-unknown-pragmas -Winvalid-pch -Werror -O2 -Wno-unused-local-typedefs -Wno-unused-function -Wno-deprecated-declarations -Wno-unused-but-set-variable -Wno-missing-braces -fstack-protector-strong -fno-builtin-memcmp",
"cxx" : "/opt/mongodbtoolchain/v2/bin/g++: g++ (GCC) 5.4.0",
"cxxflags" : "-Woverloaded-virtual -Wno-maybe-uninitialized -std=c++11",
"linkflags" : "-pthread -Wl,-z,now -rdynamic -Wl,--fatal-warnings -fstack-protector-strong -fuse-ld=gold -Wl,--build-id -Wl,-z,noexecstack -Wl,--warn-execstack -Wl,-z,relro",
"target_arch" : "x86_64",
"target_os" : "linux"
},
"bits" : 64,
"debug" : false,
"maxBsonObjectSize" : 16777216,
"storageEngines" : [
"devnull",
"ephemeralForTest",
"mmapv1",
"wiredTiger"
]
}
}
預設情況下,啟動mongod時還會啟動一個基本的HTTP伺服器,該伺服器監聽的埠號比主服務的埠號大1000。這個服務提供了HTTP介面,可以檢視Mongodb的一些基本資訊。這些資訊也可以通過shell來檢視。比如說你啟動的是預設埠27017,那麼在瀏覽器開啟http://10.0.0.13:28017 但是你開啟的時候可能沒有,因為預設管理介面是關閉的,所以在啟動的時候加上開啟管理介面引數--httpinterface,也就是 mongodb/bin/mongod --dbpath mongodb/0706 --fork --logpath 0706.log --httpinterface
當你點進去的時候,是這樣的,說你的引數沒開啟,所以啟動的時候還得加上--rest引數
加上引數重新啟動之後,可以看到,有詳細的資訊了
2):配置檔案
Mongodb支援從檔案讀取配置檔案。指定配置檔案可以使用-f和--config選項
mongod -f D:\mongodb\conf\mongo.conf
2:停止Mongodb
方法一:檢視程序,使用kill命令;不能使用kill -9
方法二:在客戶端進去,使用shutdown命令
> use admin;
switched to db admin
> db.shutdownServer();
server should be down...
在主節點(primary)上執行shutdown命令時,伺服器在關閉之前,會先等待備份節點追趕主節點以保持同步。這將回滾的可能性降至最低,但shutdown操作有失敗的可能性。如幾秒鐘內沒有備份節點成功同步,則shutdown操作失敗,主節點不會停止執行。
3:日誌
在啟動mongod的時候,可以指定日誌的級別,即(-v、-vv、-vvv、-vvvv、-vvvvv)或者在shell命令列執行命令修改
mongodb/bin/mongod --dbpath mongodb/0707 --directoryperdb --fork -vvv
日誌級別越大,輸出的日誌越詳細,調至5時,這時mongod會在日誌中記錄幾乎所有的操作,包括每一個請求所處理的內容。
MongoDB預設記錄耗時超過100毫秒的查詢資訊。如果100毫秒不適合需求,可以通過setProfilingLevel命令來改變,下面這條命令表示記錄查詢時間超過500毫秒的訊息
> db.setProfilingLevel(1,500)
{ "was" : 0, "slowms" : 100, "ok" : 1 }
如果想要日誌分割,如按天存放,有兩種方法
方法一:每天定時的執行kill -USR1 程序號,這樣就可以看到,每執行一次kill -USR1 程序號,那麼就會重新生成一個日誌檔案
方法二:在MongoDB的shell行執行,每執行一次都會產生一個新的日誌檔案
> db.adminCommand({"logRotate":1})
{ "ok" : 1 }
要使分割日誌生效,必須啟動的時候使用--logpath,然後可以根據自己的需求,寫shell或python指令碼,然後crontab做成定時任務