CentOS 7下MongoDB的安裝配置


一、Mongodb安裝

以下安裝步驟全部以dp用戶執行

1. 下載mongodb 3.4.2的安裝包:

“mongodb-linux-x86_64-rhel70-3.4.2.tgz”,放在~/software下。

2. 解壓該文件包:

$ cd ~/software

$ tar -xf mongodb-linux-x86_64-rhel70-3.4.2.tgz

得到文件夾 mongodb-linux-x86_64-rhel70-3.4.2/,其中的bin文件夾包含Mongodb的所有可執行文件。

3. 將bin文件夾拷貝到dp用戶的默認可執行文件目錄~/bin

$ mv bin ~/

4. 創建數據庫目錄文件夾

創建數據庫文件目錄,放在~/data/db下

$ mkdir -p ~/data/db

創建MongoDB日志目錄,放在~/data/mongodb/log下

$ mkdir -p ~/data/mongodb/log

  • 注:“~/data/mongodb/log” 文件夾用于存放MongoDB系統日志文件
  • 注:MongoDB進程守護文件mongod.pid放在“~/data/mongodb”下

5. 啟動mongod服務

$ mongod -dbpath ~/data/db -port 7974

如可以啟動,則安裝成功。如不成功,可能需要進行SELinux配置,允許MongoDB可以在相應端口啟動

# semanage port -a -t mongod_port_t -p tcp 7974

  • 注:7974是本項目MongoDB使用的端口,代替默認端口 27017

二、MongoDB配置

1. 寫配置腳本:

創建一個腳本mongod.conf,存放在/home/dp/data/mongodb/config下,內容為

systemLog:
 destination: file
###日志存儲位置
 path: /home/dp/data/mongodb/log/mongod.log
 logAppend: true
storage:
##journal配置
 journal:
  enabled: true
##數據文件存儲位置
 dbPath: /home/dp/data/db/
##是否一個庫一個文件夾
 directoryPerDB: true
##數據引擎
 engine: wiredTiger
##WT引擎配置
 wiredTiger:
  engineConfig:
##WT最大使用cache(根據服務器實際情況調節4~8)
   cacheSizeGB: 4
##是否將索引也按數據庫名單獨存儲
   directoryForIndexes: true
##表壓縮配置,數據壓縮算法,可選值“none”、“snappy”、“zlib”
  collectionConfig:
   blockCompressor: none
##索引配置
  indexConfig:
   prefixCompression: true
##使mongo進程成為系統集成(父id為1)
processManagement:
 fork: true
 pidFilePath:/home/dp/data/mongodb/mongod.pid
##端口配置,將默認端口設為7974(默認為27017)
net:
 port: 7974
 bindIp:127.0.0.1,192.168.117.55
 http:
  enabled: false

2. 取消透明大頁:

MongoDB建議關閉Linux系統默認開啟的透明大頁功能,可編輯rc.local文件,使其在系統啟動的時候關閉:

編輯rc.local文件:

[root@fx dp]# vim /etc/rc.d/rc.local

增加下列內容:

if test -f /sys/kernel/mm/transparent_hugepage/enabled; then
 echo never > /sys/kernel/mm/transparent_hugepage/enabled
 fi
 if test -f /sys/kernel/mm/transparent_hugepage/defrag; then
 echo never > /sys/kernel/mm/transparent_hugepage/defrag
 fi

保存退出,然后賦予rc.local文件執行權限:

[root@fx dp]# chmod +x /etc/rc.d/rc.local

再重啟系統即可。

3. 將MongoDB設為開機啟動

在CentOS 7下使用systemctl服務管理方式配置MongoDB的啟動:

CentOS 7的服務systemctl腳本存放在/usr/lib/systemd/,MongoDB需要開機不登陸就能運行,就要存在系統服務/usr/lib/systemd/system目錄下。

每一個服務以.service結尾,如mongod.service。內容分為3部分:[Unit]、[Service]和[Install]

[Unit]
Description=MongoDB database server
After=network.target
After=syslog.target

[Service]    
#Type=forking  #一次性啟動,mongod的后臺保持由mongod自己的配置文件中定義
Type=oneshot
User=dp
#PIDFile=/home/dp/data/mongodb/pid
#KillMode=process,只殺死主進程,mongod主進程將收到 SIGTERM 信號
KillMode=process
ExecStart=/usr/bin/numactl --interleave=all  /home/dp/bin/mongod -f /home/dp/data/mongodb/config/mongod.conf
#ExecReload=
#ExecStop=
PrivateTmp=true

[Install]
WantedBy=multi-user.target
  • 注:MongoDB建議關閉NUMA功能,用 numactl --interleave=all 方式啟動 mongod 進程

腳本按照上面編寫完成后,以754的權限保存在/usr/lib/systemd/system目錄下,這時就可以利用systemctl進行配置:

  • 重新加載配置文件用systemctl daemon-reload
  • 用systemctl start mongod可測試服務是否可以成功運行
  • 如果不能運行則可以使用systemctl status mongod查看錯誤信息和其他服務信息。

如果無法啟動MongoDB,可檢查日志/home/dp/data/mongodb/log/mongod.log,如果是由于如下錯誤:

WiredTiger error (13) [1488260221:910792][6102:0x7f33bf806dc0], file:WiredTiger.wt, connection: /home/dp/data/db/WiredTiger.turtle: handle-open: open: Permission denied

可能是由于WiredTiger.turtle的權限不足,或所有者不是dp用戶,可以用chmod、chown、chgrp命令修改該文件的屬性。

使用systemctl enable mongod就可以將所編寫的服務添加至開機啟動。

三、MongoDB的安全配置

1. 修改登陸端口號和IP

在配置文件/home/dp/data/mongodb/config/mongod.conf下,定義:

net:
 bindIp: 127.0.0.1,192.168.117.55
 port: 7974 

2. 添加認證用戶

在剛安裝完畢的時候,MongoDB都默認有一個admin數據庫,此時admin數據庫是空的,沒有記錄權限相關的信息。當集合admin.system.users中一個用戶都沒有時,即使mongod啟動時添加了—auth參數,如果沒有在admin數據庫中添加用戶,此時不進行任何認證還是可以做任何操作(不管是否是以—auth 參數啟動),直到在admin.system.users中添加了一個用戶。加固的核心是只有在admin.system.users中添加用戶之后,mongodb的認證,授權服務才能生效。

步驟一:在未開啟認證的環境下,登錄到數據庫

[dp@fx]$ mongo 127.0.0.1:7974

步驟二:切換到admin數據庫

> use admin

步驟三:創建管理員賬號

>db.createUser({user:"ems",pwd:"jcid8$lcdcd",roles:["root"]})

新增的用戶在 db.system.users

> db.getCollectionNames()
[ "system.indexes", "system.users", "system.version" ]
  • 說明:
    1)MongoDB從V3版本開始取消使用addUser方法,采用db.createUser方法創建用戶;
    2)賬號不要設置為常見賬號,密碼需要滿足一定的復雜度,至少8位以上,包括大小寫字母、數字、特殊字符混合體,不要使用生日、姓名、身份證編號等常見密碼。

步驟四:驗證用戶是否創建成功

> db.auth("ems","jcid8$lcdcd")
1
> exit
bye

步驟五:殺掉進程,重啟mongoDB服務

四、Mongodb C drive安裝

1. 下載Mongodb C驅動文件解壓

下載地址為:
mongo-c-driver

2. 運行配置腳本

$ ./configure –disable-automatic-init-and-cleanup

3. 編譯

$ make

4. 安裝

 $ sudo make install
  • 注:使用 sudo 應先對dp用戶的sudo權限進行設置,命令為 # visudo

或者使用root用戶

# make install

安裝生成的頭文件在/usr/local/include/libmongoc-1.0下,庫文件在/usr/local/lib下。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容