“文档” 菜单
文档首页
/
MongoDB Manual
/ / /

在 SUSE 上安装 MongoDB Community Edition

在此页面上

  • 概述
  • 注意事项
  • 安装 MongoDB Community Edition
  • 运行 MongoDB Community Edition
  • 卸载 MongoDB Community Edition
  • 更多信息

注意

MongoDB 阿特拉斯

MongoDB Atlas 是在云中托管的 MongoDB 服务选项,无需安装开销,并提供免费套餐,可以立即开始使用。

使用本教程,利用 zypper 软件包管理器在 SUSE Linux Enterprise Server (SLES) 上安装 MongoDB 7.0 社区版。

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

MongoDB7 。0 Community Edition 支持采用64 x86 _ 架构的以下 位 SUSE Linux64 Enterprise Server (SLES) 版本:

  • SLES 15

  • SLES 12

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

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

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

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

1
sudo rpm --import https://pgp.mongodb.com/server-7.0.asc
2

添加存储库,以便可以安装 MongoDB。使用适合 SUSE 版本的命令:

sudo zypper addrepo --gpgcheck "https://repo.mongodb.org/zypper/suse/15/mongodb-org/7.0/x86_64/" mongodb
sudo zypper addrepo --gpgcheck "https://repo.mongodb.org/zypper/suse/12/mongodb-org/7.0/x86_64/" mongodb

要安装以前版本系列(例如4的 MongoDB 包。 0 ,您可以在存储库配置中指定版本系列。

例如,将 SUSE 12系统限制为4 。 0版本系列,请使用以下命令:

sudo zypper addrepo --no-gpgcheck "https://repo.mongodb.org/zypper/suse/12/mongodb-org/4.0/x86_64/" mongodb
3

要安装最新版 MongoDB,请发出以下命令:

sudo zypper -n install mongodb-org

要安装特定版本的 MongoDB,请单独指定每个组件包并将版本号附加到软件包名称中,如下例所示:

sudo zypper install mongodb-org-7.0.12 mongodb-org-database-7.0.12 mongodb-org-server-7.0.12 mongodb-mongosh-7.0.12 mongodb-org-mongos-7.0.12 mongodb-org-tools-7.0.12

虽然您可以指定任意可用版本的 MongoDB,但当有新版本可用时,zypper 仍会升级这些软件包。为防止意外升级,请运行以下命令固定软件包:

sudo zypper addlock mongodb-org-7.0.12 mongodb-org-database-7.0.12 mongodb-org-server-7.0.12 mongodb-mongosh-7.0.12 mongodb-org-mongos-7.0.12 mongodb-org-tools-7.0.12

以前版本的 MongoDB 软件包使用不同的存储库位置。请参阅适用于您的 MongoDB 版本的文档版本。

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

注意

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

默认情况下,MongoDB 实例存储:

  • 其数据文件于 /var/lib/mongo

  • 其日志文件于 /var/log/mongodb

如果通过包管理器进行安装,则会在安装过程中创建这些默认目录。

如果您通过下载 tarball 手动安装,则可以使用 mkdir -p <directory>sudo mkdir -p <directory> 创建目录,具体取决于将运行 MongoDB 的用户。(有关 mkdirsudo 的信息,请参见您的 linux 手册页。)

默认情况下,MongoDB 使用 mongod 用户账户运行。如果更改运行 MongoDB 进程的用户,还必须修改 /var/lib/mongo/var/log/mongodb 目录,以赋予该用户访问这些目录的权限。

要指定不同的日志文件目录和数据文件目录,请编辑 /etc/mongod.conf 中的 systemLog.pathstorage.dbPath 设置。确保运行 MongoDB 的用户有访问这些目录的权限。

请按照以下步骤运行 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) 标签页。


1

您可以通过发出以下命令来启动 mongod 进程:

sudo systemctl start mongod

如果收到类似下方的错误(在启动 mongod 时):

Failed to start mongod.service: Unit mongod.service not found.

首先运行以下命令:

sudo systemctl daemon-reload

然后再次运行上面的启动命令。

2

您可以通过发出以下命令来验证 mongod 进程已成功启动:

sudo systemctl status mongod

您可以通过选择执行以下命令,来确保 MongoDB 将在系统 重新启动后启动:

sudo systemctl enable mongod
3

您可以根据需要,通过发出以下命令来停止 mongod 进程:

sudo systemctl stop mongod
4

您可以通过发出以下命令来重启 mongod 进程:

sudo systemctl restart mongod

通过观察 /var/log/mongodb/mongod.log 文件中的输出,可以跟踪错误或重要消息的进程状态。

5

在与 mongod 相同的主机上启动 mongosh 会话。您可以在不使用任何命令行选项的情况下运行 mongosh,从而连接在本地主机上运行且默认端口号为 27017 的 mongod

mongosh

如需进一步了解使用 mongosh 进行连接(例如连接在其他主机和/或端口上运行的 mongod 实例),请参阅 mongosh 文档。

为了帮助您开始使用 MongoDB,MongoDB 提供了各种驱动程序版本的入门指南。关于驱动程序文档,请参阅 开始使用 MongoDB 开发。

1

您可以通过发出以下命令来启动 mongod 进程:

sudo service mongod start
2

您可以通过检查位于/var/log/mongodb/mongod.log的日志文件的内容是否有一行以下内容来验证mongod进程已成功启动:

[initandlisten] waiting for connections on port <port>

其中, <port>是在/etc/mongod.conf (默认为27017 )中配置的端口。

您可以通过选择执行以下命令,来确保 MongoDB 将在系统 重新启动后启动:

sudo chkconfig mongod on
3

您可以根据需要,通过发出以下命令来停止 mongod 进程:

sudo service mongod stop
4

您可以通过发出以下命令来重启 mongod 进程:

sudo service mongod restart

通过观察 /var/log/mongodb/mongod.log 文件中的输出,可以跟踪错误或重要消息的进程状态。

5

在与 mongod 相同的主机上启动 mongosh 会话。您可以在不使用任何命令行选项的情况下运行 mongosh,从而连接在本地主机上运行且默认端口号为 27017 的 mongod

mongosh

如需进一步了解使用 mongosh 进行连接(例如连接在其他主机和/或端口上运行的 mongod 实例),请参阅 mongosh 文档。

为了帮助您开始使用 MongoDB,MongoDB 提供了各种驱动程序版本的入门指南。关于驱动程序文档,请参阅 开始使用 MongoDB 开发。

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

警告

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

1

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

sudo service mongod stop
2

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

sudo zypper remove $(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 脚本

后退

使用 .tgz Tarball 进行安装

来年

使用 .tgz Tarball 进行安装