MongoDB是一个免费的开源文档数据库。它属于一个称为NoSQL的数据库家族,它与传统的基于表的SQL数据库(如MySQL和PostgreSQL)不同。
在MongoDB中,数据存储在灵活的,类似于JSON的文档中,其中文档之间的字段可能会有所不同。它不需要预定义的架构,并且数据结构可以随时间更改。
本教程介绍了如何在Ubuntu 20.04上安装和配置MongoDB Community Edition。
标准的Ubuntu存储库包括一个过时的MongoDB版本。在Ubuntu上安装最新的MongoDB非常简单。我们将启用MongoDB存储库,导入存储库GPG密钥,并安装MongoDB服务器。
在Ubuntu 20.04上安装MongoDB
以root或具有sudo特权的用户执行以下步骤,以在Ubuntu上安装MongoDB:
- 安装通过HTTPS添加新存储库所需的依赖项:
sudo apt update
sudo apt install dirmngr gnupg apt-transport-https ca-certificates software-properties-common
- 导入存储库的GPG密钥,并使用以下命令添加MongoDB存储库:
wget -qO - https://www.mongodb.org/static/pgp/server-4.4.asc | sudo apt-key add -
sudo add-apt-repository 'deb [arch=amd64] https://repo.mongodb.org/apt/ubuntu focal/mongodb-org/4.4 multiverse'
在撰写本文时,MongoDB的最新版本是4.4版。要安装另一个版本,请替换
4.4
为您的首选版本。 - 启用存储库后,
mongodb-org
通过键入以下命令安装元软件包:sudo apt install 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 --now mongod
- 要验证安装是否成功完成,请使用该
mongo
工具连接到MongoDB数据库服务器,并打印连接状态:mongo --eval 'db.runCommand({ connectionStatus: 1 })'
输出如下所示:
MongoDB shell version v4.4.0 connecting to: mongodb://127.0.0.1:27017/?compressors=disabled&gssapiServiceName=mongodb Implicit session: session { "id" : UUID("2af3ab0e-2197-4152-8bd0-e33efffe1464") } MongoDB server version: 4.4.0 { "authInfo" : { "authenticatedUsers" : [ ], "authenticatedUserRoles" : [ ] }, "ok" : 1 }
的值
1
的ok
字段表示成功。
配置MongoDB
MongoDB配置文件已命名mongod.conf
并位于/etc
目录中。该文件为YAML格式。
在大多数情况下,默认配置设置已足够。但是,对于生产环境,我们建议取消对安全性部分的注释并启用授权,如下所示:
sudo nano /etc/mongod.conf
security:
authorization: enabled
该authorization
选项启用了基于角色的访问控制(RBAC),它可以控制用户对数据库资源和操作的访问。如果禁用此选项,则每个用户将有权访问所有数据库并执行任何操作。
编辑MongoDB配置文件时,请重新启动mongod服务,以使更改生效:
sudo systemctl restart mongod
要查找有关MongoDB 4.4中可用配置选项的更多信息,请访问“配置文件选项”文档页面。
创建管理MongoDB用户
如果启用了MongoDB身份验证,则需要创建一个可以访问和管理MongoDB实例的管理用户。
访问mongo shell:
mongo
从MongoDB Shell内部,键入以下命令以连接到admin
数据库:
use admin
switched to db admin
运行以下命令以创建一个名为的新用户mongoAdmin
,其密码changeMe
和userAdminAnyDatabase
角色为:
db.createUser(
{
user: "mongoAdmin",
pwd: "changeMe",
roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
}
)
Successfully added user: {
"user" : "mongoAdmin",
"roles" : [
{
"role" : "userAdminAnyDatabase",
"db" : "admin"
}
]
}
完成后,使用以下命令退出mongo shell:
quit()
要测试更改,请使用先前创建的管理用户访问mongo shell:
mongo -u mongoAdmin -p --authenticationDatabase admin
use admin
switched to db admin
运行show users
,您应该看到有关新创建的用户的信息:
show users
{
"_id" : "admin.mongoAdmin",
"userId" : UUID("49617e41-ea3b-4fea-96d4-bea10bf87f61"),
"user" : "mongoAdmin",
"db" : "admin",
"roles" : [
{
"role" : "userAdminAnyDatabase",
"db" : "admin"
}
],
"mechanisms" : [
"SCRAM-SHA-1",
"SCRAM-SHA-256"
]
}
您也可以尝试不带任何参数的mongo shell(只需键入mongo
),看看是否可以使用与上述相同的命令列出用户。
原创文章,作者:校长,如若转载,请注明出处:https://www.yundongfang.com/Yun35676.html