在Mac上搭建MongoDB环境

最近工作中需要装MongoDB环境,搭建过程中遇到了一些问题,在这里记录一下安装MongoDB环境的方法以及问题的解决方法。有两种安装MongoDB的方法:brew安装和手动安装。

目录

使用Homebrew安装MongoDB

手动安装MongoDB(不使用Homebrew)

两种安装方式对应的卸载方法

[执行mongo命令提示command not found](#执行mongo命令提示command not found)


使用Homebrew安装MongoDB

  1. 安装Homebrew(如果你还没有安装): 打开终端(Terminal)并运行以下命令来安装Homebrew:

    /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
    

    安装完成后,运行以下命令以确保Homebrew安装正确:

    brew doctor
    
  2. 通过Homebrew安装MongoDB: MongoDB官方已经不支持通过Homebrew直接安装,但你可以使用第三方tap来安装。在终端运行以下命令:

    brew tap mongodb/brew brew install mongodb-community
    
  3. 启动MongoDB服务 : 你可以使用brew服务来启动MongoDB:

    brew services start mongodb/brew/mongodb-community
    

    这将配置MongoDB作为后台服务启动。执行这条命令遇到了报错:

    Error: uninitialized constant Homebrew::Service::System
    /usr/local/Homebrew/Library/Homebrew/macos_version.rb:150:in `const_missing'
    /usr/local/Homebrew/Library/Taps/homebrew/homebrew-services/cmd/services.rb:61:in `services'
    /usr/local/Homebrew/Library/Homebrew/brew.rb:94:in `<main>'
    

    这个错误信息表明在尝试使用Homebrew的services命令时遇到了问题。Homebrew::Service::System是一个未初始化的常量,这通常意味着Homebrew的某部分没有正确加载或者Homebrew本身可能存在损坏。

    为了解决这个问题,可以尝试以下几个步骤:(1)更新Homebrew: 运行以下命令以确保Homebrew和所有的tap都是最新的:

    brew update 
    brew upgrade
    

    (2)检查Homebrew的健康状况: 运行以下命令来检查Homebrew的状态,并修复任何报告的问题:

    brew doctor 
    

    (3)重新启动你的计算机 : 有时候,简单地重新启动计算机可以解决临时的系统问题。 以上三步都没有解决我的问题。 (4)重新安装Homebrew服务: 如果更新和修复之后问题仍然存在,尝试卸载Homebrew服务然后重新安装:

    brew untap homebrew/services 
    brew tap homebrew/services
    

    这一步解决了我的问题。(5)检查Homebrew的版本: 确保你的Homebrew版本是最新的。运行以下命令查看当前版本:

    brew --version
    

    如果不是最新的,再次运行brew update。(6)重新安装Homebrew : 如果以上步骤都不能解决问题,你可能需要重新安装Homebrew。首先,备份你当前的Homebrew安装(包括已安装的包),然后根据Homebrew的文档进行重新安装。如果在尝试这些步骤之后问题依然存在,你可能需要查看Homebrew的GitHub仓库中的Issues页面看看是否有其他人遇到了类似的问题,或者创建一个新的Issue求助。 启动mongodb服务成功:

  4. 验证MongoDB是否正在运行: 在终端运行以下命令来连接MongoDB服务器:

    mongo
    

    如果MongoDB已经启动,你将看到MongoDB shell的提示符。这一步我又遇到了问题:

    qa@QAdeMacBook-Pro ~ % mongo
    zsh: command not found: mongo
    

    这意味着 mongo shell 并不在你的系统 PATH 环境变量中。这通常发生在以下几种情况:(1)MongoDB shell没有安装 :在某些情况下,MongoDB服务器和MongoDB shell是分开安装的。确保你已经安装了包含mongo shell的MongoDB包。(2)PATH环境变量未正确设置 :当你安装MongoDB时,mongo shell的可执行文件应该位于MongoDB的bin目录中。你需要确保这个目录被添加到了你的PATH环境变量中。解决这个问题的步骤如下:(1)确认mongo shell是否安装 : 你可以通过brew list命令检查是否安装了mongo shell:

    brew list | grep mongo
    

    如果这个命令返回了与mongodb-community相关的结果,那么mongo shell应该已经安装了。(2)添加MongoDB的bin目录到PATH : 找到MongoDB的安装目录,并将其bin目录添加到你的PATH环境变量中。通常,如果你是通过Homebrew安装的MongoDB,它的bin目录可能位于/usr/local/opt/mongodb-community/bin。你可以通过以下命令将其添加到你的.zshrc文件中:

    echo 'export PATH="/usr/local/opt/mongodb-community/bin:$PATH"' >> ~/.zshrc
    

    然后,运行source ~/.zshrc来重新加载你的配置,或者重新打开一个终端窗口。(3)验证PATH环境变量 : 使用echo $PATH命令来确认PATH环境变量是否包含了MongoDB的bin目录。(4)再次尝试运行mongo shell : 在终端中输入mongo并回车,看看是否能够启动MongoDB shell。如果你按照上述步骤操作后仍然无法运行mongo命令,可能需要重新安装MongoDB shell或者进一步检查你的系统配置。我按照要求设置了环境变量,还是会有这个报错。如果要停止使用brew services启动的MongoDB服务,你可以执行以下命令:

    brew services stop mongodb
    

    如果你的MongoDB是通过mongodb-community包安装的,你可能需要执行:

    brew services stop mongodb-community
    

    如果你想查看所有通过brew services管理的服务的状态,可以使用:

    brew services list
    

    这将列出所有服务及其当前状态(如已启动、已停止等)。这样,你就可以轻松管理你的MongoDB服务以及任何其他使用Homebrew安装的后台服务。

手动安装MongoDB(不使用Homebrew)

  1. 下载MongoDB : 访问MongoDB官方网站下载页(https://www.mongodb.com/try/download/community),选择适合的版本下载。![](https://file.jishuzhan.net/article/1759488276638470145/1c4aa425c9974e7cf6a92f052b5902da.webp)![](https://file.jishuzhan.net/article/1759488276638470145/a8af44c7dee2baa8d1ee802368ac437e.webp)

  2. 解压MongoDB压缩包: 下载完成后,解压MongoDB压缩包到一个你选择的目录。

  3. 配置环境变量 : 将MongoDB目录的bin文件夹添加到你的PATH环境变量中。你可以在~/.bash_profile~/.zshrc或你的shell配置文件中添加以下行:

    export PATH=<MongoDB安装目录>/bin:$PATH
    

    替换<MongoDB安装目录>为你的实际安装路径。/Users/qa/Downloads/mongodb-macos-x86_64-7.0.4/bin,export PATH="/Users/qa/Downloads/mongodb-macos-x86_64-7.0.4/bin:$PATH"

  4. 创建数据和日志目录 : 默认情况下,MongoDB将数据存储在/data/db目录中,但你需要手动创建这个目录:

    sudo mkdir -p /data/db 
    sudo chown `id -un` /data/db
    

    你也可以选择其他目录来存储数据,但需要在启动MongoDB时指定。执行sudo mkdir -p /data/db 报错mkdir: /data: Read-only file system。

    在macOS上,特别是从Catalina (10.15) 版本开始,系统引入了只读的系统卷,这意味着你不能直接在根目录(/)下创建或修改文件夹,因此你会遇到 "Read-only file system" 的错误。

    为了解决这个问题,你可以在用户的主目录或其他非系统保护区域创建数据目录。例如,你可以在你的主目录下创建一个db目录:(1)打开终端。(2)运行以下命令来创建一个名为mongodb-data的目录(你可以根据自己的需要命名这个目录):

    mkdir -p ~/mongodb-data
    

    (3)然后你需要告诉MongoDB使用这个新的数据目录。当你启动mongod服务时,使用--dbpath选项指定数据目录的路径:

    mongod --dbpath ~/mongodb-data
    

    这样,MongoDB就会使用你在主目录下创建的mongodb-data文件夹来存储数据,而不是默认的/data/db目录。

    请注意,如果你是通过Homebrew安装的MongoDB,并且希望使用brew services来管理MongoDB服务,你可能需要修改Homebrew服务的配置文件来指定新的数据目录路径。这通常涉及到编辑MongoDB的plist文件(位于/usr/local/Cellar/mongodb-community/{version}/homebrew.mxcl.mongodb-community.plist,其中{version}需要替换为实际安装的版本号),并在其中添加--dbpath选项。

  5. 启动MongoDB: 在终端运行以下命令来启动MongoDB:

    mongod
    

    如果你更改了数据存储目录,使用--dbpath选项指定路径:

    mongod --dbpath <你的数据目录路径>
    
  6. 连接MongoDB: 打开另一个终端窗口,运行以下命令连接MongoDB:

    mongo
    

当我启动mongodb服务时,遇到了错误:

{"t":{"$date":"2023-12-29T15:46:46.054+08:00"},"s":"E",  "c":"CONTROL",  "id":20568,   "ctx":"initandlisten","msg":"Error setting up listener","attr":{"error":{"code":9001,"codeName":"SocketException","errmsg":"setup bind :: caused by :: Address already in use"}}}
{"t":{"$date":"2023-12-29T15:46:46.054+08:00"},"s":"I",  "c":"REPL",     "id":4784900, "ctx":"initandlisten","msg":"Stepping down the ReplicationCoordinator for shutdown","attr":{"waitTimeMillis":15000}}
{"t":{"$date":"2023-12-29T15:46:46.054+08:00"},"s":"I",  "c":"REPL",     "id":4794602, "ctx":"initandlisten","msg":"Attempting to enter quiesce mode"}
{"t":{"$date":"2023-12-29T15:46:46.054+08:00"},"s":"I",  "c":"-",        "id":6371601, "ctx":"initandlisten","msg":"Shutting down the FLE Crud thread pool"}
{"t":{"$date":"2023-12-29T15:46:46.054+08:00"},"s":"I",  "c":"COMMAND",  "id":4784901, "ctx":"initandlisten","msg":"Shutting down the MirrorMaestro"}

Error setting up listener

这表明MongoDB服务在尝试绑定到某个网络地址(如localhost)和端口(默认是27017)时遇到了问题。错误的具体内容是:

Address already in use

这意味着MongoDB服务尝试绑定的端口已经被其他进程占用了。在大多数情况下,这是因为另一个MongoDB实例已经在运行,或者有其他服务正在使用该端口。

要解决这个问题,你可以采取以下步骤:

  1. 查找占用端口的进程 :你可以使用lsofnetstat命令来查找哪个进程正在使用27017端口。例如:

    lsof -i :27017
    

    或者

    netstat -anp | grep 27017
    

    这将列出所有使用27017端口的进程信息。

  2. 结束占用端口的进程 :如果确定是MongoDB的另一个实例占用了端口,并且你确定要关闭它,你可以使用kill命令来结束该进程。例如:

    kill <PID>
    

    其中<PID>是占用端口的进程ID。

  3. 重新启动MongoDB服务:在结束占用端口的进程之后,你可以尝试再次启动MongoDB服务:

    mongod --dbpath ~/mongodb-data
    

以上就是在Mac上搭建MongoDB环境的基本步骤。如果有任何问题,可以参考MongoDB的官方文档或者在安装过程中查看终端中的错误信息。

两种安装方式对应的卸载方法

如果你在电脑上既使用Homebrew安装了MongoDB,又手动安装了MongoDB,并为它们配置了不同的环境变量,可能会遇到以下问题:

  1. 端口冲突:MongoDB默认使用27017端口。如果两个MongoDB实例都尝试使用同一个端口,那么后启动的实例将无法绑定到该端口上,因为它已经被第一个实例占用了。

  2. 配置混淆:如果你为两个MongoDB实例设置了不同的环境变量,可能会导致运行时的配置混淆。例如,当你尝试启动或与MongoDB交互时,你可能不确定正在使用哪个版本的MongoDB实例。

  3. 路径冲突:如果两个MongoDB实例配置的数据目录或日志目录相同,可能会导致数据覆盖或损坏。

  4. 版本冲突:如果两个MongoDB实例的版本不同,可能会导致客户端工具、驱动程序或应用程序与MongoDB实例的兼容性问题。

  5. 管理复杂性:维护两个MongoDB实例意味着你需要记住两套配置、两个不同的命令集以及两个服务的启动和停止方式,这增加了管理的复杂性。

为了避免这些问题,建议你选择一种安装方式,并且坚持使用它:

  • 如果选择Homebrew :你可以通过brew services管理MongoDB服务,并且依赖Homebrew来处理版本更新和路径配置。

  • 如果选择手动安装:你需要自己管理MongoDB的启动、停止、配置和更新。

卸载用Homebrew安装的MongoDB,可以运行:

brew services stop mongodb 
brew uninstall mongodb

如果你想删除手动安装的MongoDB,你需要停止服务(如果它正在运行),然后删除MongoDB的文件夹和配置文件。

在做出决定之前,请确保备份所有重要的数据,以免在卸载过程中丢失。

执行mongo命令提示command not found

首先想到的原因是没有配置环境变量会有这个问题,

即使你已经配置过环境变量,这可能是由以下原因引起的:

  1. 环境变量未生效 :你可能在配置文件中正确设置了环境变量,但是更改可能还没有生效。你可以通过关闭并重新打开你的终端窗口来刷新环境变量,或者在当前终端中运行source ~/.bash_profile(或对应的配置文件,比如~/.zshrc~/.bashrc等,取决于你使用的shell)来使更改立即生效。

  2. 错误的环境变量路径 :你可能在环境变量中设置了错误的路径。检查你的.bash_profile.bashrc.zshrc或其他shell配置文件中的PATH环境变量,确保它包含了MongoDB的可执行文件目录。对于Homebrew安装的MongoDB,它通常位于/usr/local/bin目录中。

  3. 配置文件未加载 :如果你使用的是非常规的shell或者有特殊的配置,可能你的环境变量配置文件(如.bash_profile.bashrc.zshrc等)没有被加载。确保你在正确的文件中添加了环境变量,并且这个文件在你的shell启动时会被读取。

  4. 多个MongoDB版本 :由于你提到电脑上同时用brew安装了MongoDB,也手动安装了MongoDB,可能存在多个版本的MongoDB。确保你的PATH环境变量指向的是你想要使用的MongoDB版本的路径。

  5. 权限问题 :可能是由于权限问题导致的。确认mongo命令的可执行文件是否具有适当的执行权限。

  6. Shell不识别更改 :如果你使用的是zsh而不是bash,你需要在.zshrc而不是.bash_profile中设置环境变量。

你可以通过执行以下命令来确认mongo命令的位置:

which mongo

或者查找系统中所有mongo命令的位置:

find / -name mongo 2>/dev/null

如果以上命令返回了mongo命令的路径,确保这个路径被包含在你的PATH环境变量中。如果命令没有返回任何路径,那么可能你的MongoDB没有安装正确,或者mongo命令的路径没有被加入到PATH中。

一旦你找到了正确的mongo命令路径,你可以通过以下命令将它添加到你的PATH环境变量中(假设mongo命令位于/path/to/mongo/bin):

export PATH="/path/to/mongo/bin:$PATH"

然后将这行添加到你的shell配置文件中(.bash_profile.bashrc.zshrc等),保存文件,并重新加载配置或重启你的终端。

相关推荐
Leo.yuan5 分钟前
数据量大Excel卡顿严重?选对报表工具提高10倍效率
数据库·数据分析·数据可视化·powerbi
Runing_WoNiu14 分钟前
MySQL与Oracle对比及区别
数据库·mysql·oracle
天道有情战天下35 分钟前
mysql锁机制详解
数据库·mysql
看山还是山,看水还是。37 分钟前
Redis 配置
运维·数据库·redis·安全·缓存·测试覆盖率
谷新龙00141 分钟前
Redis运行时的10大重要指标
数据库·redis·缓存
CodingBrother42 分钟前
MySQL 中单列索引与联合索引分析
数据库·mysql
精进攻城狮@1 小时前
Redis缓存雪崩、缓存击穿、缓存穿透
数据库·redis·缓存
小酋仍在学习1 小时前
光驱验证 MD5 校验和
数据库·postgresql
keep__go1 小时前
Linux 批量配置互信
linux·运维·服务器·数据库·shell
小王同学mf1 小时前
怎么尽可能保证 Kafka 的可靠性
数据库