MongoDB 是一个免费的开源文档数据库。它属于 NoSQL 数据库家族,与 MySQL 和 PostgreSQL 等传统的基于表的 SQL 数据库不同。
在 MongoDB 中,数据存储在灵活的、类似 JSON字段可能因文档而异的文档。它不需要预定义的模式,并且数据结构可以随着时间的推移而改变。
在本教程中,我们将介绍在 Ubuntu 18.04 计算机上从官方 MongoDB 存储库安装和配置最新版本 MongoDB 社区版的过程。
先决条件#
在继续本教程之前,请确保您以以下身份登录具有 sudo 权限的用户
.
安装 MongoDB#
在撰写本文时,MongoDB 的最新版本是 4.0 版。
在继续安装过程之前,请转到在 Ubuntu 上安装MongoDB 文档部分,并检查是否有可用的新版本。
以下步骤描述了如何在 Ubuntu 服务器上安装 MongoDB:
-
使用以下命令将 MongoDB GPG 密钥添加到您的系统:
sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 9DA31620334BD75D9DCB49F368818C72E52529D4
导入密钥后,添加 MongoDB 存储库:
sudo add-apt-repository 'deb [arch=amd64] https://repo.mongodb.org/apt/ubuntu bionic/mongodb-org/4.0 multiverse'
如果您收到一条错误消息说add-apt-repository command not found
,安装software-properties-common
包裹。
要安装旧版本的 MongoDB,请替换4.0
与您喜欢的版本。
-
更新软件包列表并安装mongodb-org
元包通过键入:
sudo apt update
sudo apt install mongodb-org
以下软件包将作为安装包的一部分安装在您的系统上mongodb-org
包裹:
-
mongodb-org-server
- The mongod
守护进程和相应的初始化脚本和配置。
-
mongodb-org-mongos
- The mongos
daemon.
-
mongodb-org-shell
- mongo shell 是 MongoDB 的交互式 JavaScript 接口。它用于通过命令行执行管理任务。
-
mongodb-org-tools
- 包含多个用于导入和导出数据、统计数据以及其他实用程序的 MongoDB 工具。
-
安装完成后,启动 MongoDB 守护进程,并通过键入以下命令使其在启动时启动:
sudo systemctl start mongod
sudo systemctl enable mongod
-
为了验证安装是否已成功完成,我们将使用以下命令连接到 MongoDB 数据库服务器mongo
工具并打印连接状态:
mongo --eval 'db.runCommand({ connectionStatus: 1 })'
输出将如下所示:
MongoDB shell version v4.0.10
connecting to: mongodb://127.0.0.1:27017
MongoDB server version: 4.0.10
{
"authInfo" : {
"authenticatedUsers" : [ ],
"authenticatedUserRoles" : [ ]
},
"ok" : 1
}
值为1
为了ok
字段表示成功。
配置 MongoDB#
MongoDB 使用YAML格式化的配置文件,/etc/mongod.conf
。您可以通过编辑此文件来配置 MongoDB 实例。
默认配置设置对于大多数用户来说已经足够了。但对于生产环境,建议取消安全部分的注释并启用授权,如下所示:
/etc/mongod.conf
security:
authorization: enabled
The authorization
选项启用基于角色的访问控制 (RBAC)它规范用户对数据库资源和操作的访问。如果禁用此选项,每个用户都将有权访问所有数据库并执行任何操作。
更改 MongoDB 配置文件后,使用以下命令重新启动 mongod 服务:
sudo systemctl restart mongod
要查找有关 MongoDB 4.0 中可用配置选项的更多信息,请访问配置文件选项文档页面。
创建 MongoDB 管理用户#
如果您启用了 MongoDB 身份验证,请创建一个管理 MongoDB 用户,用于访问和管理 MongoDB 实例。
首先,使用以下命令访问 mongo shell:
mongo
进入 MongoDB shell 后,输入以下命令连接到admin
数据库:
switched to db admin
发出以下命令来创建一个名为的新用户mongoAdmin
与userAdminAnyDatabase
role:
db.createUser(
{
user: "mongoAdmin",
pwd: "changeMe",
roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
}
)
Successfully added user: {
"user" : "mongoAdmin",
"roles" : [
{
"role" : "userAdminAnyDatabase",
"db" : "admin"
}
]
}
使用以下命令退出 mongo shell:
要测试更改,请使用您之前创建的管理用户访问 mongo shell:
mongo -u mongoAdmin -p --authenticationDatabase admin
switched to db admin
现在,使用以下命令打印用户:
{
"_id" : "admin.mongoAdmin",
"user" : "mongoAdmin",
"db" : "admin",
"roles" : [
{
"role" : "userAdminAnyDatabase",
"db" : "admin"
}
],
"mechanisms" : [
"SCRAM-SHA-1",
"SCRAM-SHA-256"
]
}
您还可以尝试在不使用任何参数的情况下访问 mongo shell(只需键入mongo
)并查看是否可以使用与上面相同的命令列出用户。
结论#
您已经学习了如何在 Ubuntu 18.04 服务器上安装和配置 MongoDB 4.0。访问MongoDB 4.0 手册有关此主题的更多信息。
如果您遇到问题或有反馈,请在下面发表评论。