如何在CentOS 8上安装MongoDB

时间:2020-03-05 15:30:16  来源:igfitidea点击:

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

在MongoDB中,数据存储在灵活的,类似于JSON的文档中,其中文档之间的字段可能会有所不同。

它不需要预定义的架构,并且数据结构可以随时间更改。

本教程说明了如何在CentOS 8服务器上安装和配置MongoDB社区版。

安装MongoDB

MongoDB在CentOS 8核心存储库中不可用。
我们将启用官方的MongoDB存储库并安装软件包。

在撰写本文时,可从官方MongoDB存储库中获得的最新版本的MongoDB是4.2版。
在开始安装之前,请访问MongoDB文档的“在Red Hat上安装”部分,并检查是否有可用的新版本。

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

  • 通过在“ /etc/yum.repos.d/”目录中创建一个名为“ mongodb-org.repo”的新存储库文件来启用MongoDB存储库:
sudo nano /etc/yum.repos.d/mongodb-org.repo

/etc/yum.repos.d/mongodb-org.repo

[mongodb-org-4.2]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/4.2/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-4.2.asc

如果要安装旧版本的MongoDB,请用首选版本替换每个“ 4.2”实例。

  • 安装“ mongodb-org”元软件包:
sudo dnf install mongodb-org

在安装过程中,我们将提示我们导入MongoDB GPG密钥。输入'y'并点击'Enter'。以下软件包将作为'mongodb-org'软件包的一部分安装在系统上:

  • 'mongodb-org-server'-'mongod'守护程序以及相应的初始化脚本和配置。
  • 'mongodb-org-mongos'-'mongos'守护程序。
  • 'mongodb-org-shell'-mongo shell,它是MongoDB的交互式JavaScript接口,用于执行命令行中的管理任务。
  • 'mongodb-org-tools'-包含几个用于导入和导出数据,统计信息以及其他实用程序的MongoDB工具。
  • 安装完成后,启用并启动MongoDB服务:
sudo systemctl enable mongod --now
  • 要验证安装,请连接到MongoDB数据库服务器并打印服务器版本:
mongo

运行以下命令以显示MongoDB版本:

db.version()

输出看起来像这样:

4.2.3

配置MongoDB

MongoDB配置文件名为“ mongod.conf”,位于“/etc”目录中。
该文件为YAML格式。

在大多数情况下,默认配置设置就足够了。
但是,对于生产环境,我们建议取消对安全性部分的注释并启用授权,如下所示:

/etc/mongod.conf

security:
  authorization: enabled

“授权”选项启用了基于角色的访问控制(RBAC),该功能可控制用户对数据库资源和操作的访问。

如果禁用此选项,则每个用户将有权访问任何数据库并执行任何操作。

对MongoDB配置文件进行更改后,重新启动mongod服务:

sudo systemctl restart mongod

有关MongoDB配置选项的更多信息,请访问“配置文件选项”文档页面。

创建MongoDB管理用户

如果启用了MongoDB身份验证,则需要创建一个可以访问和管理MongoDB实例的管理用户。

首先,使用以下命令访问MongoDB shell:

mongo

键入以下命令以连接到“ admin”数据库:

use admin
switched to db admin

使用“ userAdminAnyDatabase”角色创建一个名为“ mongoAdmin”的新用户:

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 version v4.2.3
Enter password:
use admin
switched to db admin

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

show users
{
	"_id" : "admin.mongoAdmin",
	"user" : "mongoAdmin",
	"db" : "admin",
	"roles" : [
		{
			"role" : "userAdminAnyDatabase",
			"db" : "admin"
		}
	],
	"mechanisms" : [
		"SC内存-SHA-1",
		"SC内存-SHA-256"
	]
}