无法连接MongoDB本地27017端口?

连接MongoDB数据库

# 连接远程服务器(示例)
mongo --host 192.168.1.100 --port 27017 -u admin -p password

数据库操作

> show dbs                  # 查看所有数据库
> use mydb                  # 切换到mydb数据库(不存在则创建)
> db.dropDatabase()         # 删除当前数据库
> db.getName()              # 查看当前数据库名

集合(表)管理

> db.createCollection("users")             # 创建集合
> show collections                         # 显示所有集合
> db.users.drop()                          # 删除集合
> db.users.stats()                         # 查看集合统计信息

文档(记录)操作

插入数据

> db.users.insertOne({name: "张三", age: 28, email: "zhang@example.com"})
> db.users.insertMany([
    {name: "李四", age: 32},
    {name: "王五", age: 25}
])

查询数据

> db.users.find()                          # 查询所有文档
> db.users.findOne({age: {$gt: 30}})       # 查找年龄>30的第一条记录
> db.users.find().sort({age: -1}).limit(5) # 按年龄降序取前5条

更新数据

> db.users.updateOne(
    {name: "张三"},
    {$set: {age: 29, status: "active"}}    # 更新指定字段
)
> db.users.updateMany(
    {age: {$lt: 30}},
    {$inc: {age: 1}}                       # 年龄+1
)

删除数据

> db.users.deleteOne({name: "李四"})
> db.users.deleteMany({status: "inactive"})

索引管理

> db.users.createIndex({email: 1})         # 创建升序索引
> db.users.createIndex({name: 1, age: -1}) # 复合索引
> db.users.getIndexes()                    # 查看所有索引
> db.users.dropIndex("email_1")            # 删除索引

用户权限管理

# 管理员连接后创建用户
> use admin
> db.createUser({
    user: "webadmin",
    pwd: "securepass123",
    roles: [{
        role: "readWrite", 
        db: "mydb"
    }]
})
# 修改密码
> db.changeUserPassword("webadmin", "newpass456")

数据导入导出

# 导出JSON数据
mongoexport --db mydb --collection users --out users.json
# 导入JSON数据
mongoimport --db mydb --collection users --file users.json
# 导出CSV
mongoexport --type=csv --fields name,age --db mydb --collection users

备份与恢复

# 全库备份
mongodump --host localhost --out /backup/20251001
# 单库备份
mongodump --db mydb --archive > mydb_backup.gz
# 恢复数据
mongorestore --db mydb /backup/20251001/mydb

性能监控

> db.currentOp()                  # 查看当前操作
> db.serverStatus()               # 服务器状态
> db.users.explain().find(...)    # 查询分析
> db.collection.totalIndexSize()  # 索引大小

安全退出与日志

> exit          # 退出mongo shell
Ctrl + C        # 强制退出
# 查看日志(Linux系统)
tail -f /var/log/mongodb/mongod.log

注意事项

  1. 生产环境必做

    • 启用身份验证 security.authorization: enabled
    • 定期备份关键数据
    • 使用--tls参数加密连接
  2. 操作警告

    > db.users.update({}, {$unset: {phone:1}}, {multi:true})  # 批量操作前先测试
    > db.runCommand({collMod: "users", validator: {...}})     # 模式变更需停服维护
  3. 效率优化

    • 查询时使用.projection()限制返回字段
    • 避免全集合扫描(COLLSCAN
    • 索引内存占用不超过RAM的70%

引用说明:本文操作基于MongoDB 6.0+版本,参考MongoDB官方文档[1],关键安全配置遵循OWASP数据库安全标准[2],备份策略建议采用3-2-1原则(3份副本,2种介质,1份异地)[3]。

[1] MongoDB Command Line Tools Documentation
[2] OWASP Database Security Cheat Sheet
[3] NIST SP 800-209 Security Guidelines for Storage Infrastructure

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/5332.html

(0)
酷番叔酷番叔
上一篇 2025年6月22日 19:43
下一篇 2025年6月22日 20:24

相关推荐

  • August.js是什么?

    August.js 是一个轻量级、高性能的前端 JavaScript 框架,专为构建现代化的单页应用(SPA)而设计,它以简洁的 API、灵活的架构和出色的性能著称,尤其适合中小型项目或对性能要求较高的场景,本文将详细介绍 August.js 的核心特性、使用方法以及最佳实践,帮助开发者快速上手并高效开发,核心……

    2025年12月14日
    6100
  • Windows命令提示符如何换行?

    命令行窗口(交互式)换行在cmd窗口中直接输入长命令时,使用 ^(脱字符) 作为换行转义符:在需要换行处输入 ^,确保^后无空格,按回车键,下一行开头显示 More?,继续输入命令剩余部分,最后按回车执行完整命令,示例:echo This is a very long command ^that spans t……

    2025年7月19日
    11900
  • 智慧医疗如何让安享从概念走进健康日常?

    随着信息技术的飞速发展,智慧医疗正逐步从概念走向现实,成为提升医疗服务效率、改善患者就医体验的重要力量,所谓“安享智慧医疗”,不仅是指技术层面的智能化升级,更强调通过科技赋能,让每个人都能便捷、安全、有尊严地获得优质医疗服务,真正实现“病有所医”的安心与舒心,从挂号问诊到康复管理,从疾病预防到精准治疗,智慧医疗……

    2025年11月15日
    8200
  • 3ds Max切片命令如何精准切割模型?

    3ds Max的切片命令是精准切割模型的利器,它允许用户创建切割平面,精确控制位置和角度,将模型一分为二或添加新分段,是建模和修改拓扑结构的关键工具。

    2025年6月23日
    14100
  • 安全数据记录仪的正确使用方法和操作步骤是怎样的?

    安全数据记录仪是一种用于实时采集、存储和分析设备运行状态、环境参数及操作行为的智能化装置,广泛应用于工业制造、交通运输、安防监控、能源管理等领域,其核心价值在于通过持续记录关键数据,为事故溯源、风险预警、合规审计及效率优化提供可靠依据,是提升安全管理水平的重要工具,安全数据记录仪的核心功能模块及具体说明如下表所……

    2025年10月31日
    7400

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信