第6期 MongoDB配置啟動(dòng)方式

一、前言
在安裝好MongoDB后,我們常規(guī)會(huì)進(jìn)入安裝目錄下的bin文件啟動(dòng)服務(wù),但這種啟動(dòng)方式在測(cè)試的時(shí)候還可以用用,但在開(kāi)發(fā)過(guò)程中或者生產(chǎn)環(huán)境中不太實(shí)用,我們要設(shè)置自動(dòng)化啟動(dòng)才能滿足我們的要求,希望通過(guò)本期的學(xué)習(xí)對(duì)大家有幫助,如果大家學(xué)到有,記得點(diǎn)贊、關(guān)注,以后不錯(cuò)過(guò)每一篇干貨。
二、常規(guī)啟動(dòng)服務(wù)方式
啟動(dòng)服務(wù)需要在管理員權(quán)限下打開(kāi)PowerShell命令窗口
2.1 mongod啟動(dòng)MongoDB服務(wù)
# 進(jìn)入MongoDB安裝bin目錄
$ cd 數(shù)據(jù)庫(kù)路徑
# 啟動(dòng)mongod服務(wù)
mongod
--dbpath = 數(shù)據(jù)庫(kù)路徑/data/
--logpath = 數(shù)據(jù)庫(kù)路徑/log/mongodb.log
--port = 27017
--auth 啟用權(quán)限
Eg.mongod --dbpath=D:\MongoDB\Server\4.4\data --logpath=D:\MongoDB\Server\4.4\data\logs\mongodb.log --auth
三、快速啟動(dòng)服務(wù)方式
啟動(dòng)服務(wù)需要在管理員權(quán)限下打開(kāi)PowerShell命令窗口
3.1 設(shè)置為服務(wù)啟動(dòng)方式
設(shè)置服務(wù)啟動(dòng)方式
# 進(jìn)入MongoDB安裝bin目錄
$ cd 數(shù)據(jù)庫(kù)路徑
# 設(shè)置MongoDB服務(wù)
mongod
--dbpath = 數(shù)據(jù)庫(kù)路徑/data/
--logpath = 數(shù)據(jù)庫(kù)路徑/log/mongodb.log
--port = 27017
--auth 啟用權(quán)限
--install
--serviceName "服務(wù)名稱"
Eg.
mongod --dbpath=D:\MongoDB\Server\4.4\data
--logpath=D:\MongoDB\Server\4.4\data\logs\mongodb.log
--auth
--install
--serviceName "MongoDB"
啟動(dòng)服務(wù)
$net start MongoDB
暫停服務(wù)
$net stop MongoDB
刪除服務(wù)
$sc delete MongoDB
3.2 mongo.cfg啟動(dòng)方式 新增mongo.cfg并配置,配置如下:
# mongod.cfg
##location for data
dbpath: D:\Program Files\MongoDB\Server\4.4\data
## location for log
logpath: D:\Program Files\MongoDB\Server\4.4\log\mongod.log
啟動(dòng)配置
$ mongod --config "D:/mongodb/server/mongo.cfg"
設(shè)置為啟動(dòng)服務(wù)
$ mongod --config "D:/mongodb/server/mongo.cfg" --install
--serviceName "MongoDB"
啟動(dòng)服務(wù)
$net start MongoDB
暫停服務(wù)
$net stop MongoDB
刪除服務(wù)
$sc delete MongoDB
四、Mongodb啟動(dòng)命令mongod參數(shù)說(shuō)明基本參數(shù)
| 參數(shù)名稱 | 說(shuō)明 |
|---|---|
| --quiet | # 安靜輸出 |
| --port arg | # 指定服務(wù)端口號(hào),默認(rèn)端口27017 |
| --bind_ip arg | # 綁定服務(wù)IP,若綁定127.0.0.1,則只能本機(jī)訪問(wèn),不指定默認(rèn)本地所有IP |
| --logpath arg | # 指定MongoDB日志文件,注意是指定文件不是目錄 |
| --logappend | # 使用追加的方式寫日志 |
| --pidfilepath arg | # PID File 的完整路徑,如果沒(méi)有設(shè)置,則沒(méi)有PID文件 |
| --keyFile arg | # 集群的私鑰的完整路徑,只對(duì)于Replica Set 架構(gòu)有效 |
| --unixSocketPrefix arg | # UNIX域套接字替代目錄,(默認(rèn)為 /tmp) |
| --fork | # 以守護(hù)進(jìn)程的方式運(yùn)行MongoDB,創(chuàng)建服務(wù)器進(jìn)程 |
| --auth | # 啟用驗(yàn)證 |
| --cpu | # 定期顯示CPU的CPU利用率和iowait |
| --dbpath arg | # 指定數(shù)據(jù)庫(kù)路徑 |
| --diaglog arg | # diaglog選項(xiàng) 0=off 1=W 2=R 3=both 7=W+some reads |
| --directoryperdb | # 設(shè)置每個(gè)數(shù)據(jù)庫(kù)將被保存在一個(gè)單獨(dú)的目錄 |
| --journal | # 啟用日志選項(xiàng),MongoDB的數(shù)據(jù)操作將會(huì)寫入到j(luò)ournal文件夾的文件里 |
| --journalOptions arg | # 啟用日志診斷選項(xiàng) |
| --ipv6 | # 啟用IPv6選項(xiàng) |
| --jsonp | # 允許JSONP形式通過(guò)HTTP訪問(wèn)(有安全影響) |
| --maxConns arg | # 最大同時(shí)連接數(shù) 默認(rèn)2000 |
| --noauth | # 不啟用驗(yàn)證 |
| --nohttpinterface | # 關(guān)閉http接口,默認(rèn)關(guān)閉27018端口訪問(wèn) |
| --noprealloc | # 禁用數(shù)據(jù)文件預(yù)分配(往往影響性能) |
| --noscripting | # 禁用腳本引擎 |
| --notablescan | # 不允許表掃描 |
| --nounixsocket | # 禁用Unix套接字監(jiān)聽(tīng) |
| --nssize arg (=16) | # 設(shè)置信數(shù)據(jù)庫(kù).ns文件大小(MB) |
| --objcheck | # 在收到客戶數(shù)據(jù),檢查的有效性, |
| --profile arg | # 檔案參數(shù) 0=off 1=slow, 2=all |
| --quota | # 限制每個(gè)數(shù)據(jù)庫(kù)的文件數(shù),設(shè)置默認(rèn)為8 |
| --quotaFiles arg | # number of files allower per db, requires --quota |
| --rest | # 開(kāi)啟簡(jiǎn)單的rest API |
| --repair | # 修復(fù)所有數(shù)據(jù)庫(kù)run repair on all dbs |
| --repairpath arg | # 修復(fù)庫(kù)生成的文件的目錄,默認(rèn)為目錄名稱dbpath |
| --slowms arg (=100) | # value of slow for profile and console log |
| --smallfiles | # 使用較小的默認(rèn)文件 |
| --syncdelay arg (=60) | # 數(shù)據(jù)寫入磁盤的時(shí)間秒數(shù)(0=never,不推薦) |
| --sysinfo | # 打印一些診斷系統(tǒng)信息 |
| --upgrade | # 如果需要升級(jí)數(shù)據(jù)庫(kù) |
Replicaton 參數(shù)
| 參數(shù)名稱 | 說(shuō)明 |
|---|---|
| -fastsync | # 從一個(gè)dbpath里啟用從庫(kù)復(fù)制服務(wù),該dbpath的數(shù)據(jù)庫(kù)是主庫(kù)的快照,可用于快速啟用同步 |
| --autoresync | # 如果從庫(kù)與主庫(kù)同步數(shù)據(jù)差得多,自動(dòng)重新同步, |
| --oplogSize arg | # 設(shè)置oplog的大小(MB) |
主/從參數(shù)
| 參數(shù)名稱 | 說(shuō)明 |
|---|---|
| --master | # 主庫(kù)模式 |
| --slave | # 從庫(kù)模式 |
| --source arg | # 從庫(kù) 端口號(hào) |
| --only arg | # 指定單一的數(shù)據(jù)庫(kù)復(fù)制 |
| --slavedelay arg | # 設(shè)置從庫(kù)同步主庫(kù)的延遲時(shí)間 |
Replica set(副本集)選項(xiàng)
| 參數(shù)名稱 | 說(shuō)明 |
|---|---|
| --replSet arg | # 設(shè)置副本集名稱 |
Sharding(分片)選項(xiàng)
| 參數(shù)名稱 | 說(shuō)明 |
|---|---|
| --configsvr | # 聲明這是一個(gè)集群的config服務(wù),默認(rèn)端口27019,默認(rèn)目錄/data/configdb |
| --shardsvr | # 聲明這是一個(gè)集群的分片,默認(rèn)端口27018 |
| --noMoveParanoia | # 關(guān)閉偏執(zhí)為moveChunk數(shù)據(jù)保存 |
注:上述參數(shù)都可以寫入 mongo.cfg 配置文檔里例如:
dbpath = /data/mongodb
logpath = /data/mongodb/mongodb.log
logappend = true
port = 27017
fork = true
auth = true
五、點(diǎn)擊下方關(guān)注我們
評(píng)論
圖片
表情
