mongoDB 启动与停止

mongoDB 启动与停止MongoDB 是一个基于分布式文件存储的数据库 由 C 语言编写 旨在为 WEB 应用提供可扩展的高性能数据存储解决方案 它以高性能 易部署 易使用 存储数据非常方便等优点被广泛使用 其安装配置相当简单 有如轻量级的 mysql 但功能丝毫不差 本文主要描述 mongoDB 的启动与停止

MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。它以高性能、易部署、易使用,存储数据非常方便等优点被广泛使用。其安装配置相当简单,有如轻量级的mysql,但功能丝毫不差。本文主要描述mongoDB的启动与停止。

一、准备环境

1、当前环境 # more /etc/redhat-release  CentOS release 6.7 (Final)
2、安装mongod # which mongod /var/lib/mongodb/bin/mongod
3、创建数据目录 # mkdir -pv /data/mongodata/{rs1,rs2,rs3} # mkdir -pv /var/lib/mongodb/conf

二、启动mongodb

1、基于命令行方式启动mongodb # mongod --dbpath=/data/mongodata/rs1 --logpath=/data/mongodata/rs1/rs1.log & 缺省端口为 [root@node3 rs1]# netstat -nltp|grep mongod tcp 0 0 0.0.0.0:27017 0.0.0.0:* LISTEN 5062/mongod 2、基于配置文件的命令行启动 vi /var/lib/mongodb/conf/rs2.conf port = 27000 dbpath = /data/mongodata/rs2 logpath = /data/mongodata/rs2/rs2.log smallfiles = true fork = true pidfilepath = /var/run/mongo.pid # mongod --config /var/lib/mongodb/conf/rs2.conf &  Author : Leshami  Blog : http://blog.csdn.net/leshami # netstat -nltp|grep 27000 tcp 0 0 0.0.0.0:27000 0.0.0.0:* LISTEN 5356/mongod 3、以守护进程方式启动mongodb # mongod --dbpath=/data/mongodata/rs3 --logpath=/data/mongodata/rs1/rs3.log --fork --port 28000 # netstat -nltp|grep mongod tcp 0 0 0.0.0.0:28000 0.0.0.0:* LISTEN 5465/mongod tcp 0 0 0.0.0.0:27017 0.0.0.0:* LISTEN 5435/mongod tcp 0 0 0.0.0.0:27000 0.0.0.0:* LISTEN 5448/mongod 4、使用系统服务的方式启动mogodb 启动脚本 # vi /etc/init.d/mongod #!/bin/sh  # chkconfig: 2345 93 18  #MogoDB home directory  MONGODB_HOME=/var/lib/mongodb #mongodb command  MONGODB_BIN=$MONGODB_HOME/bin/mongod #mongodb config file MONGODB_CONF=$MONGODB_HOME/conf/mongodb.conf #mongodb PID MONGODB_PID=/var/run/mongo.pid #set open file limit SYSTEM_MAXFD=65535 MONGODB_NAME="mongodb" . /etc/rc.d/init.d/functions if [ ! -f $MONGODB_BIN ] then echo "$MONGODB_NAME startup: $MONGODB_BIN not exists! " exit fi start(){ ulimit -HSn $SYSTEM_MAXFD $MONGODB_BIN --config="$MONGODB_CONF" --fork added @ ret=$? if [ $ret -eq 0 ]; then action $"Starting $MONGODB_NAME: " /bin/true else action $"Starting $MONGODB_NAME: " /bin/false fi } stop(){ PID=$(ps aux |grep "$MONGODB_NAME" |grep "$MONGODB_CONF" |grep -v grep |wc -l) if [[ $PID -eq 0 ]];then action $"Stopping $MONGODB_NAME: " /bin/false exit fi kill -HUP `cat $MONGODB_PID` ret=$? if [ $ret -eq 0 ]; then action $"Stopping $MONGODB_NAME: " /bin/true rm -f $MONGODB_PID else action $"Stopping $MONGODB_NAME: " /bin/false fi } restart() { stop sleep 2 start } case "$1" in start) start ;; stop) stop ;; status) status $prog ;; restart) restart ;; *) echo $"Usage: $0 {start|stop|status|restart}" esac # chmod u+x /etc/init.d/mongod # service mongod start about to fork child process, waiting until server is ready for connections. forked process: 5543 child process started successfully, parent exiting Starting mongodb: [ OK ]

三、停止mongoDB

1、向mongod进程发送信号 SIGINT信号 # ps -ef|grep mongod|grep rs1 root 5435 4914 1 19:13 pts/2 00:00:14 mongod --dbpath=/data/mongodata/rs1 --logpath=/data/mongodata/rs1/rs1.log # kill -2 5435 2016-08-30T17:02:00.528+0800 I CONTROL[signalProcessingThread] got signal 2(Interrupt), will terminate after current cmd ends 2016-08-30T17:02:00.530+0800 I REPL [signalProcessingThread] Stopping replication applier threads 2016-08-30T17:02:00.554+0800 I STORAGE [conn1253] got request after shutdown() 2016-08-30T17:02:00.774+0800 I CONTROL [signalProcessingThread] now exiting 2016-08-30T17:02:00.774+0800 I NETWORK [signalProcessingThread] shutdown: going to close listening sockets... 2016-08-30T17:02:00.774+0800 I NETWORK [signalProcessingThread] closing listening socket: 6 2016-08-30T17:02:00.775+0800 I NETWORK [signalProcessingThread] closing listening socket: 7 2016-08-30T17:02:00.775+0800 I NETWORK [signalProcessingThread] removing socket file: /tmp/mongodb-27017.sock 2016-08-30T17:02:00.775+0800 I NETWORK [signalProcessingThread] shutdown: going to flush diaglog... 2016-08-30T17:02:00.775+0800 I NETWORK [signalProcessingThread] shutdown: going to close sockets... 2016-08-30T17:02:00.775+0800 I STORAGE [signalProcessingThread] shutdown: waiting for fs preallocator... 2016-08-30T17:02:00.775+0800 I STORAGE [signalProcessingThread] shutdown: final commit... 2016-08-30T17:02:00.775+0800 I JOURNAL [signalProcessingThread] journalCleanup... 2016-08-30T17:02:00.775+0800 I JOURNAL [signalProcessingThread] removeJournalFiles 2016-08-30T17:02:00.777+0800 I NETWORK [conn1254] end connection 192.168.1.247:58349 (0 connections now open) 2016-08-30T17:02:00.779+0800 I JOURNAL [signalProcessingThread] Terminating durability thread ... 2016-08-30T17:02:00.881+0800 I JOURNAL [journal writer] Journal writer thread stopped 2016-08-30T17:02:00.882+0800 I JOURNAL [durability] Durability thread stopped 2016-08-30T17:02:00.882+0800 I STORAGE [signalProcessingThread] shutdown: closing all files... 2016-08-30T17:02:00.884+0800 I STORAGE [signalProcessingThread] closeAllFiles() finished 2016-08-30T17:02:00.884+0800 I STORAGE [signalProcessingThread] shutdown: removing fs lock... 2016-08-30T17:02:00.885+0800 I CONTROL [signalProcessingThread] dbexit: rc: 0 SIGTERM信号 # ps -ef|grep mongod|grep rs3 # ps -ef|grep mongod|grep rs3 root 5465 1 1 19:14 ? 00:00:13 mongod --dbpath=/data/mongodata/rs3 --logpath=/data/mongodata/rs1/rs3.log --fork --port 28000 # kill -4 5465 信号 产生方式 sigint 通过ctrl+c将会对当进程发送此信号 sigterm kill命令不加参数就是发送这个信号 对进程的影响 sigint 信号被当前进程树接收到,也就是说,不仅当前进程会收到信号,它的子进程也会收到 sigterm只有当前进程收到信号,子进程不会收到。如果当前进程被kill了,那么它的子进程的父进程将会是init,也就是pid为1的进程 上述信号在发出后 不再接受新的连接请求 等待现有的连接处理完毕 关闭所有打开的连接 将内存的数据写出到磁盘 安全停止 2、使用系统服务脚本方式停止mongod # ps -ef|grep mongod root 5675 1 3 19:33 ? 00:00:00 /var/lib/mongodb/bin/mongod --config=/var/lib/mongodb/conf/rs2.conf root 5689 4950 0 19:33 pts/3 00:00:00 grep mongod [root@node3 conf]#  [root@node3 conf]# service mongod stop Stopping mongodb: [ OK ] 3、db.shutdownServer()方式 # mongo localhost:27000 > use admin > db.shutdownServer() 4、使用命令行方式关闭(补充@) # mongod -f /etc/mongo-m.conf --shutdown 5、强制关闭mongod # kill -9 5675 缺点: 数据库直接关闭 数据丢失 数据文件容易损坏(需要进行修复)
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/231812.html原文链接:https://javaforall.net

(0)
上一篇 2025年11月19日 下午8:01
下一篇 2025年11月19日 下午8:22


相关推荐

  • 【JS面试题】面试官问我:遍历一个数组用 for 和 forEach 哪个更快?

    【JS面试题】面试官问我:遍历一个数组用 for 和 forEach 哪个更快?for 语句用于创建一个循环 它包含了三个可选的表达式 三个可选的表达式包围在圆括号中并由分号分隔 后跟一个在循环中执行的语句 通常是一个块语句 语法 一个表达式 包含赋值语句 或者变量声明 典型地被用于初始化一个计数器 该表达式可以使用或关键字声明新的变量 使用 var 声明的变量不是该循环的局部变量 而是与循环处在同样的作用域中 用声明的变量是语句的局部变量 该表达式的结果无意义 一个条件表达式被用于确定每一次循环是否能被执行 如果该表达式的结果为 将被执行 这个表达式是可选的 如果被

    2026年3月27日
    2
  • CentOS7 安装以太坊 geth 客户端、创建私有区块链及挖矿

    CentOS7 安装以太坊 geth 客户端、创建私有区块链及挖矿安装以太坊源码,即安装GoEthereum(安装Geth)1、安装Golang可以直接使用yum这个包管理器安装Golangyuminstallgolang2、下载以太坊源码(GoEthereum)首先下载geth源码go-ethereum,这里以go-ethereum-1.9.7.tar.gz,直接在GitHub下载3、安装以太坊源码(安装Geth)接下来解压源码:tar-xzfgo-ethereum-1.9.7.tar.gz用下…

    2022年8月31日
    5
  • pycharm 内部环境变量修改

    pycharm 内部环境变量修改今天在在更新adb时,因为换了个新文件夹,在cmd中运行正常,但是在pycharm中adb还是在运行旧位置的adb程序,然后去问了一下同事,发现是因为win系统的环境变量虽然改变了,但是pycharm内部的环境变量未更改,所以导致还是执行的原来的旧程序。下面将记录如何修改pycharm的环境变量。1.点击File-Settings2.点击Tools-Terminal进入如下界面3.点击红框图标查看pycharm环境变量配置…

    2022年8月27日
    7
  • 文心一言4.5使用教程详解

    文心一言4.5使用教程详解

    2026年3月12日
    3
  • Linux下文件搜索、查找、查看命令

    Linux下文件搜索、查找、查看命令Linux下文件搜索、查找、查看命令1、最强大的搜索命令:find一、根据文件或目录名称搜索二、根据文件大小搜索三、根据所有者和所属组搜索四、根据时间属性搜索五、根据文件类型或i节点搜索六、组合条件搜索  2、在文件资料中查找文件:locate  3、搜索命令所在的目录及别名信息:which 4、搜索命令所在的目录及帮助文档路径:whereis5、在文件…

    2022年7月26日
    11
  • 用了半年 OpenRouter 后我换了,聊聊国内开发者选 API 聚合平台踩过的坑

    用了半年 OpenRouter 后我换了,聊聊国内开发者选 API 聚合平台踩过的坑

    2026年3月12日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号