MongoDB数据库安装部署及警告优化(mongodb优势与缺点)学到了

随心笔谈2年前发布 编辑
157 0
🌐 经济型:买域名、轻量云服务器、用途:游戏 网站等 《腾讯云》特点:特价机便宜 适合初学者用 点我优惠购买
🚀 拓展型:买域名、轻量云服务器、用途:游戏 网站等 《阿里云》特点:中档服务器便宜 域名备案事多 点我优惠购买
🛡️ 稳定型:买域名、轻量云服务器、用途:游戏 网站等 《西部数码》 特点:比上两家略贵但是稳定性超好事也少 点我优惠购买



目录1.软件下载2.部署MongoDB2.1.规划部署目录2.2.下载软件包2.3.安装MongoDB2.4.MongoDB配置文件介绍2.5.编写MongoDB配置文件2.6.启动MongoDB2.7.如何关闭MongoDB2.8.登录MongoDB3.优化MongoDB警告信息3.1.优化启动用户警告3.2.优化大内存页警告3.2.1.永久关闭大内存页3.2.2.临时关闭大内存页3.3.优化limit警告

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

官网文档:https://docs.mongodb.com/manual/

程序目录
[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

[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

MongoDB下载后直接解压即可使用,不包含配置文件,需要自己创建

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.创建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

配置文件注解:
systemLog:
destination: file //Mongodb日志输出为文件
logAppend: true //当实例重启时,不创建新的日志文件, 在老的日志文件末尾继续添加
path: /data/mongodb_cluster/mongodb_27017/logs/mongodb.log //日志路径

storage:
journal: //回滚日志,类似于mysql的binlog
enabled: true //开启回滚日志
dbPath: /data/mongodb_cluster/mongodb_27017/data //数据存储目录
directoryPerDB: true //默认,false不适用inmemoryengine
wiredTiger: //存储引擎
engineConfig:
cacheSizeGB: 1 //将用于所有数据缓存的大小
directoryForIndexes: true //默认false索引集合storage.dbPath存储在数据单独子目录,这里必须配置为true,否则所有库的数据文件都会存放在一个目录中
collectionConfig:
blockCompressor: zlib //开启压缩
indexConfig:
prefixCompression: true //开启索引

processManagement: //系统守护进程控制处理
fork: true //后台运行
pidFilePath: /data/mongodb_cluster/mongodb_27017/pid/mongod.pid //pid文件路径

net:
port: 27017 //监听端口
bindIp: 127.0.0.1,192.168.81.210 //绑定ip

[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

1.启动MongoDB
[root@mongodb-1 ~]# cd /data/mongodb_cluster
[root@mongodb-1 /data/mongodb_cluster]# https://www.jb51.net/article/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.查看进程和端口
[root@mongodb-1 /data/mongodb_cluster]# ps aux | grep mongo
[root@mongodb-1 /data/mongodb_cluster]# netstat -lnpt | grep mongo

MongoDB数据库安装部署及警告优化(mongodb优势与缺点)学到了

直接用启动命令后面加一个–shutdown即可关闭MongoDB

两种方式关闭MongoDB

1.命令行关闭MongoDB
[root@mongodb-1 ~]# cd /data/mongodb_cluster
[root@mongodb-1 /data/mongodb_cluster]# https://www.jb51.net/article/mongodb/bin/mongod -f mongodb_27017/conf/mongodb.yml –shutdown
killing process with pid: 73550

2.交互式关闭MongoDB
[mongo@mongodb-1 ~]$mongo
> use admin
switched to db admin
> db.shutdownServer()

查看进程和端口
[root@mongodb-1 /data/mongodb_cluster]# ps aux | grep mongo
[root@mongodb-1 /data/mongodb_cluster]# netstat -lnpt | grep mongo

登录MongoDB需要使用mongo命令

1.启动MongoDB
[root@mongodb-1 ~]# cd /data/mongodb_cluster
[root@mongodb-1 /data/mongodb_cluster]# https://www.jb51.net/article/mongodb/bin/mongod -f mongodb_27017/conf/mongodb.yml

2.登录MongoDB
[root@mongodb-1 /data/mongodb_cluster]# https://www.jb51.net/article/mongodb/bin/mongo

登录后会有一些警告信息,我们再3里面进行优化

MongoDB数据库安装部署及警告优化(mongodb优势与缺点)学到了

警告内容:

这个警告内容就提示我们尽量不要用root直接启动,我们需要用普通用户启动

思路:创建一个普通用户,将MongoDB的部署目录赋权给普通用户,用普通用户启动即可

1.关闭MongoDB
[root@mongodb-1 /data/mongodb_cluster]# https://www.jb51.net/article/mongodb/bin/mongod -f mongodb_27017/conf/mongodb.yml –shutdown

2.创建用户
[root@mongodb-1 ~]# useradd mongo
[root@mongodb-1 ~]# echo “123456” | passwd –stdin mongo

3.赋权
[root@mongodb-1 ~]# chown -R mongo.mongo /data/mongodb_cluster/

4.登陆普通用户并配置环境变量
[root@mongodb-1 ~]# su – mongo
[mongo@mongodb-1 ~]$ vim .bashrc
export PATH=/data/mongodb_cluster/mongodb/bin/:$PATH
[mongo@mongodb-1 ~]$ source .bashrc

5.启动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

可以到启动用户的警告信息已经消失

MongoDB数据库安装部署及警告优化(mongodb优势与缺点)学到了

告警内容:

?

?

?

这是由于大内存设置了always,MongoDB建议使用never

MongoDB数据库安装部署及警告优化(mongodb优势与缺点)学到了

3.2.1.永久关闭大内存页

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

1.准备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.赋权并添加为开机自启
[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

MongoDB数据库安装部署及警告优化(mongodb优势与缺点)学到了

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.临时关闭大内存页

1.临时关闭内存页
[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

可以看到大内存页警告已经接解决

MongoDB数据库安装部署及警告优化(mongodb优势与缺点)学到了

告警内容:

提示的是limt设置的打开文件数太低

1.调整limit(此方法是不重启机器的情况下生效)
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

到此这篇关于MongoDB数据库安装部署及警告优化的文章就介绍到这了,更多相关MongoDB安装及警告优化内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:GoFrame代码优化gconv类型转换避免重复定义mapDjango项目优化数据库操作总结go select编译期的优化处理逻辑使用场景分析Django程序的优化技巧python3 googletrans超时报错问题及翻译工具优化方案 附源码详解Django中views数据查询使用locals()函数进行优化Django serializer优化类视图的实现示例浅谈优化Django ORM中的性能问题Go?内联优化让程序员爱不释手

© 版权声明

相关文章