mongodb資料庫的啟動和停止,mongodb資料庫啟動
資料庫的啟動和停止是資料庫最基本的操作,也是資料庫能夠提供服務和被串連管理的前提條件。不同的資料庫啟動和停止的方式有一些差異,但也有相同之處,啟動和關閉也必定會和資料庫的進程有關。
在oracle資料庫中,資料庫的啟動和停止都是分三個過程的,正常的啟動方法都是在sqlplus中執行startup命令啟動,或者shutdown immediate命令關閉資料庫;在一些特殊的情況下,會通過shutdown abort或者kill後台進程的方式強制關閉資料庫;
在MySQL資料庫中,資料庫的啟動也是通過mysqld或者mysqld_safe命令加設定檔的方式進行啟動,關閉時使用mysqladmin工具加shutdown選項的命令進行mysql資料庫的正常關閉; 通過確認kill進程的方式與shutdown命令的方式停止過程相同,也可以通過kill進程的方式實現mysql的關閉;
對於MongoDB資料庫的啟動和停止,可以通過下面的方法進行研究:
啟動MongoDB 進入MongoDB安裝目錄# cd mongodb-linux-x86_64-2.*.* 執行下面的命令啟動MongoDB# ./bin/mongod --port 33334 --fork --logpath data/log/mongodb.log --dbpath data/db 啟動相關參數說明如下:--port 啟動連接埠號碼--fork 以守護進行方式啟動--logpath mongodb 日誌輸出路徑--dbpath mongodb 資料檔案路徑 其他選項可以執行命令查看: ./bin/mongod --help
操作示範: 編寫MongoDB開機檔案: vim start.sh 指令碼內容如下:cd mongodb-linux-x86_64-2.*.*
./bin/mongod --port 33334 --fork --logpath data/log/mongodb.log --dbpath data/db
停止指令碼啟動:chmod +x start.sh./start.sh 執行結果出現 start sucessful ,說明mongod啟動完成,可以通過下面兩種方式確認MongoDB啟動過程: 確認進程:$ ps -axu | grep mongo 確認日誌:cd /data/logtail -f mongodb.log
安全停止MongoDB進程 向MongoDB進程發送訊號用於停止MongoDB,如果要安全停止可以有兩種訊號:sigint 訊號,或者 sigterm訊號 如何停止:$ kill -2 8888其中 8888 為mongod進程號 ,該進程號可以通過 ps -axu |grep mongo 擷取;-2 表示向mongod進程發送sigint訊號$ kill -4 8888其中 8888 為mongod進程號 ,該進程號可以通過 ps -axu |grep mongo 擷取;-4 表示向mongod進程發送sigterm訊號
上面2種方式如何做到停止安全 mongod進程收到sigint訊號或者sigterm訊號,會做一些處理:關閉所有開啟的串連;將記憶體資料強制重新整理到磁碟;當前的操作執行完畢;。。。。安全停止
除了上面兩種直接針對進程的停止方式,還有使用mongod命令shutdown的安全停止方式:> use admin; --使用管理員資料庫> db.shutdownServer();
不安全的停止方式有:$ kill -9 8888其中 8888 為mongod進程號 ,該進程號可以通過 ps -axu |grep mongo 擷取;-9 表示向mongod進程發送sigkill訊號,MongoDB直接停止,不會做一些相關處理;資料庫直接關閉;資料丟失;資料檔案損壞;修複資料庫(成本高,有風險)
通過上面的分析可以看出,MongoDB的啟動過程和其他資料庫類似,主要是校正資料庫檔案的一致性,一般不會有太多風險,只要資料庫能夠正常啟動即可; 對於MongoDB的停止,可以通過mongo工具中的shutdown命令安全停止,也可以在查詢到MongoDB進程號後,使用kill -2,kill -4 兩種方式實現相同的安全停止方式; 如果對MongoDB使用kill -9的方式,則是不安全的停止方式,有可能造成各種問題; 而安全停止和不安全停止的區別在於:安全停止在發出停止命令後,資料庫在後台會進行一系列的操作來保證資料庫最終是一致性關閉; 但如果是不安全停止,則資料庫進程直接沒有,資料庫不會再後台做一系列的操作保證一致性關閉,下次啟動時,就有可能發生各種問題。
著作權聲明:本文為博主原創文章,未經博主允許不得轉載。