在 Debian 10 Linux 上安装 MongoDB

在本教程中,我们将说明如何在 Debian 10 Buster 上安装和配置最新版本的 MongoDB Community Edition 。

MongoDB 是一个免费的开源文档数据库。它属于一个称为 NoSQL 的数据库家族,它与传统的基于表的 SQL 数据库(如 MySQL 和 PostgreSQL) 不同。

在 MongoDB 中,数据存储在灵活的,类似于 JSON 的文档中,其中文档之间的字段可能有所不同。它不需要预定义的架构,并且数据结构可以随时更改。

安装 MongoDB

MongoDB 在标准的 Debian Buster 存储库中不可用。我们将启用官方的 MongoDB 存储库并安装软件包。

在撰写本文时, MongoDB 的最新版本是 4.2 版。在开始安装之前,请转到 MongoDB 文档的关于在 Debian 上安装的页面,并检查是否有可用的新版本。

以 root 或具有 sudo 特权的用户执行以下步骤,以在 Debian 系统上安装 MongoDB :

  1. 安装添加新存储库所需的软件包:

    sudo apt install dirmngr gnupg apt-transport-https software-properties-common ca-certificates curl
    
  2. 将 MongoDB GPG 密钥添加到您的系统:

    curl -fsSL https://www.mongodb.org/static/pgp/server-4.2.asc |  sudo apt-key add - 
    
  3. 启用 MongoDB 存储库:

    sudo add-apt-repository 'deb https://repo.mongodb.org/apt/debian buster/mongodb-org/4.2 main'
    

    较旧版本 MongoDB 的软件包不适用于 Debian 10 。

  4. 更新软件包列表并安装 mongodb-org 软件包:

    sudo apt update
    sudo apt install mongodb-org
    

    以下软件包将作为 mongodb-org 软件包的一部分安装在系统上:

    • mongodb-org-servermongod 守护程序以及相应的初始化脚本和配置。
    • mongodb-org-mongosmongos 守护进程。
    • mongodb-org-shell - mongo shell 是 MongoDB 的交互式 JavaScript 接口。它用于通过命令行执行管理任务。
    • mongodb-org-tools - 包含几个用于导入和导出数据,统计信息以及其他实用程序的 MongoDB 工具。
  5. 启动 MongoDB 服务,并使其在启动时启动:

    sudo systemctl enable mongod --now
    
  6. 要验证安装是否成功完成,请使用该 mongo 工具连接到 MongoDB 数据库服务器并打印连接状态:

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

    输出将如下所示:

    MongoDB shell version v4.2.1
    connecting to: mongodb://127.0.0.1:27017/? compressors=disabled & gssapiServiceName=mongodb 
    Implicit session: session { " id "  : UUID( " 09f11c53-605f-44ad-abec-ec5801bb6b06 " )  }
    MongoDB server version: 4.2.1
    {
    	" authInfo "  :  {
    		" authenticatedUsers "  : [ ], 
    		" authenticatedUserRoles "  : [ ] 
    	},
    	" ok "  : 1 
    }

    字段 ok 的值为 1 表示成功。

配置 MongoDB

MongoDB 配置文件是位于 /etc 目录中的 mongod.conf 。该文件为 YAML 格式。

默认配置设置对于大多数用户而言已足够。但是,对于生产环境,建议取消注释安全性部分并启用授权,如下所示:

/etc/mongod.conf

security:
  authorization: enabled

authorization 选项启用了基于角色的访问控制 (RBAC) ,它可以控制用户对数据库资源和操作的访问。如果禁用此选项,则每个用户都可以访问所有数据库并执行任何操作。

编辑配置文件后,重新启动 mongod 服务以使更改生效:

sudo systemctl restart mongod

要查找有关 MongoDB 4.2 中可用配置选项的更多信息,请访问配置文件选项文档页面。

创建管理 MongoDB 用户

如果启用了 MongoDB 身份验证,则需要创建一个可以访问和管理 MongoDB 实例的管理用户。为此,请使用以下命令访问 mongo shell :

mongo

在 MongoDB Shell 中,键入以下命令以连接到 admin 数据库:

use admin
switched to db admin

发出以下命令来创建一个 mongoAdmin 具有该 userAdminAnyDatabase 角色的新用户:

db.createUser(
  {
    user: "mongoAdmin", 
    pwd: "changeMe", 
    roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
  }
)
Successfully added user: {
	"user" : "mongoAdmin",
	"roles" : [
		{
			"role" : "userAdminAnyDatabase",
			"db" : "admin"
		}
	]
}

您可以根据需要命名 MongoDB 管理用户。

使用以下命令退出 mongo shell :

quit()

要测试更改,请使用先前创建的管理用户访问 mongo shell :

mongo -u mongoAdmin -p --authenticationDatabase admin

出现提示时输入密码。一旦进入 MongoDB Shell ,请连接到 admin 数据库:

use admin
switched to db admin

现在,使用以下命令打印用户:

show users
{
	"_id" : "admin.mongoAdmin",
	"userId" : UUID("cdc81e0f-db58-4ec3-a6b8-829ad0c31f5c"),
	"user" : "mongoAdmin",
	"db" : "admin",
	"roles" : [
		{
			"role" : "userAdminAnyDatabase",
			"db" : "admin"
		}
	],
	"mechanisms" : [
		"SCRAM-SHA-1",
		"SCRAM-SHA-256"
	]
}

结论

我们向您展示了如何在 Debian 10 Buster 上安装 MongoDB 4.2 。有关此主题的更多信息,请访问 MongoDB 手册