设为首页 收藏本站
查看: 1415|回复: 0

[经验分享] mongodb维护常用命令

[复制链接]

尚未签到

发表于 2018-10-25 10:41:19 | 显示全部楼层 |阅读模式
一,用户操作:  
1. #进入数据库admin
  
use admin
  
2. #增加或修改用户密码
  
db.addUser('name','pwd')
  
3. #查看用户列表
  
db.system.users.find()
  
4. #用户认证
  
db.auth('name','pwd')
  
5. #删除用户
  
db.removeUser('name')
  
6. #查看所有用户
  
show users
  
7. #查看所有数据库
  
show dbs
  
8. #查看所有的collection
  
show collections
  
9. #查看各collection的状态
  
db.printCollectionStats()
  
10. #查看主从复制状态
  
db.printReplicationInfo()
  
11. #修复数据库
  
db.repairDatabase()
  
12. #设置记录profiling,0=off 1=slow 2=all
  
db.setProfilingLevel(1)
  
13. #查看profiling
  
show profile
  
14. #拷贝数据库
  
db.copyDatabase('mail_addr','mail_addr_tmp')
  
15. #删除collection
  
db.mail_addr.drop()
  
16. #删除当前的数据库
  
db.dropDatabase()
  
17. 备份数据库
  
mongodump -h localhost:27017 -d dataname -o /data/dump
  
18. 恢复数据库
  
mongorestore -d dataname /data/dump
  
19. 备份数据库表
  
mongodump -h localhost:27017 -d dataname -c tablename -o /data/dump
  
20. 恢复数据库表
  
mongorestore -d dataname -c tablename /data/dump
  
mongorestore -h host:port -d dataname --collection tablename ./tmpdump/some.bson
  

  
二,数据操作:
  

  
1. #存储嵌套的对象
  
db.foo.save({'name':'ysz','address':{'city':'beijing','post':100096},'phone':[138,139]})
  
2. #存储数组对象
  
db.user_addr.save({'Uid':'yushunzhi@sohu.com','Al':['test-1@sohu.com','test-2@sohu.com']})
  
3. #根据query条件修改,如果不存在则插入,允许修改多条记录
  
db.foo.update({'yy':5},{'$set':{'xx':2}},upsert=true,multi=true)
  
4. #删除yy=5的记录
  
db.foo.remove({'yy':5})
  
5. #删除所有的记录
  
db.foo.remove()
  
6. #增加索引:1(ascending),-1(descending)
  
7. db.foo.ensureIndex({firstname: 1, lastname: 1}, {unique: true});
  
8. #索引子对象
  
9. db.user_addr.ensureIndex({'Al.Em': 1})
  
10. #查看索引信息
  
11. db.foo.getIndexes()
  
12. db.foo.getIndexKeys()
  
13. #根据索引名删除索引
  
14. db.user_addr.dropIndex('Al.Em_1')
  

  
三,查询操作:
  

  

  
1. #查找所有
  
2. db.foo.find()
  
3. #查找一条记录
  
4. db.foo.findOne()
  
5. #根据条件检索10条记录
  
6. db.foo.find({'msg':'Hello 1'}).limit(10)
  
7. #sort排序
  
8. db.deliver_status.find({'From':'ixigua@sina.com'}).sort({'Dt',-1})
  
9. db.deliver_status.find().sort({'Ct':-1}).limit(1)
  
10. #count操作
  
11. db.user_addr.count()
  
12. #distinct操作,查询指定列,去重复
  
13. db.foo.distinct('msg')
  
14. #”>=”操作
  
15. db.foo.find({"timestamp": {"$gte" : 2}})
  
16. #子对象的查找
  
17. db.foo.find({'address.city':'beijing'})
  
条件操作符
  
$gt : >
  
$lt : <
  
$gte: >=
  
$lte: = 18 的数据
  
db.users.find({name: {$ne: "bruce"}, age: {$gte: 18}});
  

  
查询 creation_date > '2010-01-01' and creation_date  18 的记录,以下查询都一样
  
db.users.find({age: {$gt: 18}});
  
db.users.find({$where: "this.age > 18"});
  
db.users.find("this.age > 18");
  
f = function() {return this.age > 18} db.users.find(f);
  

  
排序sort()
  
以年龄升序asc
  
db.users.find().sort({age: 1});
  
以年龄降序desc
  
db.users.find().sort({age: -1});
  

  
限制返回记录数量limit()
  
返回5条记录
  
db.users.find().limit(5);
  
返回3条记录并打印信息
  
db.users.find().limit(3).forEach(function(user) {print('my age is ' + user.age)});
  
结果
  
my age is 18
  
my age is 19
  
my age is 20
  

  
限制返回记录的开始点skip()
  
从第3条记录开始,返回5条记录(limit 3, 5)
  
db.users.find().skip(3).limit(5);
  

  
查询记录条数count()
  
db.users.find().count();
  
db.users.find({age:18}).count();
  
以下返回的不是5,而是user表中所有的记录数量
  
db.users.find().skip(10).limit(5).count();
  
如果要返回限制之后的记录数量,要使用count(true)或者count(非0)
  
db.users.find().skip(10).limit(5).count(true);
  

  
分组group()
  
假设test表只有以下一条数据
  
{ domain: "www.mongodb.org"
  
, invoked_at: {d:"2009-11-03", t:"17:14:05"}
  
, response_time: 0.05
  
, http_action: "GET /display/DOCS/Aggregation"
  
}
  
使用group统计test表11月份的数据count:count(*)、total_time:sum(response_time)、avg_time:total_time/count;
  
db.test.group(
  
{ cond: {"invoked_at.d": {$gt: "2009-11", $lt: "2009-12"}}
  
, key: {http_action: true}
  
, initial: {count: 0, total_time:0}
  
, reduce: function(doc, out){ out.count++; out.total_time+=doc.response_time }
  
, finalize: function(out){ out.avg_time = out.total_time / out.count }
  
} );
  

  
[
  
{
  
"http_action" : "GET /display/DOCS/Aggregation",
  
"count" : 1,
  
"total_time" : 0.05,
  
"avg_time" : 0.05
  
}
  
]
  

  
四:日常维护管理:
  
1. #查看collection数据的大小
  

  
  db.deliver_status.dataSize()
  
2#查看colleciont状态
  

  
  db.deliver_status.stats()
  

  
3. #查询所有索引的大小
  

  
  db.deliver_status.totalIndexSize()
  

  
五,mongodb服务维护需知:
  

  
1,mongod 参数说明
  
--dbpath            #指定db文件存放的目录
  
--port              #指定mongod服务使用的端口
  
--fork              #设置mongo服务为后台运行
  
--logpath           #指定log文件的目录和文件名
  
--logappend         #设置每次log添加在文件最后
  
--rest              #关闭rest api功能
  
--nohttpinterface   #关闭web管理功能
  
--auth              #指定mongo使用身份验证机制
  
--bindip            #用逗号分隔ip地址,用来指定
  
--f                 #将所有前面介绍的参数都可以存放到一个配置文件中,然后用这个参数调用配置文件来启动
  
2,mongodb 关闭方法:
  
a. db.shutdownServer()  #推荐优先使用
  
b. ctrl + c             #在不使用 --fork参数的时候可以使用,可能会造成数据文件损坏
  
c. kill / kill -2       #在无法使用 a和b的情况下使用,可能会造成数据文件损坏
  
d. kill -9              #不在万不得已的情况下,不要使用这个方法
  

  
3. 查看MongoDB状态
  
a.db.runCommand({"serverStatus":1})
  
b.MONGO_HOME/bin/mongostat
  

  
4. 添加用户,切换用户 使 --auth参数起效
  
db.addUser("root","123")
  
db.addUser("read_only","123",true);  #第3个参数表示设置readonly的状态
  

  
db.auth("read_only","123")
  

  
5. 数据库备份
  
有4种方法备份数据库
  
a. 关闭mongod服务后,复制--dbpath参数指定的数据文件。优点速度快,缺点需要停止mongo服务。
  
b. 使用mongodump 导出数据,并用mongorestore 导入数据。优点不需要停止mongo服务,缺点在mongodump操作时用户插入的数据可能无法备份出来。
  
c. fsync and lock锁定数据库的让用户只能使用read功能,再使用方法b导出并导入数据。优点不需要停止mongo服务,缺点在数据库lock期间用户无法执行insert操作。
  
d. 使用slaveDB并且 使用方法c锁定slaveDB,再使用方法b导出并导入数据。优点不需要停止mongo服务,不会影响用户insert操作(推荐使用此方法)。
  

  
6. 修复数据库
  
当数据库文件遭到损坏的时候有3种方法修复数据文件
  
a. MONGO_HOME/bin/mongod --repair
  
b. use test
  
db.repairDatabase()
  
c. db.runCommand({"repairDatabase":1});
  

  
7.MongoDB会以令人震惊的方式丢失数据
  
这里 http://coolshell.cn/articles/5826.html 有详解,值得关注一下.
  

  
六,mongodb分布式集群操作
  

  
查看集群分片信息
  
db.printShardingStatus()



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-626251-1-1.html 上篇帖子: CentOS7部署LNMP+Mongodb环境 下篇帖子: NoSQL -- Mongodb 安装 使用 副本集 备份恢复
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表