无法连接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

相关推荐

  • 国内云计算与虚拟化技术究竟有何区别?

    虚拟化是技术手段,将物理资源转化为虚拟资源;云计算是服务模式,通过网络按需交付资源。

    2026年2月6日
    9400
  • 网络安全动态具体包含哪些全面的核心信息内容与监测要素?

    当前,安全动态已从单一的技术防护扩展为覆盖网络、数据、物理、新兴技术等多维度的综合体系,其核心在于应对快速演变的威胁形态与复杂的应用场景,无论是国家关键信息基础设施、企业核心业务系统,还是个人日常数字生活,安全动态的演进都直接影响着信息社会的稳定运行,以下从多个维度解析安全动态的核心内容,展现其当前的发展态势与……

    2025年11月17日
    12400
  • 国内BI使用说明,如何轻松上手商业智能工具?

    选择易用的国产BI,连接数据后通过拖拽生成报表,参考官方教程即可快速上手。

    2026年3月4日
    6800
  • CAD打断命令怎么用?操作方法与步骤详解

    在CAD绘图过程中,经常需要将已有的线段、圆弧等对象分割为两部分或删除其中一段,打断”命令便成为高效完成此类操作的关键工具,该命令通过指定点将对象断开,支持直线、圆弧、圆、多段线等多种对象类型,灵活运用可大幅提升绘图效率,下面将从命令启动、操作步骤、实例演示及注意事项等方面详细解析打断命令的使用方法,打断命令的……

    2025年8月31日
    14400
  • CentOS停更后如何选择替代方案?

    chspace 命令详解与使用指南chspace 是 LVM(Logical Volume Manager) 环境中的一个实用命令,主要用于 修改 LVM 精简池(Thin Pool)中逻辑卷(Thin LV)的元数据空间大小,当元数据空间不足导致操作失败时(如 lvextend 报错),此命令至关重要,📌 核……

    2025年7月24日
    17200

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信