如何安装和配置MongoDB?
admin
2023-02-03 05:20:04
0

MongoDB简介

MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。
在高负载的情况下,添加更多的节点,可以保证服务器性能。
MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案。

安装MongoDB及配置

1、安装相关软件包
[root@centos-01 ~]# wget -b http://downloads.mongodb.org/linux/mongodb-linux-x86_64-3.6.14.tgz
[root@centos-01 ~]# tar zxvf mongodb-linux-x86_64-3.6.14.tgz
[root@centos-01 ~]# mv mongodb-linux-x86_64-3.6.14  /ust/local/mongodb
2、创建MongoDB的数据存储目录,日志存储目录
[root@centos-01 ~]# mkdir -p /data/mongodb/data
[root@centos-01 ~]# mkdir -p /data/logs/mongodb
[root@centos-01 ~]# ln -s /usr/local/mongodb/bin/* /usr/bin/
3、当MongoDB处于频繁访问的状态时,如果shell启动进程所占用的资源设置过低的话,将会产生错误导致无法连接到MongoDB实例。需设置ulimit -n和ulimit -u的值大于20000。
[root@centos-01 ~]# ulimit -n 25000
[root@centos-01 ~]# ulimit -u 25000
4、创建MongoDB配置文件,定义启动所需相关参数

[root@centos-01 ~]# vim /etc/mongodb.cnf
#系统日志
systemLog:
  #日志输出目的地,可以指定为 “file” 或者“syslog”
  destination: file
  #使用追加的方式写日志
  logAppend: true
  #日志存储目录
  path: /data/logs/mongodb/mongo.log

storage:
  #数据存储目录
  dbPath: /data/mongodb/data
  #是否开启 journal 日志持久存储,journal 日志用来数据恢复,是 mongod 最基础的特性,通常用于故障恢复
  journal:
    enabled: true
#  engine: wiredTiger
#  mmapv1:
#如下配置仅对 wiredTiger 引擎生效(3.0 以上版本)
  wiredTiger:
    engineConfig:
      #wiredTiger 缓存工作集(working set)数据的内存大小
      cacheSizeGB: 4
      #是否将索引和 collections 数据分别存储在 dbPath 单独的目录中
      directoryForIndexes: false
    collectionConfig:
      blockCompressor: zlib
    indexConfig:
      prefixCompression: false
# how the process runs
processManagement:
#以后台方式运行进程
  fork: true   
#PID File 的完整路径,如果没有设置,则没有PID文件
  pidFilePath: /data/mongodb/mongod.pid  
# network interfaces
net:
#默认服务器端口号
  port: 27017
#mongodb所绑定的ip地址
  bindIp: 127.0.0.1
security:
#表示是否开启用户访问控制
  authorization: enabled

#性能分析器
operationProfiling:
  #开启慢日志
  slowOpThresholdMs: 100
  mode: slowOp
#如果架构模式为 replication Set,那么还需要在所有的 “复制集”members 上增加如下配置:
#replication:
#  oplogSizeMB: 2048       
#  replSetName: mongodb      
#sharding:
## Enterprise-Only Options
#auditLog:

5、设置内核参数,关闭NUMA
[root@centos-01 ~]# echo 0 >/proc/sys/vm/zone_reclaim_mode            //当某个节点可用内存不足时系统会从其他节点分配内存
[root@centos-01 ~]# sysctl -w vm.zone_reclaim_mode=0                       //永久设置
6、mongodb启停
[root@centos-01 ~]#  mongod -f /etc/mongodb.cnf     //启动
[root@centos-01 ~]#  mongod -f /etc/mongodb.cnf --shutdown  //停止
[root@centos-01 ~]#  netstat -anpt | grep mongod
tcp        0      0 127.0.0.1:27017             0.0.0.0:*                   LISTEN      33475/mongod
7、设置为开机自动启动
[root@centos-01 ~]# echo "mongod -f /etc/mongodb.cnf"  >>  /etc/rc.local
8、进入MongoDB之后也可以这样关闭mongoDB

use admin;
db.shutdownServer();

9、为了便于运维人员管理,编写一个MongoDB数据库的控制脚本
[root@centos-01 ~]#  vim /etc/init.d/mongod
#!/bin/bash
PROG="/usr/local/mongodb/bin/mongod"
CONFIG=$1
CONF="/etc/$CONFIG.cnf"
case "$2" in
start)
  $PROG -f $CONF
  ;;
stop)
  $PROG -f $CONF --shutdown
  ;;
restart)
$0 stop
sleep 1
$0 start
sleep 1
echo "mongod has been restarted successfully"
;;
*)
   echo "Usage: $0 {start|stop|restart}"
   exit 2
esac
exit 0
[root@centos-01 ~]# chmod +x /etc/init.d/mongod
[root@centos-01 ~]# chkconfig --add mongod
[root@centos-01 ~]# /etc/init.d/mongod start

相关内容

热门资讯

德国总理:美国正在被伊朗羞辱 德国之声4月27日报道,德国总理默茨在访问一所学校时表示,在当前的持续冲突中,伊朗领导层正试图羞辱美...
理响中国|“长”歌以行,风云激... 光阴如梭,东方潮阔。这里是中国的长三角,世界的长三角。无论过去、现在还是未来,这片土地都因时代而生,...
白宫:特朗普及其国安团队开会讨... 新华社华盛顿4月27日电 美国白宫新闻秘书莱维特27日在记者会上证实,总统特朗普及其国家安全团队当天...
人民日报刊文:日本放开杀伤性武... 日本放开杀伤性武器出口推高地缘冲突风险(国际论坛)常思纯《人民日报》(2026年04月28日 第 0...
医疗保障法草案二审:明确生育保... 满足多样化健康保障需求本报记者 彭 波4月27日,医疗保障法草案二审稿提请十四届全国人大常委会第二十...
天津一景区发生自转旋翼机事故1... 澎湃新闻记者 吕新文中国民用航空华北地区管理局4月22日公布《豪客通航“10•1”天津长芦汉盐旅游区...
卡塔尔埃米尔与美国总统特朗普通... 当地时间24日,卡塔尔埃米尔塔米姆与美国总统特朗普通电话,重点就中东地区局势以及伊朗与美国谈判问题交...
男子30年前被扣押2859克黄... 澎湃新闻记者 王鑫家住辽宁省大连市的潘永嘉近日向澎湃新闻反映称,三十年前,他在大连周水子机场被盖州市...
商务部:取消反制欧盟两家金融机... 中华人民共和国商务部令二〇二六年 第1号鉴于欧盟已取消对中国两家金融机构的制裁措施,现公布《关于取消...
过去24小时共有5艘船只通过霍... 总台记者当地时间24日获悉,过去24小时内,共有5艘船只通过霍尔木兹海峡,其中包括一艘伊朗油轮。(总...