MongoDB的启动与停止

1:启动和停止Mongodb

 1)从命令行启动

执行mongod,启动MongoDB服务器,mongod有很多可配置的启动选项,可以使用mongod --help查看所有选项

--dbpath:

指定数据目录,默认是/data/db下,每个mongod进程都需要独立的数据目录,加入有3个mongod实例,就必须要有3个独立的数据目录。当mongod启动时,会在数据目录中创建mongod.lock文件。这个文件用于防止其他mongod进程使用该数据目录。若当有一个mongd启动后,再启动另一个mongod时,若再使用刚刚已经启动mongod的目录,那么会报错:

2017-07-06T16:03:09.703+0800 I STORAGE [initandlisten] exception in initAndListen: 98 Unable to lock file: mongodb/0706/mongod.lock Resource temporarily unavailable. Is a mongod instance already running?, terminating

--port:

指定服务器监听的端口号。默认端口号为27017,要是运行多个mongod,必须指定不同的端口号

若有一个27017的端口已经使用了,那么如果启动第二个mongod的时候,若还指定27017的话,会报错:

2017-07-06T16:13:07.215+0800 E NETWORK [initandlisten] listen(): bind() failed Address already in use for socket: 0.0.0.0:27017

--fork:

以守护进程的方式运行MongoDB,创建服务进程,相当于nohup ... &

nohup mongodb/bin/mongod --dbpath mongodb/0706 &

mongodb/bin/mongod --dbpath mongodb/0706 --fork 

一样的效果

--logpath:  

指定输出日志的路径,而不是输出到命令行。如果对文件夹有写权限的话,系统会在文件不存在时创建它。它将会已有文件覆盖掉,清除原来所有的日志记录。如果想保留原来的日志,还需要使用--logappend

--config:

指定配置文件,加载命令行未指定的各种选项

--directoryperdb:

使用该参数可以将每个数据库存放在单独的目录中

比如我新建两个数据库,那么在数据目录下会自动建立数据库名一样的文件夹

启动数据库时,MongoDB会将一个文件写入local数据库的startup_log集合中,该集合包含了MongoDB的版本,所基于的系统等

    > use local
    switched to db local
    > db.startup_log.findOne()
    {
    "_id" : "vst2-1499343744092",
    "hostname" : "vst2",
    "startTime" : ISODate("2017-07-06T12:22:24Z"),
    "startTimeLocal" : "Thu Jul 6 20:22:24.092",
    "cmdLine" : {
    "storage" : {
    "dbPath" : "mongodb/0707",
    "directoryPerDB" : true
    }
    },
    "pid" : NumberLong(15613),
    "buildinfo" : {
    "version" : "3.4.5",
    "gitVersion" : "520b8f3092c48d934f0cd78ab5f40fe594f96863",
    "modules" : [ ],
    "allocator" : "tcmalloc",
    "javascriptEngine" : "mozjs",
    "sysInfo" : "deprecated",
    "versionArray" : [
    3,
    4,
    5,
    0
    ],
    "openssl" : {
    "running" : "OpenSSL 1.0.1f 6 Jan 2014",
    "compiled" : "OpenSSL 1.0.1f 6 Jan 2014"
    },
    "buildEnvironment" : {
    "distmod" : "ubuntu1404",
    "distarch" : "x86_64",
    "cc" : "/opt/mongodbtoolchain/v2/bin/gcc: gcc (GCC) 5.4.0",
    "ccflags" : "-fno-omit-frame-pointer -fno-strict-aliasing -ggdb -pthread -Wall -Wsign-compare -Wno-unknown-pragmas -Winvalid-pch -Werror -O2 -Wno-unused-local-typedefs -Wno-unused-function -Wno-deprecated-declarations -Wno-unused-but-set-variable -Wno-missing-braces -fstack-protector-strong -fno-builtin-memcmp",
    "cxx" : "/opt/mongodbtoolchain/v2/bin/g++: g++ (GCC) 5.4.0",
    "cxxflags" : "-Woverloaded-virtual -Wno-maybe-uninitialized -std=c++11",
    "linkflags" : "-pthread -Wl,-z,now -rdynamic -Wl,--fatal-warnings -fstack-protector-strong -fuse-ld=gold -Wl,--build-id -Wl,-z,noexecstack -Wl,--warn-execstack -Wl,-z,relro",
    "target_arch" : "x86_64",
    "target_os" : "linux"
    },
    "bits" : 64,
    "debug" : false,
    "maxBsonObjectSize" : 16777216,
    "storageEngines" : [
    "devnull",
    "ephemeralForTest",
    "mmapv1",
    "wiredTiger"
    ]
    }
    }

默认情况下,启动mongod时还会启动一个基本的HTTP服务器,该服务器监听的端口号比主服务的端口号大1000。这个服务提供了HTTP接口,可以查看Mongodb的一些基本信息。这些信息也可以通过shell来查看。比如说你启动的是默认端口27017,那么在浏览器打开http://10.0.0.13:28017  但是你打开的时候可能没有,因为默认管理接口是关闭的,所以在启动的时候加上开启管理接口参数--httpinterface,也就是 mongodb/bin/mongod --dbpath mongodb/0706 --fork --logpath 0706.log --httpinterface 

当你点进去的时候,是这样的,说你的参数没打开,所以启动的时候还得加上--rest参数

加上参数重新启动之后,可以看到,有详细的信息了

2):配置文件

Mongodb支持从文件读取配置文件。指定配置文件可以使用-f--config选项

2:停止Mongodb

方法一:查看进程,使用kill命令;不能使用kill -9

方法二:在客户端进去,使用shutdown命令

> use admin;
switched to db admin
> db.shutdownServer();
server should be down...

在主节点(primary)上运行shutdown命令时,服务器在关闭之前,会先等待备份节点追赶主节点以保持同步。这将回滚的可能性降至最低,但shutdown操作有失败的可能性。如几秒钟内没有备份节点成功同步,则shutdown操作失败,主节点不会停止运行。

3:日志

在启动mongod的时候,可以指定日志的级别,即(-v、-vv、-vvv、-vvvv、-vvvvv)或者在shell命令行执行命令修改

mongodb/bin/mongod --dbpath mongodb/0707 --directoryperdb --fork -vvv 

日志级别越大,输出的日志越详细,调至5时,这时mongod会在日志中记录几乎所有的操作,包括每一个请求所处理的内容。

MongoDB默认记录耗时超过100毫秒的查询信息。如果100毫秒不适合需求,可以通过setProfilingLevel命令来改变,下面这条命令表示记录查询时间超过500毫秒的消息

    > db.setProfilingLevel(1,500)
    { "was" : 0, "slowms" : 100, "ok" : 1 }

如果想要日志分割,如按天存放,有两种方法

方法一:每天定时的执行kill -USR1 进程号,这样就可以看到,每执行一次kill -USR1 进程号,那么就会重新生成一个日志文件

方法二:在MongoDB的shell行执行,每执行一次都会产生一个新的日志文件

    > db.adminCommand({"logRotate":1})
    { "ok" : 1 }

要使分割日志生效,必须启动的时候使用--logpath,然后可以根据自己的需求,写shell或python脚本,然后crontab做成定时任务

时间: 2024-11-09 12:58:10

MongoDB的启动与停止的相关文章

Mongodb的启动和停止

1.Mongod的启动 1.1.Mongod的启动选项 Mongod有许多可配置的选项,在命令行运行mongod --help可以查看所有选项,常用的选项如下: 序号 选项 含义 1 --dbpath 指定数据目录,默认值是/data/db(Windows下是C:\data\db).每个mongod进程都需要独立的数据目录,所以要是有3个mongod的实例,必须要有独立的数据目录.当mongod启动时,会在数据目录中创建mongod.lock文件,这个文件用于防止其他mongod进程使用该数据目

mongoDB 启动与停止

MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案.它以高性能.易部署.易使用,存储数据非常方便等优点被广泛使用.其安装配置相当简单,有如轻量级的mysql,但功能丝毫不差.本文主要描述mongoDB的启动与停止. 一.准备环境 1.当前环境 # more /etc/redhat-release CentOS release 6.7 (Final) 2.安装mongod # which mongod /var/lib/mongod

mongodb数据库的启动和停止

数据库的启动和停止是数据库最基本的操作,也是数据库能够提供服务和被连接管理的前提条件.不同的数据库启动和停止的方式有一些差异,但也有相同之处,启动和关闭也必定会和数据库的进程有关. 在oracle数据库中,数据库的启动和停止都是分三个过程的,正常的启动方法都是在sqlplus中执行startup命令启动,或者shutdown immediate命令关闭数据库: 在一些特殊的情况下,会通过shutdown abort或者kill后台进程的方式强制关闭数据库: 在MySQL数据库中,数据库的启动也是

Nginx编译安装,启动,停止,升级。

1.简单介绍下Nginx Nginx是一款轻量级的web服务器和反向代理服务器,它使用了epoll的I/O模型,也就是事件触发I/O模型,减少了进程的生成切换所消耗的系统资源(CPU的压力减少,内存的占用也会减少),可以达到很高的并发请求.它是一款开源软件,企业成本降低,它的使用配置也比较简单,同时支持Rewrite,作为反向代理的时候可以检查后端的Web服务器的健康状况,能够支持热部署. 2.Nginx安装,重启,升级,停止. 环境是Centos系统,通过www.nginx.org下载需要的源

Appium+Python app自动化测试之脚本启动和停止Appium服务

研究了一段时间的Appium android app的自动化测试,工作中需要连接多台手机终端同时执行测试用例,我实现的方式是获取用例中需要执行用例的设备id个数以及实际连接到的设备数(通过adb devices获取),然后启动相应数量的Appium 服务,以便每个设备执行时并发进行并且互不影响.当然也可以通过selenium grid来实现,只是目前还在学习研究中,还是先把目前启动多个appium服务实现的方式记录下来. 一.Windows下启动单个appium服务 需要启动多个appium服务

oracle rac的启动与停止

引言:这写篇文章的出处是因为我的一名学生最近在公司搭建RAC集群,但对其启动与关闭的顺序和原理不是特别清晰,我在教学工作中也发现了很多学员对RAC知识了解甚少,因此我在这里就把RAC里面涉及到的最常用的启动与关闭顺序和命令逐一列举出来,由于RAC的后台资源较多,因此涉及到的命令也很多,最后附上帮助手册让在工作中临时使用时也可以迅速查到,如果这篇文章能够帮到大家就是我今后继续努力撰写的动力,感谢大家对我文章的浏览多提宝贵意见. 11G RAC启动关闭简单的多. 关闭:1,oracle用户关闭服务.

shell脚本批量/单独启动、停止、重启java独立jar程序

本人最近半年使用阿里dubbo做开发,并在公司内部大力进行推广,将原来一个笨重且不易于维护的大项目切分成多个相对独立的java程序,好处是显而易见的,但是随着切分的独立运行程序包越来越多,程序的部署变成了一件非常头痛的问题,无耐之下,本人想到可否写一个shell脚本来批量/单独启动.停止.重启这些独立的java程序,之前没有写过shell脚本,研究二天后,终于将这个脚本写出来了,以后部署起来方便多了,废话不多说,直接贴上shell脚本,有需要的朋友可以根据自己项目修改前面的程序代码数组.程序名称

(转)redis 学习笔记(1)-编译、启动、停止

redis 学习笔记(1)-编译.启动.停止 一.下载.编译 redis是以源码方式发行的,先下载源码,然后在linux下编译 1.1 http://www.redis.io/download 先到这里下载Stable稳定版,目前最新版本是2.8.17 1.2 上传到linux,然后运行以下命令解压 tar xzf redis-2.8.17.tar.gz 1.3 编译 cd redis-2.8.17make 注:make命令需要linux上安装gcc,若机器上未安装gcc,redhat环境下,如

linux 下 apache启动、停止、重启命令

原文:linux 下 apache启动.停止.重启命令 基本的操作方法: 本文假设你的apahce安装目录为/usr/local/apache2,这些方法适合任何情况 apahce启动命令: 推荐/usr/local/apache2/bin/apachectl start apaceh启动 apache停止命令 /usr/local/apache2/bin/apachectl stop   停止 apache重新启动命令: /usr/local/apache2/bin/apachectl res