日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無(wú)先后,達(dá)者為師

網(wǎng)站首頁(yè) 編程語(yǔ)言 正文

MongoDB數(shù)據(jù)庫(kù)安裝部署及警告優(yōu)化_MongoDB

作者:Jiangxl~ ? 更新時(shí)間: 2022-02-10 編程語(yǔ)言

1.軟件下載

3.6.13版本:https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.6.13.tgz

4.0.14版本:https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-4.0.14.tgz

官網(wǎng)文檔:https://docs.mongodb.com/manual/

2.部署MongoDB

2.1.規(guī)劃部署目錄

程序目錄
[root@mongodb-1 ~]# mkdir /data/mongodb_cluster/mongodb_27017/{conf,data,logs,pid} -p

軟件目錄
[root@mongodb-1 ~]# mkdir /data/soft

[root@mongodb-1 ~]# tree /data/
/data/
├── mongodb_cluster
│   └── mongodb_27017
│       ├── conf
│       ├── data
│       ├── logs
│       └── pid
└── soft

7 directories, 0 files

2.2.下載軟件包

[root@mongodb-1 ~]# cd /data/soft/
[root@mongodb-1 /data/soft]# wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-4.0.14.tgz

2.3.安裝MongoDB

MongoDB下載后直接解壓即可使用,不包含配置文件,需要自己創(chuàng)建

1.解壓MongoDB
[root@mongodb-1 /data/soft]# tar xf mongodb-linux-x86_64-4.0.14.tgz -C /data/mongodb_cluster/

2.制作軟連接
[root@mongodb-1 /data/soft]# cd /data/mongodb_cluster/
[root@mongodb-1 /data/mongodb_cluster]# ln -s mongodb-linux-x86_64-4.0.14/ mongodb

3.創(chuàng)建MongoDB配置文件目錄
[root@mongodb-1 ~]# mkdir /data/mongodb_cluster/mongodb_27017/{conf,data,logs,pid} -p
[root@mongodb-1 ~]# tree /data/ -d
/data/
├── mongodb_cluster
│   ├── mongodb -> mongodb-linux-x86_64-4.0.14/
│   ├── mongodb_27017
│   │   ├── conf
│   │   ├── data
│   │   ├── logs
│   │   └── pid
│   └── mongodb-linux-x86_64-4.0.14
│       └── bin
└── soft

2.4.MongoDB配置文件介紹

配置文件注解:
systemLog:
  destination: file 	//Mongodb日志輸出為文件
  logAppend: true 			//當(dāng)實(shí)例重啟時(shí),不創(chuàng)建新的日志文件, 在老的日志文件末尾繼續(xù)添加
  path: /data/mongodb_cluster/mongodb_27017/logs/mongodb.log 		//日志路徑

storage:
  journal: 				//回滾日志,類似于mysql的binlog
    enabled: true			//開啟回滾日志
  dbPath: /data/mongodb_cluster/mongodb_27017/data 		//數(shù)據(jù)存儲(chǔ)目錄
  directoryPerDB: true 		//默認(rèn),false不適用inmemoryengine
  wiredTiger:				//存儲(chǔ)引擎
    engineConfig:
      cacheSizeGB: 1 		//將用于所有數(shù)據(jù)緩存的大小
      directoryForIndexes: true 	//默認(rèn)false索引集合storage.dbPath存儲(chǔ)在數(shù)據(jù)單獨(dú)子目錄,這里必須配置為true,否則所有庫(kù)的數(shù)據(jù)文件都會(huì)存放在一個(gè)目錄中
    collectionConfig:
      blockCompressor: zlib			//開啟壓縮
    indexConfig:	
      prefixCompression: true			//開啟索引

processManagement: 			//系統(tǒng)守護(hù)進(jìn)程控制處理
  fork: true 			//后臺(tái)運(yùn)行
  pidFilePath: /data/mongodb_cluster/mongodb_27017/pid/mongod.pid   //pid文件路徑

net:
  port: 27017 			//監(jiān)聽端口
  bindIp: 127.0.0.1,192.168.81.210			//綁定ip

2.5.編寫MongoDB配置文件

[root@mongodb-1 ~]# cd /data/mongodb_cluster/mongodb_27017/
[root@mongodb-1 /data/mongodb_cluster/mongodb_27017]# vim conf/mongodb.yml
systemLog:
  destination: file
  logAppend: true
  path: /data/mongodb_cluster/mongodb_27017/logs/mongodb.log

storage:
  journal:
    enabled: true
  dbPath: /data/mongodb_cluster/mongodb_27017/data
  directoryPerDB: true
  wiredTiger:
    engineConfig:
      cacheSizeGB: 1
      directoryForIndexes: true
    collectionConfig:
      blockCompressor: zlib
    indexConfig:
      prefixCompression: true

processManagement:
  fork: true
  pidFilePath: /data/mongodb_cluster/mongodb_27017/pid/mongod.pid

net:
  port: 27017
  bindIp: 127.0.0.1,192.168.81.210

2.6.啟動(dòng)MongoDB

1.啟動(dòng)MongoDB
[root@mongodb-1 ~]# cd /data/mongodb_cluster
[root@mongodb-1 /data/mongodb_cluster]# ./mongodb/bin/mongod -f mongodb_27017/conf/mongodb.yml 
about to fork child process, waiting until server is ready for connections.
forked process: 73550
child process started successfully, parent exiting

2.查看進(jìn)程和端口
[root@mongodb-1 /data/mongodb_cluster]# ps aux | grep mongo
[root@mongodb-1 /data/mongodb_cluster]# netstat -lnpt | grep mongo

在這里插入圖片描述

2.7.如何關(guān)閉MongoDB

直接用啟動(dòng)命令后面加一個(gè)–shutdown即可關(guān)閉MongoDB

兩種方式關(guān)閉MongoDB

1.命令行關(guān)閉MongoDB
[root@mongodb-1 ~]# cd /data/mongodb_cluster
[root@mongodb-1 /data/mongodb_cluster]# ./mongodb/bin/mongod -f mongodb_27017/conf/mongodb.yml --shutdown
killing process with pid: 73550

2.交互式關(guān)閉MongoDB
[mongo@mongodb-1 ~]$mongo
> use admin
switched to db admin
> db.shutdownServer()

查看進(jìn)程和端口
[root@mongodb-1 /data/mongodb_cluster]# ps aux | grep mongo
[root@mongodb-1 /data/mongodb_cluster]# netstat -lnpt | grep mongo

2.8.登錄MongoDB

登錄MongoDB需要使用mongo命令

1.啟動(dòng)MongoDB
[root@mongodb-1 ~]# cd /data/mongodb_cluster
[root@mongodb-1 /data/mongodb_cluster]# ./mongodb/bin/mongod -f mongodb_27017/conf/mongodb.yml 

2.登錄MongoDB
[root@mongodb-1 /data/mongodb_cluster]# ./mongodb/bin/mongo

登錄后會(huì)有一些警告信息,我們?cè)?里面進(jìn)行優(yōu)化

在這里插入圖片描述

3.優(yōu)化MongoDB警告信息

3.1.優(yōu)化啟動(dòng)用戶警告

警告內(nèi)容:2021-02-13T10:44:47.832+0800 I CONTROL [initandlisten] ** WARNING: You are running this process as the root user, which is not recommended.

這個(gè)警告內(nèi)容就提示我們盡量不要用root直接啟動(dòng),我們需要用普通用戶啟動(dòng)

思路:創(chuàng)建一個(gè)普通用戶,將MongoDB的部署目錄賦權(quán)給普通用戶,用普通用戶啟動(dòng)即可

1.關(guān)閉MongoDB
[root@mongodb-1 /data/mongodb_cluster]# ./mongodb/bin/mongod -f mongodb_27017/conf/mongodb.yml --shutdown

2.創(chuàng)建用戶
[root@mongodb-1 ~]# useradd mongo
[root@mongodb-1 ~]# echo "123456" | passwd --stdin mongo

3.賦權(quán)
[root@mongodb-1 ~]# chown -R mongo.mongo /data/mongodb_cluster/

4.登陸普通用戶并配置環(huán)境變量
[root@mongodb-1 ~]# su - mongo
[mongo@mongodb-1 ~]$ vim .bashrc
export PATH=/data/mongodb_cluster/mongodb/bin/:$PATH
[mongo@mongodb-1 ~]$ source .bashrc

5.啟動(dòng)MongoDB
[mongo@mongodb-1 ~]$ mongod -f /data/mongodb_cluster/mongodb_27017/conf/mongodb.yml 
about to fork child process, waiting until server is ready for connections.
forked process: 73835
child process started successfully, parent exiting

6.登陸MongoDB
[mongo@mongodb-1 ~]$ mongo

可以到啟動(dòng)用戶的警告信息已經(jīng)消失

在這里插入圖片描述

3.2.優(yōu)化大內(nèi)存頁(yè)警告

告警內(nèi)容:** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.

? ** We suggest setting it to 'never'

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

? ** We suggest setting it to 'never'

這是由于大內(nèi)存設(shè)置了always,MongoDB建議使用never

在這里插入圖片描述

3.2.1.永久關(guān)閉大內(nèi)存頁(yè)

官方文檔:https://docs.mongodb.com/manual/tutorial/transparent-huge-pages/

1.準(zhǔn)備init腳本
[root@mongodb-1 ~]# 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' | tee ${thp_path}/enabled > /dev/null

    unset thp_path
    ;;
esac

2.賦權(quán)并添加為開機(jī)自啟
[root@mongodb-1 ~]# chmod 755 /etc/init.d/disable-transparent-hugepages
[root@mongodb-1 ~]# chkconfig --add disable-transparent-hugepages
[root@mongodb-1 ~]# chkconfig --list | grep disa

在這里插入圖片描述

3.重啟MongoDB
[mongo@mongodb-1 ~]$ mongod -f /data/mongodb_cluster/mongodb_27017/conf/mongodb.yml --shutdown
[mongo@mongodb-1 ~]$ mongod -f /data/mongodb_cluster/mongodb_27017/conf/mongodb.yml 

4.登陸mongdo查看警告
[mongo@mongodb-1 ~]$ mongo

3.2.2.臨時(shí)關(guān)閉大內(nèi)存頁(yè)

1.臨時(shí)關(guān)閉內(nèi)存頁(yè)
[root@mongodb-1 ~]# echo "never" > /sys/kernel/mm/transparent_hugepage/enabled
[root@mongodb-1 ~]# echo "never" > /sys/kernel/mm/transparent_hugepage/defrag
[root@mongodb-1 ~]# cat /sys/kernel/mm/transparent_hugepage/enabled 
always madvise [never]
[root@mongodb-1 ~]# cat /sys/kernel/mm/transparent_hugepage/defrag 
always madvise [never]

2.重啟MongoDB
[root@mongodb-1 ~]# su - mongo
[mongo@mongodb-1 ~]$ mongod -f /data/mongodb_cluster/mongodb_27017/conf/mongodb.yml --shutdown
[mongo@mongodb-1 ~]$ mongod -f /data/mongodb_cluster/mongodb_27017/conf/mongodb.yml

3.登陸MongoDB查看告警
[mongo@mongodb-1 ~]$ mongo

可以看到大內(nèi)存頁(yè)警告已經(jīng)接解決

在這里插入圖片描述

3.3.優(yōu)化limit警告

告警內(nèi)容:** WARNING: soft rlimits too low. rlimits set to 15324 processes, 65535 files. Number of processes should be at least 32767.5: 0.5 times number of files.

提示的是limt設(shè)置的打開文件數(shù)太低

1.調(diào)整limit(此方法是不重啟機(jī)器的情況下生效)
cat > /etc/profile<<EOF
ulimit -f unlimited
ulimit -t unlimited
ulimit -v unlimited
ulimit -n 64000
ulimit -m unlimited
ulimit -u 64000
EOF

source /etc/profile

2.重啟MongoDB
[root@mongodb-1 ~]# su - mongo
[mongo@mongodb-1 ~]$ mongod -f /data/mongodb_cluster/mongodb_27017/conf/mongodb.yml --shutdown
[mongo@mongodb-1 ~]$ mongod -f /data/mongodb_cluster/mongodb_27017/conf/mongodb.yml


原文鏈接:https://blog.csdn.net/weixin_44953658/article/details/121925964

欄目分類
最近更新