一、Mongodb安裝
以下安裝步驟以dp用戶執行
1. 下載mongodb/107301.html">mongodb/44419.html">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
啟動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: truestorage:##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##端口配置,將默認端口設為7974(默認為27017)net: port: 7974
2. 取消透明大頁:
MongoDB建議關閉Linux系統默認開啟的透明大頁功能,可編輯rc.local文件,使其在系統啟動的時候關閉:
編輯rc.local文件:
[root@localhost ~]# 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 serverAfter=network.targetAfter=syslog.target[Service] #Type=forking #一次性啟動,mongod的后臺保持由mongod自己的配置文件中定義Type=oneshotUser=dp#PIDFile=/home/dp/data/mongodb/pidExecStart=/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進行配置:
如果無法啟動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: 79742017/3/8 16:59:55 2017/3/8 16:59:58
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:"pubugou2017",roles:["root"]})
新增的用戶在 db.system.users 中
> db.getCollectionNames()[ "system.indexes", "system.users", "system.version" ]
說明:
1)MongoDB從V3版本開始取消使用addUser方法,采用db.createUser方法創建用戶;
2)賬號不要設置為常見賬號,密碼需要滿足一定的復雜度,至少8位以上,包括大小寫字母、數字、特殊字符混合體,不要使用生日、姓名、身份證編號等常見密碼。
步驟四:驗證用戶是否創建成功
> db.auth("supper","supWDxsf67%H")1> exitbye
步驟五:殺掉進程,重啟mongoDB服務
四、Mongodb C drive安裝
1. 下載Mongodb C驅動文件解壓
下載地址為:mongo-c-driver 1.61
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下。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。
新聞熱點
疑難解答
圖片精選