Docs 菜单
Docs 主页
/
MongoDB Manual
/ / /

在 Red Hat 或 CentOS 上安装 MongoDB Community Edition

在此页面上

  • 概述
  • 考虑因素
  • 安装 MongoDB Community Edition
  • 运行 MongoDB Community Edition
  • 卸载 MongoDB Community Edition
  • 更多信息

注意

MongoDB Atlas

MongoDB Atlas是云中托管的 MongoDB 服务选项,无需安装开销,并提供免费入门套餐。

使用本教程,使用 yum软件包管理器在 Red Hat Enterprise Linux、CentOS Linux 或 Oracle Linux [1]上安装 MongoDB 7.0 Community Edition。

本教程安装的是 MongoDB 7.0 Community Edition。想要安装不同版本的 MongoDB Community Edition,请移步本页面左上角的版本下拉菜单,选择该版本对应的文档进行参照。

MongoDB 7.0 社区版支持以下采用 x86_64 架构的 64 位 Red Hat Enterprise Linux (RHEL)、CentOS Linux、Oracle Linux [1]、Rocky Linux 和 AlmaLinux [2] 版本:

  • RHEL / CentOS Stream / Oracle / Rocky / AlmaLinux 9

  • RHEL / CentOS Stream / Oracle / Rocky / AlmaLinux 8

  • RHEL / CentOS / Oracle 7

MongoDB 仅支持这些平台的 64 位版本。

RHEL/CentOS/Oracle/Rocky/Alma Linux 上的 MongoDB 7.0 Community Edition 还支持部分平台上的 ARM64 架构。

更多信息,请参阅平台支持

[1](1, 2) MongoDB 仅支持运行 Red Hat Compatible Kernel (RHCK) 的 Oracle Linux。MongoDB 支持 Unbreakable Enterprise Kernel (UEK)。
[2] 针对 RHEL 版本 8.0+ 发布的 MongoDB 本地部署产品,与 Rocky Linux 版本 8.0+ 和 AlmaLinux 版本 8.0+ 兼容并受支持(前提是这些发行版能满足其承诺,提供完整的 RHEL 兼容性)。

在生产环境部署 MongoDB 之前,请考虑生产环境说明文档,其中提供了有关生产环境中 MongoDB 部署的性能注意事项和配置建议。

按照以下步骤使用 yum 软件包管理器安装 MongoDB Community Edition。

1

创建 /etc/yum.repos.d/mongodb-org-7.0.repo 文件,以便直接使用 yum 来安装 MongoDB:

您也可以直接从.rpm MongoDB 存储库 下载 文件 。下载按 Red Hat/CentOS 版本(例如9 )、MongoDB 发布版本 (例如7.0 )和架构(例如x86_64 )进行组织。

在 MongoDB 5.0 之前,奇数 MongoDB 发布版本(例如 4.3)为开发版本。从 MongoDB 5.1 开始,MongoDB 每季度进行快速发布。有关快速发布版本与长期支持版本之间区别的更多信息,请参阅 MongoDB 版本控制

2

要安装最新稳定版 MongoDB,请执行以下命令:

sudo yum install -y mongodb-org

要安装 MongoDB 的特定版本,需单独指定各组件包并在软件包名称后面加上版本号,如下例所示:

sudo yum install -y mongodb-org-7.0.7 mongodb-org-database-7.0.7 mongodb-org-server-7.0.7 mongodb-mongosh-7.0.7 mongodb-org-mongos-7.0.7 mongodb-org-tools-7.0.7

注意

yum 当有新版本可用时会自动升级这些软件包。如果要阻止 MongoDB 升级,请将以下 exclude 指令添加到 /etc/yum.conf 文件,固定您的软件包:

exclude=mongodb-org,mongodb-org-database,mongodb-org-server,mongodb-mongosh,mongodb-org-mongos,mongodb-org-tools

大多数类 Unix 操作系统都会对每个进程可以使用的系统资源进行限制。这些限制可能会对 MongoDB 操作产生负面影响,应进行适当调整。有关您平台的建议设置,请参阅 UNIX ulimit 设置

注意

如果打开文件数的ulimit值低于64000 ,则 MongoDB 会生成初创企业警告。

默认情况下,MongoDB 使用 mongod 用户帐户运行,并且使用以下默认目录:

  • /var/lib/mongo (数据目录)

  • /var/log/mongodb (日志目录)

软件包管理器在安装过程中创建默认目录。所有者和群组名称是mongod

要使用除默认目录外的数据目录和/或日志目录:

  1. 创建新目录。

  2. 编辑配置文件 /etc/mongod.conf 并相应修改以下字段:

    • storage.dbPath 指定新的数据目录路径(例如/some/data/directory

    • systemLog.path 以指定新的日志文件路径(例如 /some/log/directory/mongod.log

  3. 确保运行 MongoDB 的用户有权访问这些目录:

    sudo chown -R mongod:mongod <directory>

    如果更改运行 MongoDB 进程的用户,必须赋予新用户访问这些目录的权限。

  4. 如果已强制执行,请配置 SELinux。请参阅配置 SELinux。

从 MongoDB 5.0 开始,一个新的 SELinux 策略可用于安装 MongoDB:

  • 使用 .rpm 安装程序。

  • 使用默认配置设置。

  • 在 RHEL7 或更高版本上运行。

使用 LDAP 身份验证安装 MongoDB Enterprise 时,必须额外实施以下 SELinux 策略:

如果您的安装不符合这些要求,请参阅 .tgz 软件包的 SELinux 说明

注意

如果您的 MongoDB 部署对以下任何设置项使用了自定义设置:

您无法使用 MongoDB 提供的 SELinux 策略。备选方法是创建一个自定义 SELinux 策略,但编写不当的自定义策略可能降低安全性或导致 mongod 实例无法运行。

  1. 确保您已安装以下软件包:

    • git

    • make

    • checkpolicy

    • policycoreutils

    • selinux-policy-devel

    sudo yum install git make checkpolicy policycoreutils selinux-policy-devel
  2. 下载策略存储库。

    git clone https://github.com/mongodb/mongodb-selinux
  3. 构建策略。

    cd mongodb-selinux
    make
  4. 应用该策略。

    sudo make install

重要

向后不兼容的功能

从 MongoDB 5.1 开始,您必须在先前克隆 SELinux 策略的 目录运行以下命令,然后才能 降级到 MongoDB 的早期版本:

sudo make uninstall
  • SELinux 策略旨在与标准 MongoDB.rpm 包安装产生的配置配合使用。请参阅 标准安装假设 了解更多详情。

  • SELinux 策略专为 mongod 服务器而设计。它不应用于其他 MongoDB 守护进程或工具,例如:

  • 参考策略 SELinux 项目提供的包含一个mongodb_admin 宏。 MongoDB SELinux 策略中不包含此宏。unconfined_t 域中的管理员可以管理mongod

  • 要卸载策略,请转至您保存 策略存储库的目录并运行:

    sudo make uninstall

请按照以下步骤在您的系统上运行 MongoDB Community Edition。 参照这些操作说明的前提是您在使用默认设置。

初始化系统

要运行和管理 mongod 进程,需使用操作系统内置的初始化系统。较新版本的 Linux 倾向于使用 systemd(它会使用 systemctl 命令),而较旧版本的 Linux 倾向于使用 System V init(它使用 service 命令)。

如果您不确定您的平台使用的是哪个初始化系统,请运行以下 命令:

ps --no-headers -o comm 1

然后根据结果选择下面合适的标签页:

  • systemd - 选择下方的 systemd (systemctl) 标签页。

  • init - 选择下方的 System V Init (service) 标签页。


要从系统中完全删除 MongoDB,您必须删除 MongoDB 应用程序本身、配置文件以及任何包含 数据和日志的目录。以下部分将指导您完成所需的步骤。

警告

此过程将完全删除 MongoDB、其配置以及所有数据库。此过程不可逆,因此请确保在继续之前备份所有配置和数据。

1

通过发出以下命令来停止 mongod 进程:

sudo service mongod stop
2

删除您之前安装的所有 MongoDB 包。

sudo yum erase $(rpm -qa | grep mongodb-org)
3

删除 MongoDB 数据库和日志文件。

sudo rm -r /var/log/mongodb
sudo rm -r /var/lib/mongo

默认情况下,MongoDB 会以将 bindIp 设为 127.0.0.1 来启动,从而绑定到本地主机网络接口。这意味着 mongod 只能接受来自同一计算机上运行的客户端的连接。远程客户端无法连接到 mongod,且 mongod 无法初始化副本集,除非将此值设为可从远程客户端访问的有效网络接口。

该值可通过以下任一方式配置:

  • 在 MongoDB 配置文件中使用 bindIp,或

  • 通过命令行参数 --bind_ip

警告

将实例绑定到可公开访问的 IP 地址之前,必须保护集群免遭未经授权的访问。有关安全建议的完整列表,请参阅安全检查清单。至少应考虑强化网络基础设施启用身份验证

有关配置 bindIp 的更多信息,请参阅 IP 绑定。

MongoDB Community Edition 可从其专用 存储库获取,并包含以下官方支持的包:

包名称
说明
mongodb-org
自动安装下列组件包的 metapackage
mongodb-org-database

自动安装下列组件包的 metapackage

包名称
说明
mongodb-org-server
包含 mongod 守护程序、相关的初始化脚本和配置文件 (/etc/mongod.conf)。您可以使用初始化脚本启动mongod与配置文件。有关详细信息,请参阅上面的“运行 MongoDB 社区版”部分。
mongodb-org-mongos
包含 mongos 守护程序。
mongodb-mongosh
包含 MongoDB Shell ( mongosh )。
mongodb-org-tools

自动安装下列组件包的 metapackage

包名称
说明
mongodb-database-tools
mongodb-org-database-tools-extra
包含 install_compass 脚本
← 在 Linux 上安装 MongoDB Community Edition