linux: mogodb 3.4 安裝配置

mongodb 3.X安裝詳細過程

一、準備安裝

mongodb的安裝方式,我通常使用二進制包的方式,內網不能配置連接外網的yum源

官方下載地址:

https://www.mongodb.org/dl/linux/x86_64

下載mongodb-linux-x86_64-3.4.5.tgz

如果將整個mongodb安裝過程已經編寫了腳本,可以獲取安裝腳本,用腳本執行安裝;

如果手動安裝,則可跳過此步;

手工安裝mongodb的腳步的執行過程,一般如下:

1.mkdir -p /root/{software,scripts}

2.wget -q http://ptmaster.test.cn/files/init/mongodb_install.sh -O /root/scripts/mongodb_install.sh

3.cd /root/scripts

4./mongodb_install.sh -p 27117

二、添加mongodb用戶和環境變量,修改系統設置

添加用戶:

groupadd mongodb

useradd -g mongodb mongodb

創建mongodb腳本目錄

mkdir -p /home/mongodb/scripts/

修改目錄權限:

chown -R mongodb:mongodb /home/mongodb/scripts/

在 /etc/profile 中添加 mongodb 用戶的環境變量:

# MongoDB Environment Variables

export PATH=$PATH:$HOME/bin:/usr/local/mongodb/bin:/home/mongodb/scripts/

讓上面的變量生效:

source /etc/profile

mongodb要求hugepage設置為禁用,soft limit設置足夠大,可以在一開始修改,也可以到后面修改

cat /etc/security/limits.d/90-nproc.conf

修改這個文件中下列的值

* soft nproc 2048

確保: soft nproc 的值至少是 soft nofile 值的一半;

修改后,退出當前用戶,重新進入一下,設置就可以生效了;

禁用 hugepage 的值:

# echo "never" > /sys/kernel/mm/transparent_hugepage/enabled

# echo "never" > /sys/kernel/mm/transparent_hugepage/defrag

三、安裝mongodb軟件

上傳并解壓軟件:

cd /usr/local

rz mongodb-linux-x86_64-3.4.5.tgz

tar -zxvf mongodb-linux-x86_64-3.4.5.tgz

ln -sv mmongodb-linux-x86_64-3.4.5.tgz /usr/local/mongodb

修改文件權限:

chown -R mongodb:mongodb mmongodb-linux-x86_64-3.4.5.tgz

chown -R mongodb:mongodb /usr/local/mongodb

四、創建mongodb實例所需的目錄和配置文件

創建mongodb實例所需目錄

mkdir -p /data/mongo_27117/{db,log,tmp}

創建mongodb實例配置文件所需目錄和文件:

mkdir -p /etc/mongodb

touch /etc/mongodb/mongo_27117.conf

五、啟動mongodb實例,修改管理員密碼

使用下面的命令啟動mongodb服務:

/usr/local/mongodb/bin/mongod --config /etc/mongodb/mongo_27117.conf

確認密碼,mongodb的管理員密碼,可以根據各自的規則設置:

echo $MONGODB_ROOT_PASS

mongodb_020248_Pass

修改管理員密碼,注意 mongodb 3.2要對admin授予三個角色,這點與之前的版本不同:

1、/usr/local/mongodb/bin/mongo --port=27117

2、 use admin;

3、db.system.users.find();

4、db.createUser({user:'useradmin',pwd:'mongodb_020248_@JJMatch',roles:[ { "role" : "clusterAdmin", "db" : "admin" }, { "role" : "userAdminAnyDatabase", "db" : "admin" }, { "role" : "dbAdminAnyDatabase", "db" : "admin" } ] })

5、db.system.users.find();

6、db.auth("useradmin","mongodb_020248_@JJMatch")

7、db.system.users.find();

8、/usr/local/mongodb/bin/mongo --port=27117 -u useradmin -p mongodb_020248_@JJMatch --authenticationDatabase admin

9、use admin;

10、db.system.users.find();

生成密碼后,使用新用戶和密碼登陸mongo,確認狀態:

/usr/local/mongodb/bin/mongo --port=27117 -u useradmin -p mongodb_020248_@JJMatch --authenticationDatabase admin

六、為應用創建業務賬號

創建一個 admin / admin 用戶,具有可以自行創建用戶和數據庫的權限,密碼業務自己再修改:

db.createUser({user:'admin',pwd:'admin',roles:[{role:'userAdminAnyDatabase',db:'admin'},{role:'dbAdminAnyDatabase',db:'admin'}]})

驗證業務賬號登陸:

/usr/local/mongodb/bin/mongo --port=27117 -u admin -p admin --authenticationDatabase admin

七、實例啟動時的報警處理

在mongodb啟動過程中,有時會提示一些警告,其中常見的兩類警告處理過程如下:

警告1:

提示:

2016-10-19T12:12:59.097+0800 I CONTROL [initandlisten] ** WARNING: soft rlimits too low. rlimits set to 2048 processes, 8192 files. Number of processes should be at least 4096 : 0.5 times number of files.

處理方式,根據提示,將 processes 值,由現在的 2048,修改為4096,甚至更高的值。

ps -ef|grep mongod

cat /proc/32321/limits

cat /etc/security/limits.d/90-nproc.conf

vim /etc/security/limits.d/90-nproc.conf

實際操作如下

cat /etc/security/limits.d/90-nproc.conf

vim /etc/security/limits.d/90-nproc.conf

* soft nproc 8192

* hard nproc 16384

ulimit -a

警告2:

** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.

I CONTROL [initandlisten] ** We suggest setting it to 'never'

I CONTROL [initandlisten]

I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.

I CONTROL [initandlisten] ** We suggest setting it to 'never'

確認:

cat /sys/kernel/mm/transparent_hugepage/enabled

cat /sys/kernel/mm/transparent_hugepage/defrag

處理:

echo "never" > /sys/kernel/mm/transparent_hugepage/enabled

echo "never" > /sys/kernel/mm/transparent_hugepage/defrag

八、創建mongodb實例服務管理腳本

為了方便對mongodb實例的啟動和停止,可以先創建mongodb的啟動腳本,停止腳本,然后在 /etc/init.d/ 目錄下創建一個服務腳本,這樣就可以用 service 進行實例管理了。

腳本1:啟動腳本:

vim /home/mongodb/scripts/mongodb_start.sh

#!/bin/sh

# the scripts is used to start mongodb instance with port 27117.

# created by zhaofx on 20161019.

echo -n "Starting MongoDB port 27117 ... "

/usr/local/mongodb/bin/mongod --config /etc/mongodb/mongo_27117.conf &

腳本二:停止腳本:

vim /home/mongodb/scripts/mongodb_stop.sh

#!/bin/bash

# the scripts is used to stop mongodb instance with port 27117.

# created by zhaofx on 20161019.

echo -n "Stopping MongoDB port 27117"

pid=`ps -o pid,command ax | grep mongod | awk '!/awk/ && !/grep/ {print $1}'`;

if [ "${pid}" != "" ]; then

kill -2 ${pid};

fi

腳本三:服務腳本:

vim /etc/init.d/mongodb

vim /etc/init.d/mongodb

#! /bin/sh

# the scripts is used to mange mongodb service with linux service type.

# created by zhaofx on 20161019.

PATH=/usr/local/mongodb/bin:/sbin:/bin:/usr/sbin:/usr/bin

NAME=mongodb

start(){

/home/mongodb/scripts/mongodb_start.sh

}

stop(){

/home/mongodb/scripts/mongodb_stop.sh

}

test -x $DAEMON || exit 0

set -e

case "$1" in

start)

start

;;

stop)

stop

;;

*)

N=/etc/init.d/$NAME

echo "Usage: $N {start|stop}" >&2

exit 1

;;

esac

exit 0

修改腳本的屬組,添加執行權限:

chown -R mongodb:mongodb /home/mongodb/scripts/

chown mongodb:mongodb /etc/init.d/mongodb

chmod +x /home/mongodb/scripts/mongodb_start.sh

chmod +x /home/mongodb/scripts/mongodb_stop.sh

chmod +x /etc/init.d/mongodb

最后服務啟動和停止mongodb實例的過程為:

service mongodb stop

service mongodb start

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

推薦閱讀更多精彩內容