Mongo shell使用方法及操作指南
![]() | ![]() | ![]() | ![]() |
| 【性价之王】 | 【线路之王】 | 【价格之王】 | 【配置之王】 |
| 【免费之王】 | 【香港首推】 | 【梯子之王】 | 【独服之王】 |
Mongo shell 是 MongoDB 的命令行管理工具,功能非常强大,最近社区很多人咨询的一些问题,比如
命令行看 json 格式比较吃力? 如何确定Secondary节点同步是否跟上? 怎么查看DB、集合使用了多少空间? 能否在shell 脚本里调用Mongo shell 怎么执行 MongoDB 命令,比如创建集合、索引? ……上述问题都可以通过 Mongo shell 来解决,而且Mongo shell能做的远不止这些。
语法糖为了方便关系型数据库的的用户切换到 MongoDB 上能快速上手,mongo shell里做了一些语法上的兼容(最终还是通过调用 MongoDB 的命令实现的 ),例如
show dbs 列出所有DB use dbname 切换当前DB show tables 或 show collections 列出当前DB的所有表/集合 show users 列出当前DB的所有用户 show profile 列出当前DB的所有慢查询 show logs 列出运行日志 执行命令MongoDB的所有请求都以命令的形式发出,支持的命令列表参考Database Commands
基本所有的driver都会实现一个通用的执行命令的接口,然后再封装出一些常用的接口(比如常用的CRUD操作),mongo shell 通过 runCommand 接口来实现执行命令,例如执行 serverStatus 命令
* db.runCommand( { serverStatus: 1} ) mongo shell也对很对很多常用的命令进行了封装,让用户使用起来更简单。
常见的封装接口包括
* db.serverStatus() 查看mongod运行状态信息 * db.stats() 查看db元数据 * db.collection.stats() 查看集合元数据 * db.collection.insert() / update / remove / find 对集合增删改查 * db.collection.createIndex() 创建索引 * db.collection.dropIndex() 删除索引 * db.dropDatabase() 删除DB * db.printReplicationInfo() * db.printSlaveReplicationInfo() 查看复制集同步信息 * rs.status() 查看复制集当前状态 * rs.conf() 查看复制集配置 * rs.initiate() 初始化复制集 * rs.reconfig() 重新配置复制集 * rs.add() / rs.remove() 增加/删除复制集节点 * sh.enableSharding() 对DB启用分片 * sh.shardCollection() 对集合进行分片 * sh.status() 查看sharding状态信息 * ... 文档格式化输出很多同学在使用 mongo shell时,觉得文档输出后可读性差,比如
mongo-9555:PRIMARY> db.collection1.find() // 对集合调用find时,默认输出前20个文档 { "_id" : ObjectId("587ed6ce098a4da78d508468"), "name" : "jack", "age" : 18, "sex" : "male", "hobbies" : [ "football", "basketball" ], "contact" : { "phone" : "10000123456", "address" : "hangzhou", "zipcode" : "31000" } } 实际上,mongo shell 可以对cursor的输出进行格式化(pretty)输出,JSON的文档会被格式化输出,可读性很强
mongo-9555:PRIMARY> db.collection1.find().pretty() { "_id" : ObjectId("587ed6ce098a4da78d508468"), "name" : "jack", "age" : 18, "sex" : "male", "hobbies" : [ "football", "basketball" ], "contact" : { "phone" : "10000123456", "address" : "hangzhou", "zipcode" : "31000" } } mongo shell 里还可以通过 printjson 来格式化输出任意json对象,比如
mongo-9555:PRIMARY> printjson({ "_id" : ObjectId("587ed6ce098a4da78d508468"), "name" : "jack", "age" : 18, "sex" : "male", "hobbies" : [ "football", "basketball" ], "contact" : { "phone" : "10000123456", "address" : "hangzhou", "zipcode" : "310000000" } }) { "_id" : ObjectId("587ed6ce098a4da78d508468"), "name" : "jack", "age" : 18, "sex" : "male", "hobbies" : [ "football", "basketball" ], "contact" : { "phone" : "10000123456", "address" : "hangzhou", "zipcode" : "31000" } shell脚本调用mongo shell 除了支持交互式的调用方式,还能支持执行完一个或一批操作后自动退出,这样就能很方便的在shell 脚本里调用 mongo shell,比如获取 MongoDB 各个命令备调用的次数。
$ mongo --host localhost:27017 --eval "printjson( db.serverStatus().opcounters )" MongoDB shell version: 3.0.5 connecting to: localhost:27017/test { "insert" : 2, "query" : 13, "update" : 0, "delete" : 0, "getmore" : 74191, "command" : 104198 } 如果要一次执行很多个 MongoDB 的操作,可以将操作写到文件里,然后使用 mongo shell 批量执行
$cat test.js db = db.getSiblingDB("mydb") // 脚本里切换db的方式,相当于use mydb for (var i = 0; i < 100; i++) { db.collection.insert( {x: i} ) } printjson( {db.collection.count()} ) $ mongo --host localhost:27017 test.js MongoDB shell version: 3.0.5 connecting to: localhost:27017/test 100 mongo shell 还提供『启动时执行脚本』的机制,类似与linux shell里的启动新的shell时,执行~/.bashrc等文件的机制。
只要将脚本写入 ~/.mongorc.js 文件里, mongo shell 启动时,就会先执行这个脚本,例如
$cat .mongorc.js print("Welcome, ZhangYoudong"); 然后每次登录mongo shell时,这个文件的js脚本就会被执行 $ mongo --host localhost:27017 MongoDB shell version: 3.0.5 connecting to: localhost:27017/test Welcome, ZhangYoudong > man 手册上述的命令,并不需要去记忆,跟使用 linux shell 一样,需要用的时候看下 help 信息
* help * db.help() * rs.help() * sh.help() * db.collection.find().help() * help misc 除了上述功能,mongo shell 还提供了命令补全、命令历史等很多实用的功能,只要习惯了使用mongo shell,根本无需再使用图形界面来管理 MongoDB;当然为了方便更多用户,阿里云 MongoDB 云数据库 不仅支持通过mongo shell 及 其他第三方图形管理工具访问,还附带一个DMS的数据库管理系统,供用户免费使用。
[amp]历史优惠活动内容
猜你可能想看的VPS
- 伏羲→24 月 1GB 内存 40GB SSD 空间 不限流量 15Mb虚拟空间(主机)
- 便宜 $15 年 2 核 CPU 2G 内存 50G SSD 5T 流量全球[VPS测评]
- 云上互联→20.8 元 月 512MB 内存 35GB 空间 不限流量 虚拟空间(主机)
- linux 下开启 SSH 允许 root 用户远程无密码登录全球[VPS测评]
- 四个倒着的脚字是什么成语?全球[VPS测评]
- 稳定高速 CeRaNetworks 香港服务器 4 核 16GB $18香港VPS[主机]
- INXY→提供 Leaseweb ahCDN UCDN Highwind香港VPS[主机]
- OneProvider→法国 荷兰独服特价 1Gbps 带宽 不限流量 全球[VPS测评]
- baku.hosting→$24.4 半年 768MB 内存 20GB 虚拟空间(主机)
- 干货推荐 新 老用户都可以买→腾讯云服务器(VPS) 包括“香港”等多香港VPS[主机]
- 宝塔面板中 ThinkPHP5 更改网站目录为 public 后运行报错全球[VPS测评]
- 便宜香港空间 老薛主机→影视 淘客建站扶持计划 买一年送一年 最多可送三虚拟空间(主机)
- StockServers→$25 月 Core2Quad Q9000 8全球[VPS测评]
- xxmhost→57.2 元 月 1GB 内存 15GB SSD 空间 虚拟空间(主机)
- 为什么有些网站的SEO排名总是靠前全球[VPS测评]
- WordPress插件:Simple URLs 链接点击统计管理全球[VPS测评]
- 恒星云新春香港沙田CN2 VPS¥9.9起/月,成都高防¥144/月,大香港VPS[主机]
- HKServerSolution → 2G 内存 20G HDD 2T单全球[VPS测评]
- 腾讯云香港轻量应用服务器 优惠活动最低月付仅24元香港VPS[主机]
- 麻花云怎么样?安徽移动vps月付29元/香港vps月付21元香港VPS[主机]
- 云计算到底是谁发明的?全球[VPS测评]
- kvmcloud怎么样?香港BGP云服务器 月付12.9元香港VPS[主机]
- 什么是VPS?国内VPS有哪些?全球[VPS测评]
- hosthatch:香港/芝加哥/伦敦等11机房VPS低至$17.5/年香港VPS[主机]
- 中国跨境电商,如何掘金欧洲市场?全球[VPS测评]
- centos7如何查看firewall防火墙状态:开启/关闭/重启防火墙全球[VPS测评]
- 曾经最大跨境电商平台团队收缩,只剩20人丨GoingGlobal周报全球[VPS测评]
- diyvm:香港vps/美国vps/日本vps/2核/2G内存/5M带宽日本VPS[主机]
- GreenCloudVPS:5折、6折优惠,日本、新加坡、香港等KVM 日本VPS[主机]
- 戈登云VPS,6折,充值送50%,香港cn2,美国cn云服务器,2核2G美国VPS[主机]
转载请注明原文地址:http://140.238.13.167:12355/read-157352.html











