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

相关推荐

  • 安全大数据如何与众不同?

    安全大数据如何与众不同在数字化时代,数据已成为企业和社会运营的核心资产,海量数据的积累也带来了前所未有的安全挑战,传统的安全防护手段往往依赖于规则库和已知威胁特征,难以应对复杂多变的网络攻击,安全大数据的出现,通过技术创新和应用模式的变革,重新定义了安全防护的边界,安全大数据究竟如何与众不同?本文将从技术架构……

    2025年11月24日
    4300
  • 安全实时传输协议究竟是什么?

    安全实时传输协议(Secure Real-time Transport Protocol,简称SRTP)是一种为实时媒体流(如语音、视频、数据)提供机密性、完整性和认证的安全协议,它基于实时传输协议(RTP)构建,通过加密、消息认证和重放防护等机制,保护媒体内容在传输过程中不被窃听、篡改或伪造,SRTP广泛应用……

    2025年11月3日
    6300
  • Mac如何打开终端?

    在Mac上打开终端的方法: ,1. 打开「启动台」→「其他」文件夹→点击「终端」图标 ,2. 按 Command+空格 打开聚焦搜索,输入”终端”回车 ,3. 进入「访达」→「应用程序」→「实用工具」→双击「终端」 ,启动后即可使用命令行操作。

    2025年7月15日
    12500
  • 3ds Max布尔运算怎么取消?

    情况1:操作过程中取消(未确认结果)直接按 Esc 键:执行布尔命令时(如差集/并集/交集),若未点击最终确认,按键盘左上角 Esc 键可立即中断操作,撤销上一步(Ctrl+Z):若误操作已完成但未保存,使用 Ctrl+Z 回退到布尔前的状态,情况2:操作后取消(已生成布尔对象)方法1:通过修改器堆栈删除选中布……

    2025年7月10日
    9100
  • 强制关机真的伤电脑吗?,(注,严格控制在30字内,采用疑问句式引发好奇,使用强制关机替代专业术语shutdown更易理解,痛点明确吸引点击)

    shutdown命令用于安全关闭或重启计算机系统,它支持定时关机、立即关机、重启操作,并可向用户发送警告消息,管理员还能远程关闭网络中的其他计算机,是系统维护的关键工具。

    2025年7月24日
    10400

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信