在Mac上搭建MongoDB环境

news2025/1/18 21:14:25

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

目录

使用Homebrew安装MongoDB

手动安装MongoDB(不使用Homebrew)

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

执行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),选择适合的版本下载。

  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等),保存文件,并重新加载配置或重启你的终端。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1455528.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

嵌入式第十七天!(文件IO)

文件IO&#xff1a; 标准IO和文件IO的区别&#xff1a; 1. 标准IO是库函数&#xff0c;是对系统调用的封装 2. 文件IO是系统调用&#xff0c;是Linux内核中的函数接口 3. 标准IO是有缓存的 4. 文件IO是没有缓存的 1. 操作步骤&#xff1a; 打开 -> 读/写 -> 关闭 2. 打开…

PyCharm - Script parameters (脚本参数)

PyCharm - Script parameters [脚本参数] References Run -> Edit Configurations… -> Run/Debug Configurations -> Configuration -> Script parameters 命令行&#xff1a; python display_yolo_log.py ./person_training_log/person_train_log_DIMM40_stdout…

Github 2024-02-12 开源项目日报 Top10

根据Github Trendings的统计&#xff0c;今日(2024-02-12统计)共有10个项目上榜。根据开发语言中项目的数量&#xff0c;汇总情况如下&#xff1a; 开发语言项目数量Rust项目3Python项目3JavaScript项目1TypeScript项目1C项目1C项目1PowerShell项目1非开发语言项目1 SubQuery…

NoSQL 数据库有哪些类型?

NoSQL 数据库主要可以分为下面四种类型&#xff1a; 键值&#xff1a;键值数据库是一种较简单的数据库&#xff0c;其中每个项目都包含键和值。这是极为灵活的 NoSQL 数据库类型&#xff0c;因为应用可以完全控制 value 字段中存储的内容&#xff0c;没有任何限制。Redis 和 D…

[AIGC] 利用 chatgpt 深入理解 Java 虚拟机(JVM)

Java 虚拟机&#xff08;JVM&#xff09;是 Java 编程语言的核心运行环境&#xff0c;它负责解释和执行 Java 字节码。它是 Java 程序能够跨平台运行的关键&#xff0c;因为不同的操作系统和硬件平台都有自己的指令集和体系结构&#xff0c;而 JVM 则提供了一个统一的运行环境&…

springsecurity记住我登录时访问无权限接口,跳转登录界面

贴一下springsecurity无权限时异常处理的逻辑 未登录状态&#xff1a;如果用户尝试访问需要认证的资源但未登录&#xff0c;即未经过认证&#xff0c;在这种情况下应该跳转到登录页面或者返回登录提示&#xff0c;让用户进行身份验证。通过调用 AuthenticationEntryPoint 可以统…

BufferedImage 这个类在jdk17中使用哪个import导入

在Java开发中&#xff0c;BufferedImage 类是用于处理图像数据的一个类。在JDK 17中&#xff0c;BufferedImage 类属于 java.awt.image 包。因此&#xff0c;要在你的Java程序中使用 BufferedImage 类&#xff0c;你需要通过以下方式导入该类&#xff1a; import java.awt.ima…

鸿蒙-基于ArkTS声明式开发的简易备忘录,适合新人学习,可用于大作业

本文地址&#xff1a;https://blog.csdn.net/qq_40785165/article/details/136161182?spm1001.2014.3001.5502&#xff0c;转载请附上此链接 大家好&#xff0c;我是小黑&#xff0c;一个还没秃头的程序员~~~ 不知不觉已经有很长一段时间没有分享过自己写的东西了&#xff0…

MQTT协议-ISO标准下基于发布/订阅范式的消息协议

MQTT(消息队列遥测传输)是ISO 标准(ISO/IEC PRF 20922)下基于发布/订阅范式的消息协议。它工作在 TCP/IP协议族上&#xff0c;是为硬件性能低下的远程设备以及网络状况糟糕的情况下而设计的发布/订阅型消息协议&#xff0c;为此&#xff0c;它需要一个消息中间件 。 MQTT是一个…

【力扣 - 环形链表】

题目描述 给你一个链表的头节点 head &#xff0c;判断链表中是否有环。 如果链表中有某个节点&#xff0c;可以通过连续跟踪 next 指针再次到达&#xff0c;则链表中存在环。 为了表示给定链表中的环&#xff0c;评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置&a…

5 个免费的数字取证工具可促进您的调查

数字取证在分析和解决网络攻击方面发挥着至关重要的作用&#xff0c;也是事件响应的关键组成部分。此外&#xff0c;数字取证还可以在攻击发生后为审计人员、法律团队和执法机构提供重要信息。 市场上有许多尖端的数字取证工具&#xff0c;但对于那些买不起的人来说&#xff0…

centos7.9如何关闭系统的自动更新功能

要关闭 CentOS 7.9 的自动更新功能&#xff0c;你需要禁用并停止 yum-cron 服务。以下是具体步骤&#xff1a; 停止 yum-cron 服务&#xff1a; 你需要首先停止正在运行的 yum-cron 服务。 systemctl stop yum-cron禁用 yum-cron 服务&#xff1a; 停止服务后&#xff0c;确保它…

【日常聊聊】深度学习进度

&#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a;日常聊聊 ⛳️ 功不唐捐&#xff0c;玉汝于成 目录 前言 正文 方向一&#xff1a;深度学习的基本原理和算法 方向二&#xff1a;深度学习的应用实例 方向三&#xff1a;深度学习的挑战和未…

生成式 AI - Diffusion 模型的数学原理(4)

来自 论文《 Denoising Diffusion Probabilistic Model》&#xff08;DDPM&#xff09; 论文链接&#xff1a; https://arxiv.org/abs/2006.11239 Hung-yi Lee 课件整理 文章目录 一、 q &#xff08; x t ∣ x t − 1 &#xff09; q&#xff08;x_{t} \mid x_{t-1} &#xff…

LabVIEW轨道交通列车牵引制动试验平台

LabVIEW轨道交通列车牵引制动试验平台 概述 面对城市轨道交通领域对于高效、准确牵引制动系统的迫切需求&#xff0c;开发了一套基于LabVIEW软件与硬件相结合的试验平台。该平台模拟列车的牵引、制动等工况&#xff0c;通过高精度的数据采集与实时图形化展示&#xff0c;提升…

学校图书馆管理系统的架构设计与实现

随着大学生越来越多&#xff0c;学校图书馆的管理变得愈发复杂。为了更好地管理和服务于学生和教职工&#xff0c;学校需要建立一个高效的图书馆管理系统。本文将介绍学校图书馆管理系统的架构设计与实现。 1. 架构设计 学校图书馆管理系统的架构设计主要分为三个部分&#x…

LNMP搭建discuz论坛

discuz论坛是一种网络论坛软件&#xff0c;也称bbs&#xff0c;它是一种用于在互联网上建立论坛社区的程序系统。只哟中功能强大的论坛软件&#xff0c;可以帮助用户建立一个专业、完善的论坛社区&#xff0c;并且可以实现多种功能&#xff0c;如搭建用户注册、登录、查看主题、…

JMeter 配置元件之按条件读取CSV Data Set Config

实践环境 win10 JMeter 5.4.1 需求描述 需求是这样的&#xff0c;需要压测某个接口(取消分配接口)&#xff0c;请求这个接口之前&#xff0c;需要先登录系统(物流WMS系统)&#xff0c;并在登录后&#xff0c;选择并进入需要操作的仓库&#xff0c;然后请求接口&#xff0c;…

Ubuntu22.04LTS编译Frida历史版本,环境配制及细节调整

经常使用Frida的朋友们可能会遇到Frida的各种问题需要自定义的&#xff0c;而这时候Frida的本地编译就显得很重要了。 最近一位朋友发现使用Frida14/15/16版的server只能连拉一定数量的设备&#xff0c;超过了frida-device-manager便不能连接设备。 实现没有办法&#xff0c;…

Ubuntu22.04上作业调度管理软件PBS Torque的安装、配置及主要使用方法

文章目录 前言一、PBS及Torque是什么&#xff1f;二、Ubuntu22.04上Torque的安装和配置步骤1. 更新系统软件包2. 安装必要的软件包3. 下载和安装Torque4. 配置Torque5. 设置环境变量6. 配置和启动Torque服务7. 配置计算节点8. 创建队列的信息&#xff0c;名称 batch0019. 提交测…