天天看點

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

參考: 

Linux下快速安裝MongoDB 

Windows平台下安裝MongoDB

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 @20160901

     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

        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

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

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、使用指令行方式關閉(補充@20160901)

        # mongod -f /etc/mongo-m.conf  --shutdown

5、強制關閉mongod

        # kill -9 5675

        缺點:

        資料庫直接關閉

        資料丢失

        資料檔案容易損壞(需要進行修複)

本文轉自 Mr_sheng 51CTO部落格,原文連結:http://blog.51cto.com/sf1314/2057294

繼續閱讀