阅读 136

MongoDB数据库安装部署及警告优化

大家好,本篇文章主要讲的是MongoDB数据库安装部署及警告优化,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览

目录
  • 1.软件下载

  • 2.部署MongoDB

    • 2.1.规划部署目录

    • 2.2.下载软件包

    • 2.3.安装MongoDB

    • 2.4.MongoDB配置文件介绍

    • 2.5.编写MongoDB配置文件

    • 2.6.启动MongoDB

    • 2.7.如何关闭MongoDB

    • 2.8.登录MongoDB

  • 3.优化MongoDB警告信息

    • 3.1.优化启动用户警告

    • 3.2.优化大内存页警告

      • 3.2.1.永久关闭大内存页

      • 3.2.2.临时关闭大内存页

    • 3.3.优化limit警告

    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

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

    2.部署MongoDB

    2.1.规划部署目录

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    程序目录
    [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.下载软件包

    1
    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下载后直接解压即可使用,不包含配置文件,需要自己创建

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    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

    2.4.MongoDB配置文件介绍

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    配置文件注解:
    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

    2.5.编写MongoDB配置文件

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    [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.启动MongoDB

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    1.启动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.查看进程和端口
    [root@mongodb-1 /data/mongodb_cluster]# ps aux | grep mongo
    [root@mongodb-1 /data/mongodb_cluster]# netstat -lnpt | grep mongo

    在这里插入图片描述

    2.7.如何关闭MongoDB

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

    两种方式关闭MongoDB

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    1.命令行关闭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.交互式关闭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

    2.8.登录MongoDB

    登录MongoDB需要使用mongo命令

    1
    2
    3
    4
    5
    6
    1.启动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

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

    在这里插入图片描述

    3.优化MongoDB警告信息

    3.1.优化启动用户警告

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

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

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

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    1.关闭MongoDB
    [root@mongodb-1 /data/mongodb_cluster]# ./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

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

    在这里插入图片描述

    3.2.优化大内存页警告

    告警内容:** 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'

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

    在这里插入图片描述

    3.2.1.永久关闭大内存页

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

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    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

    在这里插入图片描述

    1
    2
    3
    4
    5
    6
    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
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    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

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

    在这里插入图片描述

    3.3.优化limit警告

    告警内容:** 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设置的打开文件数太低

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    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数据库安装部署及警告优化的文章就介绍到这了

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


    文章分类
    代码人生
    版权声明:本站是系统测试站点,无实际运营。本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 XXXXXXo@163.com 举报,一经查实,本站将立刻删除。
    相关推荐