如何在 Ubuntu 18.04 上从默认 APT 仓库安装 MongoDB

作者选择了 Creative Commons Corporation作为 Write for Donations计划的一部分获得100美元的捐款。

介绍

MongoDB,也被称为 _Mongo_是一个免费和开源的NoSQL文档数据库,通常用于现代Web应用程序。

在本教程中,您将安装MongoDB,管理其服务,并可选地启用远程访问。

<$>[注] :从本文开始,本教程安装了MongoDB的3.6版本,这是从默认的Ubuntu存储库中可用的版本。然而,我们通常建议您安装MongoDB的最新版本(本文的4.4版本)而不是。

前提条件

要遵循本教程,您将需要:

步骤1:安装 MongoDB

Ubuntu 的官方包存包括 MongoDB,这意味着我们可以使用apt安装所需的包。正如介绍中提到的,从默认库存中可用的版本不是最新版本。

首先,更新包列表以获得存储库列表的最新版本:

1sudo apt update

现在安装 MongoDB 包本身:

1sudo apt install -y mongodb

此命令会安装包含 MongoDB 的稳定版本的多个包,以及 MongoDB 服务器的有用的管理工具。

接下来,让我们检查服务器是否运行并正常工作。

步骤 2:检查服务和数据库

安装过程自动启动 MongoDB,但让我们验证该服务已启动,并且数据库正在工作。

首先,检查服务的状态:

1sudo systemctl status mongodb

你会看到这个输出:

1[secondary_label Output]
2 mongodb.service - An object/document-oriented database
3   Loaded: loaded (/lib/systemd/system/mongodb.service; enabled; vendor preset: enabled)
4   Active: active (running) since Sat 2018-05-26 07:48:04 UTC; 2min 17s ago
5     Docs: man:mongod(1)
6 Main PID: 2312 (mongod)
7    Tasks: 23 (limit: 1153)
8   CGroup: /system.slice/mongodb.service
9           └─2312 /usr/bin/mongod --unixSocketPrefix=/run/mongodb --config /etc/mongodb.conf

根据systemd,MongoDB服务器正在运行。

我们可以通过实际连接到数据库服务器并执行诊断命令来进一步验证这一点。

执行此命令:

1mongo --eval 'db.runCommand({ connectionStatus: 1 })'

这将输出当前数据库版本、服务器地址和端口以及状态命令的输出:

 1[secondary_label Output]
 2MongoDB shell version v3.6.3
 3connecting to: mongodb://127.0.0.1:27017
 4MongoDB server version: 3.6.3
 5{
 6        "authInfo" : {
 7                "authenticatedUsers" : [ ],
 8                "authenticatedUserRoles" : [ ]
 9        },
10        "ok" : 1
11}

响应中的OK字段的值为1,表示服务器正在正常工作。

接下来,我们将看看如何管理服务器实例。

第3步:管理MongoDB服务

MongoDB 作为 systemd 服务安装,这意味着您可以使用 Ubuntu 中的所有其他系统服务一起使用标准 systemd 命令来管理它。

要检查服务的状态,键入:

1sudo systemctl status mongodb

您可以随时停止服务器通过键入:

1sudo systemctl stop mongodb

要在停止服务器时启动,键入:

1sudo systemctl start mongodb

您也可以使用单个命令重新启动服务器:

1sudo systemctl restart mongodb

默认情况下,MongoDB 配置为自动启动服务器. 如果您想要禁用自动启动,请键入:

1sudo systemctl disable mongodb

同样容易再次启用它. 要做到这一点,请使用:

1sudo systemctl enable mongodb

接下来,让我们调整我们的MongoDB安装的防火墙设置。

步骤 4 – 调整防火墙(可选)

假設您已遵循 初始伺服器安裝教程指示,在您的伺服器上啟用防火牆,MongoDB伺服器將無法從互聯網上存取。

如果您打算只在本地使用MongoDB服务器,并在同一服务器上运行应用程序,这是推荐的安全设置,但是,如果您希望能够从互联网连接到MongoDB服务器,则必须在ufw中允许接入连接。

要允许从任何地方访问MongoDB的默认端口27017,您可以使用sudo ufw allow 27017

在大多数情况下,MongoDB 只能从某些受信任的位置访问,例如另一个服务器托管应用程序. 为了完成此任务,您可以允许访问 MongoDB 的默认端口,同时指定另一个服务器的 IP 地址,该服务器将被明确允许连接:

1sudo ufw allow from your_other_server_ip/32 to any port 27017

您可以通过ufw验证防火墙设置的更改:

1sudo ufw status

您应该看到输出中允许的27017端口的流量:

1[label Output]
2Status: active
3
4To Action From
5--                         ------      ----
6OpenSSH ALLOW Anywhere
727017 ALLOW Anywhere
8OpenSSH (v6)               ALLOW Anywhere (v6)
927017 (v6)                 ALLOW Anywhere (v6)

如果您决定只允许某个特定 IP 地址连接到 MongoDB 服务器,则允许位置的 IP 地址将列出,而不是 Anywhere 在输出中。

您可以在 UFW Essentials: Common Firewall Rules and Commands中找到更高级的防火墙设置来限制访问服务。

即使端口是开放的,MongoDB 目前只在本地地址127.0.0.1上收听,要允许远程连接,请将服务器的公开可路由 IP 地址添加到mongod.conf文件中。

在您的编辑器中打开 MongoDB 配置文件:

1sudo nano /etc/mongodb.conf

将您的服务器的 IP 地址添加到bindIP值:

1[label ]
2...
3logappend=true
4
5bind_ip = 127.0.0.1,your_server_ip
6#port = 27017
7
8...

请确保在现有 IP 地址和您添加的 IP 地址之间放置一个。

保存文件,离开编辑器,然后重新启动 MongoDB:

1sudo systemctl restart mongodb

现在MongoDB正在听取远程连接,但任何人都可以访问它。

结论

您可以在 这些 DigitalOcean 社区文章中找到有关如何配置和使用 MongoDB 的更多深入教程。

Published At
Categories with 技术
comments powered by Disqus