您的位置:首页 > 健康 > 养生 > 江苏网站建设基本流程_室内设计培训机构排行_阿里指数官网_百度一下就知道官网

江苏网站建设基本流程_室内设计培训机构排行_阿里指数官网_百度一下就知道官网

2024/12/22 11:17:47 来源:https://blog.csdn.net/u014454538/article/details/142684993  浏览:    关键词:江苏网站建设基本流程_室内设计培训机构排行_阿里指数官网_百度一下就知道官网
江苏网站建设基本流程_室内设计培训机构排行_阿里指数官网_百度一下就知道官网

1. 通过tgz包安装MongoDB

1.1 下载并解压缩安装包

  • 官网下载 mac OS 的 MongoDB 安装包,这里选择7.x版本进行安装(下载链接)

  • 下载好的tgz包,双击解压缩,并重命名为mongdb

  • 将安装包拷贝到安装目录,笔者的安装目录为/usr/local,copy时需要root权限

    sudo cp -rf mongdb /usr/local
    

1.2 设置环境变量

  • 对于mac OS,一般通过~/.zshrc设置环境变量。因此,编辑~/.zshrc,添加如下内容

    export MONGODB_HOME=/usr/local/mongodb
    export PATH=$PATH:$MONGODB_HOME/bin
    
  • source ~/.zshrc后,分别执行如下命令,以保证 MongoDB 成功安装

    • mongod:启动 MongoDB 服务对应的命令
      mongod --version
      
    • mongos:启动 MongoDB 代理,即 mongos 对应的命令
      mongos --version
      
    • mongosh:启动 MongoDB 的shell客户端对应的命令
      mongosh --version
      
  • PS: 奇怪的是,笔者下载的是7.0.14的安装包,mongod --version却显示的是6.0.18

2. 启动服务并执行简单的查询

  • 在 Home 目录下创建data目录,用于存储数据,笔者这里选择的data目录为

    mkdir ~/mongodb/data
    

2.1 最简单的服务启动方式

  • 执行mongod命令,指定data目录、以前台运行的方式启动一个 MongoDB 服务

    • 默认端口号:27017,默认接受 0.0.0.0(所有IP)的访问
    • 默认 authorization 为false,即无需用户和密码就能访问
    mongod --dbpath ./data
    
  • 通过 mongosh 开启一个shell,其默认访问 27017 端口

    mongosh
    
  • test 库的 test_data 集合下,插入几条数据

    use test; # 切换数据库
    # 直接插入数据到test_data集合, MongoDB将自动创建test_data集合
    db.test_data.insertMany([{ name: "Bob", age: 25, sex: "male", city: "Los Angeles" },{ name: "Carol", age: 28, sex: "female", city: "Chicago" },{ name: "Dave", age: 35, sex: "male", city: "San Francisco" }
    ])
    
  • 数据插入成功,返回的信息如下:

  • 执行如下命令,查询name为Bob的信息

    db.test_data.find({'name':"Bob"});
    
  • 成功查询到对应的数据

2.2 后台运行MongoDB

  • 上述启动方式,日志直接输出到控制台对于本地开发是足够的
  • 要想后台启动MongoDB、避免服务被误关闭,可以通过指定相关参数实现
    • --dbpath,指定数据目录。--logpath,指定日志目录
    • --port,指定服务运行端口。--bind_ip_all,允许从所有IP地址访问
    • --fork,以守护进程方式运行(后台运行)
    mongod --dbpath /Users/xxx/mongodb/data --logpath  /Users/xxx/mongodb/log \
    --port 27030 --bind_ip_all --fork
    

  • 还可以通过符合 yaml 格式的配置文件,以后台进程的方式启动 MongoDB

  • 在目录下,创建 /Users/xxx/mongodb/etc/mongod.conf文件,内容如下

    storage:dbPath: /Users/xxx/mongodb/datajournal:enabled: true# 网络相关配置
    net:port: 27030bindIp: 0.0.0.0  # 允许从所有IP地址访问# 日志相关配置
    systemLog:destination: filelogAppend: truelogRotate: renamepath: /Users/xxx/mongodb/log/mongo.log# 进程管理相关配置
    processManagement:fork: true  # 以守护进程方式运行(后台运行)# 安全相关配置
    security:authorization: disabled  # 关闭用户认证
    
  • 然后,通过指定config文件,实现服务启动

    mongod --config ~/mongodb/etc/mongod.conf
    # --config可以简写为 -f
    mongod -f ~/mongodb/etc/mongod.conf
    

2.3 后台启动的一些注意事项

  • 配置文件指定路径时,一定要写绝对路径 !!!

  • 不然会根据mongod命令的执行路径自动补全,导致路径未初始化,主要报错信息如下:

    "msg":"Error during global initialization"
    "error":{"code":38,"codeName":"FileNotOpen","errmsg":"Can't initialize rotatable log file :: caused by :: Failed to open /Users/xxx/mongodb/etc/~/mongodb/log/mongod.log"}
    
  • 如果后台启动失败,一般会提示关闭后台启动,也就是说让报错信息直接打印到前台

    • 对于直接mongod --fork的启动方式,其实就是去除 --fork
    • 对于配置文件启动,将 fork: true 改成 fork: false
      在这里插入图片描述

2.4 关于MongoDB的配置文件

  • 从网上能查找的资料,好多配置文件采用旧版写法,有些配置项可能不再支持

  • 例如博客 MongoDB主从复制(master–>slave)环境搭建 中的配置文件,master=true

  • masterslave已经不再支持,会导致MongoDB无法启动,报错信息如下:

    "msg":"Master/slave replication is no longer supported"
    

3. 后记

3.1 MongoDB 诊断命令(Diagnostic Commands)

  • MongoDB Shell 的使用可以参考:MongoDB数据库的基本使用总结
  • MongoDB 提供了丰富的诊断命令:Diagnostic Commands,可以通过这些命令查看连接池、连接数等各种服务状态
  • 甚至,一些数据库函数也可以帮助我们了解MongoDB状态

示例:查看连接数

  • 执行如下命令,可以查看服务的连接情况

    db.serverStatus().connections
    
  • 返回的信息如下,关于db.serverStatus().connections各字段的含义,甚至serverStatus的其他信息,可以参考官方文档:serverStatus

    {current: 5, # 当前活动连接数available: 199, # 剩余可用连接数,current + available可以得出集群的最大连接数totalCreated: 417,  # 自 MongoDB 实例启动以来创建的总连接数active: 2, # 连接到服务器的活跃client数量threaded: 5,exhaustIsMaster: 0,exhaustHello: 1,awaitingTopologyChanges: 1,loadBalanced: Long('0')
    }
    

3.2 参考链接

  • Mac OS 安装 MongoDB 详细步骤

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com