主要介绍了日常运行维护的管理工具 MongoDB的日常维护包括使用配置文件,设置访问控制,Shell交互,系统监控和管理,数据库日常备份和恢复 启动和停止MongoDB 启动后可以通过数据库的IP加端口号访问Web形式数据库。配置文件 通过使用拂去配置文件的方式启动

主要介绍了日常运行维护的管理工具

MongoDB的日常维护包括使用配置文件,设置访问控制,Shell交互,系统监控和管理,数据库日常备份和恢复

启动和停止MongoDB

启动后可以通过数据库的IP加端口号访问Web形式数据库。配置文件

通过使用拂去配置文件的方式启动数据库实例,在bin文件夹下创建并编辑mongodb.config(名字可以随意)

事例加上 dbpath =/data/db/

启动时加上 --f 参数,并且指向配置文件即可。

使用Daemon方式启动

为什么我们使用Daemon方式?当我们关闭数据库服务的session端口的时候,MongoDB的服务也随之终止,这样是十分不安全的。通过守护进程的方式,启动即可。

添加 --fork 参数,这里必须指定存储日志的文件,即为启动 --logpath 参数。

事例如下

./mongod.exe --dbpath = D:\MongoDB --logpath = D:\MongoDB\log\mongodb50.log --fork

常见的mongod的参数说明

dbpath:数据文件存放路径

logpath: 存放的日志文件

bind_ip :对外的服务绑定IP,一般为空,面对所有的IP开放

port: fork 以后台Daemon的形式启动该服务,web管理端在其上加1000

journal: 开启日志功能,通过保存操作日志来降低单机故障的恢复时间,

config :当参数行十分多的时候,使用这个参数来设定参数文件的位置

关闭数据库

直接使用Control+C来中断

在connect连接状态下,可以切换到admin数据,后直接在库中发送db.shutdownServer()指令终止MongoDB实例。

Unix下发送Kill -2 PID 或者 Kill -15 PID来终止进程

ps aux|grep mongod

kill -2 (yourPID)

ps aux|grep mongod

注意:不能使用kill -9 PID 杀死进程,这样可能导致MongoDB数据库损坏。

访问数据库

绑定iP地址 ——bind_ip

//MongoDB 可以限制只允许某一特定IP 来访问,只要在启动时加一个参数bind_ip 即可,如下:

[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ ./mongod --bind_ip 192.168.1.61

设置监听端口 ——port

//将服务端监听端口修改为27018:

[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ ./mongod --bind_ip 192.168.1.61 --port 27018

//(报错代码)端户访问时不指定端口,会连接到默认端口27017,对于本例会报错,代码如下:

[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ ./mongo 192.168.1.50

MongoDB shell version: 2.0.2

connecting to: 192.168.1.61/test

Sun Apr 14 21:45:26 Error: couldn't connect to server 192.168.1.50 shell/mongo.js:81 exception: connect failed

使用用户名和密码登陆 ——启动时使用--auth参数

//先启用系统的登录验证模块, 只需在启动时指定 auth 参数即可,代码如下:

[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ ./mongod --auth

启动认证

默认有个admin数据库,在admin.system.users中保存的用户比其他的数据库设置的用户权限更大。在未添加admin.system.users用户的权限的的情况下, 客户端无需任何认证就可以连接到数据库,并且可以对数据库进行任何操作,只有在admin.system.users添加了用户,启动--auth参数才会起作用。

1.建立系统root用户

>db.addUser("root","123456")

>db.auth("root","123456")

2.建立只读权限用户

>db.addUser("user_reader","1234567",true)

添加只读权限的用户只需添加第三个参数,true。

使用命令行操作

MongoDB不仅可以交互,还可以执行指定的JavaScript文件,执行指定的命令片段,使用Linux Shell。

1.通过eval参数执行指定的语句

查询test库的t1集合的记录有多少:

db.t1.find()

{ "_id" : ObjectId("4f8ac746b2764d3c3e2cafbb"), "num" : 1 }

{ "_id" : ObjectId("4f8ac74cb2764d3c3e2cafbc"), "num" : 2 }

{ "_id" : ObjectId("4f8ac74eb2764d3c3e2cafbd"), "num" : 3 }

{ "_id" : ObjectId("4f8ac751b2764d3c3e2cafbe"), "num" : 4 }

{ "_id" : ObjectId("4f8ac755b2764d3c3e2cafbf"), "num" : 5 }

db.t1.count()

5

通过使用--eval参数直接执行ti的集合中的数

$./mongo.exe --eval "printjson(db.t1.count())"

MongoDB shell version: 2.0.2

connecting to: test

5

2.使用js文件执行文件内容

$cat t1_count.js

var count = db.t1.count();

printjson('count of t1 is: '+count);

显示为:

$./mongo t1_count.js

MongoDB shell version: 2.0.2

connecting to: test

"count of t1 is: 5"

Tips:通过--quiet参数屏蔽部分登陆信息,使结果更清晰

$ ./mongo --quiet t1_count.js

"count of t1 is: 5"

进程管理

查看活动进程

> db.currentOp()

>db.$cmd.sys.inprog.findOne() //$cmd调用外部函数

显示如下:

> db.currentOp()

{

"inprog" : [

{

"opid" : 630385,

"active" : true,

"lockType" : "read",

"waitingForLock" : false,

"secs_running" : 0,

"op" : "query",

"ns" : "test",

"query" : {

"count" : "t1",

"query" : {

},

"fields" : {

}

},

"client" : "127.0.0.1:51324",

"desc" : "conn",

"threadId" : "0x7f066087f710",

"connectionId" : 7,

"numYields" : 0

}

]

}

>

代码解释:

opid:操作进程号

op: 操作类型(query ,update ,etc)

ns: 命名空间(namespace),操作对象

query :显示操作的具体内容

lockType: 锁的类型,指明是写锁还是读锁

结束进程

> db.killOp(630385)

{ "info" : "attempting to kill op" }

我们查看下:

> db.currentOp()

{ "inprog" : [ ] }

>

监控系统的状态和性能

使用serverStatus命令可以获取到运行中的MongoDB服务器统计信息,下面我们来执行命令,查看MongoDB服务器的统计信息(不同平台或不同版本的键会有所不同),代码如下:

> db.runCommand({"serverStatus":1})

{

"host" : "lindenpatservermongodb01",

"version" : "2.0.2",

"process" : "mongod",

"uptime" : 6003,

"uptimeEstimate" : 5926,

"localTime" : ISODate("2012-04-15T11:02:21.795Z"),

"globalLock" : {

"totalTime" : 6002811172,

"lockTime" : 24867,

"ratio" : 0.000004142559092311891,

"currentQueue" : {

"total" : 0,

"readers" : 0,

"writers" : 0

},

"activeClients" : {

"total" : 0,

"readers" : 0,

"writers" : 0

}

},

"mem" : {

"bits" : 64,

"resident" : 52,

"virtual" : 1175,

"supported" : true,

"mapped" : 160,

"mappedWithJournal" : 320

},

"connections" : {

"current" : 1,

"available" : 818

},

"extra_info" : {

"note" : "fields vary by platform",

"heap_usage_bytes" : 341808,

"page_faults" : 14

},

"indexCounters" : {

"btree" : {

"accesses" : 1,

"hits" : 1,

"misses" : 0,

"resets" : 0,

"missRatio" : 0

}

},

"backgroundFlushing" : {

"flushes" : 100,

"total_ms" : 13,

"average_ms" : 0.13,

"last_ms" : 1,

"last_finished" : ISODate("2012-04-15T11:02:19.010Z")

},

"cursors" : {

"totalOpen" : 0,

"clientCursors_size" : 0,

"timedOut" : 0

},

"network" : {

"bytesIn" : 1729666458,

"bytesOut" : 1349989344,

"numRequests" : 21093517

},

"opcounters" : {

"insert" : 5,

"query" : 8,

"update" : 0,

"delete" : 0,

"getmore" : 0,

"command" : 21093463

},

"asserts" : {

"regular" : 0,

"warning" : 0,

"msg" : 0,

"user" : 0,

"rollovers" : 0

},

"writeBacksQueued" : false,

"dur" : {

"commits" : 30,

"journaledMB" : 0,

"writeToDataFilesMB" : 0,

"compression" : 0,

"commitsInWriteLock" : 0,

"earlyCommits" : 0,

"timeMs" : {

"dt" : 3073,

"prepLogBuffer" : 0,

"writeToJournal" : 0,

"writeToDataFiles" : 0,

"remapPrivateView" : 0

}

},

"ok" : 1

}

>

数据导出与导入 mongoexport和mongoinport

使用mongoexport导出数据

先看数据:

> db.t1.find()

{ "_id" : ObjectId("4f8ac746b2764d3c3e2cafbb"), "num" : 1 }

{ "_id" : ObjectId("4f8ac74cb2764d3c3e2cafbc"), "num" : 2 }

{ "_id" : ObjectId("4f8ac74eb2764d3c3e2cafbd"), "num" : 3 }

{ "_id" : ObjectId("4f8ac751b2764d3c3e2cafbe"), "num" : 4 }

{ "_id" : ObjectId("4f8ac755b2764d3c3e2cafbf"), "num" : 5 }

>

使用代码:

./mongoexport.exe -d test -c t1 -o t1.dat

connected to: 127.0.0.1

exported 5 records

[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ ls

bsondump mongodump mongoimport mongosniff t1_count.js

mongo mongoexport mongorestore mongostat t1.dat

mongod mongofiles mongos mongotop testfiles.txt

[root@mongodb01 /home/mongo/mongodb-2.0.2/bin]$ cat t1.dat

{ "_id" : ObjectId("4f8ac746b2764d3c3e2cafbb"), "num" : 1 }

{ "_id" : ObjectId("4f8ac74cb2764d3c3e2cafbc"), "num" : 2 }

{ "_id" : ObjectId("4f8ac74eb2764d3c3e2cafbd"), "num" : 3 }

{ "_id" : ObjectId("4f8ac751b2764d3c3e2cafbe"), "num" : 4 }

{ "_id" : ObjectId("4f8ac755b2764d3c3e2cafbf"), "num" : 5 }

./mongoexport.exe -d test -c t1 -o t1.dat 使用参数说明

-d: 指明使用的数据库

-c: 指明导出的集合,这里是t1

-o: 导出的数据名,这里的数据名默认使用相对路径,也可以使用绝对路径。

导出的数据格式的是JSON方式,也可导出csv格式;

导出为CSV格式代码文件如下:

./mongoexport -d test -c t1 -csv -f num -o t1.dat

-csv:指明了要导出的是CSV格式

-f: 指明需要导出的是哪些例子

数据导入 mongoimport

现将ti删除:

> db.t1.drop()

true

> show collections

system.indexes

system.users

>

再导入数据,这里导入的是csv数据:

./mongoimport -d test -c t1 --type csv --headerline -file /home/t1.dat

connected to: 127.0.0.1

看看导入的数据是不是一样:

> db.t1.find()

{ "_id" : ObjectId("4f8ac746b2764d3c3e2cafbb"), "num" : 1 }

{ "_id" : ObjectId("4f8ac74cb2764d3c3e2cafbc"), "num" : 2 }

{ "_id" : ObjectId("4f8ac74eb2764d3c3e2cafbd"), "num" : 3 }

{ "_id" : ObjectId("4f8ac751b2764d3c3e2cafbe"), "num" : 4 }

{ "_id" : ObjectId("4f8ac755b2764d3c3e2cafbf"), "num" : 5 }

>

--type csv 导入的数据格式为CSV,为什么导入CSV格式:CSV对各大主流的数据库支持更良好,而JSON作为轻量级的数据格式,还有些弊端。

--file 指明导入的文件路径

数据备份和恢复

使用 数据备份 mongodump

./mongodump -d test -o /home/dump

-o:表示输出的备份路径,如果没有使用这个选项的话,MongoDB会自动创建dump文件夹并将备份文件放于其内。

使用数据恢复 mongorestore

mongorestore获取mongodump的输出结果,并将备份的数据插入到运行的MongoDB中。

./mongorestore -d test dump/*

connected to: 127.0.0.1

Thu Apr 19 18:16:12 dump/test/system.users.bson

Thu Apr 19 18:16:12 going into namespace [test.system.users]

2 objects found

Thu Apr 19 18:16:12 dump/test/t1.bson

Thu Apr 19 18:16:12 going into namespace [test.t1]

5 objects found

Thu Apr 19 18:16:12 dump/test/system.indexes.bson

Thu Apr 19 18:16:12 going into namespace [test.system.indexes]

Thu Apr 19 18:16:12 { key: { _id: 1 }, ns: "test.system.users", name: "_id_" }

Thu Apr 19 18:16:13 { key: { _id: 1 }, ns: "test.t1", name: "_id_" }

2 objects found

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

PHP系统管理mongodb,MongoDB的日常维护管理相关推荐

  1. MS SQL 日常维护管理常用脚本(二)

    下面是整理.收集监控数据库运行的一些常用脚本,也是MS SQL 日常维护管理常用脚本(一)的续集,欢迎大家补充.提意见. 查看数据库登录名信息 Code Snippet SELECT name     ...

  2. MongoDB的日常维护管理

    主要介绍了日常运行维护的管理工具 MongoDB的日常维护包括使用配置文件,设置访问控制,Shell交互,系统监控和管理,数据库日常备份和恢复 启动和停止MongoDB 启动后可以通过数据库的IP加端 ...

  3. 云呐|固定资产管理系统和备件如何日常维护管理

    一般来说,企业管理者可以监控和管理固定资产的整个生命周期,解决资产管理中账卡不一致的问题.固定资产管理信息化管理,如资产设备不清.闲置浪费.资产虚增.资产流失等.规范化管理,进一步提升企业固定资产管理 ...

  4. 服务器时间维护制度,网络设备及服务器日常维护管理制度

    第一章总则 第一条:为保证机房设备与信息的安全,保障本校服务器及网络系统在良好.稳定.高效.快速的安全运行.特制定本制度. 第二条:为确保中心机房网络设备特别是服务器安全,根据岗位职责设立机房管理员, ...

  5. 【转】运行维护管理制度

    1.总则 第一条 为保障公司信息系统软硬件设备的良好运行,使员工的运维工作制度化.流程化.规范化,特制订本制度. 第二条 运维工作总体目标:立足根本促发展,开拓运维新局面.在企业发展壮大时期,通过网络 ...

  6. 计算机日常故障DIY维修有哪些,有关计算机常见故障排除与日常维护

    有关计算机常见故障排除与日常维护 计算机常见故障诊断及排除.硬件故障.CPU故障分析一般说来,CPU是不容易出现故障的,但由于超频或者电压工作不稳定和CPU的制造工艺的不同等原因,会导致CPU不能正常 ...

  7. 液晶拼接屏的日常维护方法

    大屏显示拼接墙的出现给我们的工作生活带来很大的改变,比如现在可以用它实现一个超大屏幕显示一幅高清画面信号,在很多的电视节目中我们经常能看见这种东西,还能使用它显示多路信号进行拼接,并且可以放大其中一幅 ...

  8. MongoDB——MongoDB的日常维护

    MongoDB的日常维护和复制集 日常维护 备份与回复管理 导入导出 备份与恢复 克隆(克隆集合) 安全管理 监控 进程管理 授权启动 日常维护 MongoDB日常维护主要包括数据库的备份恢复.安全管 ...

  9. MongoDB安装和MongoChef可视化管理工具的使用

    MongoDB Windows 用户向导:https://docs.mongodb.com/manual/tutorial/install-mongodb-on-windows/ 注意:最后一步时,左 ...

最新文章

  1. Ubuntu 16.04下部署Graylog日志服务器
  2. JVM 内存模型:运行时常量池
  3. Atom 相关配置备份
  4. 程序员面试100题之二:跳台阶问题(变态跳台阶)
  5. 北理工计算机学院新闻,北理工计算机学子勇夺CVPR 2021 AI安全国际顶级赛事季军...
  6. vue 实现数据滚动显示_vue实现动态添加数据滚动条自动滚动到底部的示例代码...
  7. Excel中Countif()函数运用技巧
  8. 织梦编程run=php,dedecms织梦怎么用runphp='yes'运行php
  9. 解决ssh链接服务器长时间不操作出现掉线问题
  10. Mycat安全_SQL拦截黑名单---MyCat分布式数据库集群架构工作笔记0034
  11. 我的linux 常用命令
  12. J2EE的核心API与组件
  13. windows运行python脚本卡住_运行python脚本安装windows服务时没有响应
  14. 软件开发中的完整测试所包括的环节UT、IT、ST、UAT
  15. VBScript 教程
  16. 瀚高数据库迁移工具常见问题
  17. 转载:技术大停滞——范式春梦中的地球工业文明4:范式春梦外的阴影
  18. 如何删除outlook中的重复邮件
  19. MySQL 学习篇(四)数据库结构设计目的、基本字段类型介绍和实战内容
  20. 程伟健:新城易居携手中旅联盟深度发力打造城市中心文旅目的地

热门文章

  1. 程序员:要想成为一个伟大的程序员
  2. 我感到很惭愧的飞鸽传书
  3. 现在写程序要像蚊子一样WZ132
  4. Win32下的录音编程
  5. 苦苦发愁学习Python?七天掌握Python就在此时
  6. HTML5新特征、窍门和技术(6~10)
  7. java观察者_Java中的观察者模式
  8. xiao77论坛php,论坛
  9. 实用遗传咨询 | 精神与行为异常-Autism
  10. 用Python一次性把论文作图与数据处理全部搞定!