一匠抗、系統(tǒng)及安裝說明
系統(tǒng):CentOS6.x_x64铃剔,mongodb-3.4.10。
mongodb官方下載地址 :
[https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel62-3.4.10.tgz]
(http://www.memcached.org/files/memcached-1.5.3.tar.gz)析恢。
本次安裝選擇編輯yum安裝孽椰。
二欲鹏、配置官方y(tǒng)um庫
1>創(chuàng)建yum安裝庫文件
修改文件mongodb-3.4.repo
vim /etc/yum.repos.d/mongodb-org-3.4.repo #創(chuàng)建之后可以直接使用yum安裝
添加下面的內(nèi)容,wq保存凡泣。
[mongodb-org-3.4]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/3.4/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-3.4.asc
當(dāng)設(shè)置gpgcheck=0時(shí),gpgkey路徑可以不設(shè)置
2>yum安裝
#yum install -y mongodb-org
#當(dāng)出現(xiàn)以下即為安裝中
三皮假、自定義安裝配置
1>安裝成功后鞋拟,數(shù)據(jù)和日志目錄默認(rèn)是在 /var/lib/mongo 和 /var/log/mongodb,為方便管理我們可進(jìn)行自定義惹资。以 /data/mongodb 為例
2>編輯/etc/mongod.conf
#vim /etc/mongod.conf
# mongod.conf
# for documentation of all options, see:
# http://docs.mongodb.org/manual/reference/configuration-options/
# where to write logging data.
systemLog:
destination: ``file
logAppend: ``true
path: ``/data/mongodb/log/mongod``.log
# Where and how to store data.
storage:
dbPath: ``/data/mongodb/data
journal:
enabled: ``true
# engine:
# mmapv1:
# wiredTiger:
# how the process runs
processManagement:
fork: ``true
# fork and run in background
pidFilePath: ``/var/run/mongodb/mongod``.pid ``# location of pidfile
# network interfaces
net:
port: 27017
bindIp: 127.0.0.1 ``# Listen to local interface only, comment to listen on all interfaces.
#security:
#operationProfiling:
#replication:
#sharding:
## Enterprise-Only Options
#auditLog:
#snmp
3>創(chuàng)建目錄
#mkdir -p /data/mongodb/data
#mkdir -p /data/mongodb/log
#chown mongod.mongod /data/mongodb -R #修改權(quán)限贺纲,否則mongo有可能啟動不了
四、啟動并測試
1>啟動mongod
#service mongod start|stop|restart
2>添加到開機(jī)啟動項(xiàng)
#chkconfig --add mongod
#chkconfig mongod on
3>登錄測試
#mongo --host 127.0.0.1
MongoDB shell version v3.4.10
connecting to: mongodb:``//127``.0.0.1:27017/
MongoDB server version: 3.4.10
Server has startup warnings:
2017-12-06T10:41:30.462+0800 I STORAGE [initandlisten]
2017-12-06T10:41:30.462+0800 I STORAGE [initandlisten] ** WARNING: Using the XFS filesystem is strongly recommended with the WiredTiger storage engine
2017-12-06T10:41:30.462+0800 I STORAGE [initandlisten] ** See http:``//dochub``.mongodb.org``/core/prodnotes-filesystem
2017-12-06T10:41:30.901+0800 I CONTROL [initandlisten]
2017-12-06T10:41:30.902+0800 I CONTROL [initandlisten] ** WARNING: Access control is not enabled ``for
the database.
2017-12-06T10:41:30.902+0800 I CONTROL [initandlisten] ** Read and write access to data and configuration is unrestricted.
2017-12-06T10:41:30.902+0800 I CONTROL [initandlisten]
2017-12-06T10:41:30.902+0800 I CONTROL [initandlisten]
2017-12-06T10:41:30.902+0800 I CONTROL [initandlisten] ** WARNING: ``/sys/kernel/mm/transparent_hugepage/enabled
is ``'always'``.
2017-12-06T10:41:30.902+0800 I CONTROL [initandlisten] ** We suggest setting it to ``'never'
2017-12-06T10:41:30.902+0800 I CONTROL [initandlisten]
2017-12-06T10:41:30.902+0800 I CONTROL [initandlisten] ** WARNING: ``/sys/kernel/mm/transparent_hugepage/defrag
is ``'always'``.
2017-12-06T10:41:30.902+0800 I CONTROL [initandlisten] ** We suggest setting it to ``'never'
2017-12-06T10:41:30.902+0800 I CONTROL [initandlisten]
2017-12-06T10:41:30.902+0800 I CONTROL [initandlisten] ** WARNING: soft rlimits too low. rlimits ``set
to 1024 processes, 65535 files. Number of processes should be at least 32767.5 : 0.5 ``times
number of files.
2017-12-06T10:41:30.902+0800 I CONTROL [initandlisten]
> show dbs
admin 0.000GB
local
0.000GB
>
五褪测、問題排錯(cuò)
1> 登錄mongodb數(shù)據(jù)庫時(shí)猴誊,如果出現(xiàn)以下錯(cuò)誤
MongoDB shell version v3.4.10
connecting to: mongodb:``//127``.0.0.1:27017
MongoDB server version: 3.4.10
Server has startup warnings:
2017-12-06T10:46:46.575+0800 I STORAGE [initandlisten]
2017-12-06T10:46:46.575+0800 I STORAGE [initandlisten] ** WARNING: Using the XFS filesystem is strongly recommended with the WiredTiger storage engine
2017-12-06T10:46:46.575+0800 I STORAGE [initandlisten] ** See http:``//dochub``.mongodb.org``/core/prodnotes-filesystem
2017-12-06T10:46:46.955+0800 I CONTROL [initandlisten]
2017-12-06T10:46:46.955+0800 I CONTROL [initandlisten] ** WARNING: Access control is not enabled ``for
the database.
2017-12-06T10:46:46.955+0800 I CONTROL [initandlisten] ** Read and write access to data and configuration is unrestricted.
2017-12-06T10:46:46.955+0800 I CONTROL [initandlisten]
2017-12-06T10:46:46.956+0800 I CONTROL [initandlisten]
2017-12-06T10:46:46.956+0800 I CONTROL [initandlisten] ** WARNING: ``/sys/kernel/mm/transparent_hugepage/enabled
is ``'always'``.
2017-12-06T10:46:46.956+0800 I CONTROL [initandlisten] ** We suggest setting it to ``'never'
2017-12-06T10:46:46.956+0800 I CONTROL [initandlisten]
2017-12-06T10:46:46.956+0800 I CONTROL [initandlisten] ** WARNING: ``/sys/kernel/mm/transparent_hugepage/defrag
is ``'always'``.
2017-12-06T10:46:46.956+0800 I CONTROL [initandlisten] ** We suggest setting it to ``'never'
2017-12-06T10:46:46.956+0800 I CONTROL [initandlisten]
2017-12-06T10:46:46.956+0800 I CONTROL [initandlisten] ** WARNING: soft rlimits too low. rlimits ``set
to 1024 processes, 65535 files. Number of processes should be at least 32767.5 : 0.5 ``times
number of files.
環(huán)境不通解決辦法也不通,詳情請參照官方文檔 https://docs.mongodb.com/manual/tutorial/transparent-huge-pages/
2>創(chuàng)建腳本
vim /etc/init.d/disable-transparent-hugepages
#!/bin/bash### BEGIN INIT INFO
# Provides: disable-transparent-hugepages
# Required-Start: $local_fs
# Required-Stop:
# X-Start-Before: mongod mongodb-mms-automation-agent
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Disable Linux transparent huge pages
# Description: Disable Linux transparent huge pages, to improve
# database performance.
### END INIT INFO
case
$1 ``in
start)
if
[ -d ``/sys/kernel/mm/transparent_hugepage
]; ``then
thp_path=``/sys/kernel/mm/transparent_hugepage
elif
[ -d ``/sys/kernel/mm/redhat_transparent_hugepage
]; ``then
thp_path=``/sys/kernel/mm/redhat_transparent_hugepage
else
return
0
fi
echo
'never'
> ${thp_path}``/enabled
echo
'never'
> ${thp_path}``/defrag
re=``'^[0-1]+$'
if
[[ $(``cat
${thp_path}``/khugepaged/defrag``) =~ $re ]]
then
# RHEL 7
echo
0 > ${thp_path}``/khugepaged/defrag
else
# RHEL 6
echo
'no'
> ${thp_path}``/khugepaged/defrag
fi
unset
re ``unset
thp_path ;;
esac
添加到開機(jī)服務(wù)
#chmod +x /etc/init.d/disable-transparent-hugepages
#chkconfig --add disable-transparent-hugepages
3>創(chuàng)建編輯 /etc/tune-profiles/no-thp/ktune.sh
vim /etc/tune-profiles/no-thp/ktune.sh
#echo "set_transparent_hugepages never" > ktune.sh
#chmod +x ktune.sh
#tuned-adm profile no-thp
#如果提示找不到命令請執(zhí)行yum install tuned -y
vim /etc/security/limits.conf
添加
mongod soft nofile 64000
mongod hard nofile 64000
mongod soft nproc 32000
mongod hard nproc 32000
重啟系統(tǒng) sudo reboot