MongoDB开源文档数据库。它属于一个称为NoSQL的数据库家族,它与传统关系型基于表的SQL数据库不同,如MySQL和PostgreSQL。
在MongoDB中,数据存储在灵活的JSON的文档中,字段随文档的不同而不同。它不需要预定义的结构,并且数据结构可以随时间改变。
本教程介绍如何在Ubuntu 20.04安装MongoDB Community Edition。在开始本教程之前请确保你以root或者具有sudo权限的用户登录。
安装MongoDB
标准的Ubuntu 20.04仓库包含过时的MongoDB版本。在Ubuntu 20.04安装最新的MongoDB非常简单。
在撰写本文时,可从官方MongoDB仓库获得的最新版本的MongoDB是6.0版。如果你需要安装5.0版本,请将命令的6.0替换为5.0。
首先将安装导入MongoDB的GPG密钥的软件包,运行apt命令。然后运行wget导入GPG密钥,运行echo和tee的组合命令添加MongoDB软件源。
sudo apt update
sudo apt install -y dirmngr wget gnupg apt-transport-https ca-certificates software-properties-common gnupg
wget -qO - https://www.mongodb.org/static/pgp/server-6.0.asc | sudo apt-key add -
echo "deb [ arch=amd64,arm64 ] https://repo.mongodb.org/apt/ubuntu focal/mongodb-org/6.0 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-6.0.list
当导入MongoDB的软件源之后,运行命令sudo apt install -y mongodb-org安装MongoDB服务器以及所有工具。
如果你MongoDB运行在Docker,可以运行命令sudo apt install mongodb-org-shell mongodb-org-tools
仅安装MongoDB客户端和MongoDB工具。
sudo apt update
sudo apt install -y mongodb-org
sudo apt install mongodb-org-shell mongodb-org-tools
在与MongoDB进行交互时,首先启动MongoDB服务,运行命令sudo systemctl enable --now mongod
,该命令还会设置MongoDB的自动启动。
要查看MongoDB服务运行状态请运行命令sudo systemctl status mongod
。
你也可以运行命令mongo --eval 'db.runCommand({ connectionStatus: 1 })'
直接连接到Mongodb服务器,它将会打印当前连接的状态。ok
字段的1
值表示成功。
sudo systemctl enable mongod --now
sudo systemctl status mongod
当你完成MongoDB安装后,Ubuntu 20.04将会安装mongodb-org-server
以及相应的初始化脚本和配置。
mongodb-org-shell
也就是mongodb的客户端,它是MongoDB的交互式JavaScript接口。它用于执行命令行中的管理任务。
mongodb-org-tools
包含用于导入和导出数据,统计信息以及其他程序的MongoDB工具。
MongoDB 权限控制
MongoDB配置文件名为mongod.conf
,位于/etc
目录中。该文件为YAML格式。
默认配置设置在大多数情况下就足够。但是,对于生产环境,我们建议取消对安全性部分的注释并启用授权。
配置文件中的authorization
选项可启用基于角色的访问控制RBAC,该功能管理用户对数据库资源和操作的访问。
如果禁用此选项,则每个用户将有权访问所有数据库并执行任何操作。如果你需要启用此选项。请执行以下步骤。
使用你喜欢的文本编辑器,打开文件/etc/mongod.conf
。在本教程中,我们将使用vim打开文件/etc/mongod.conf
。
然后使用vim搜索关键词authorization,并定位此选项,然后启用authorization授权验证。
sudo vim /etc/mongod.conf
sudo systemctl restart mongod
security:
authorization: enabled
完成后保存文件并退出vim,每次编辑MongoDB配置文件时,你都需要运行命令sudo systemctl restart mongod
重新启动mongod服务以使更改生效。
要查找有关MongoDB中可用配置选项的更多信息,请访问配置文件选项文档页面。
创建 MongoDB用户
如果启用了MongoDB身份验证,则需要创建一个可以访问和管理MongoDB实例的管理用户。
首先使用mongodb客户端连接MongoDB服务器。当你进入MongoDB Shell时运行命令use admin
切换到admin
数据库。
然后运行createUser命令来创建用户。其中user
是用户名,pwd
是密码,role
的userAdminAnyDatabase也就是管理任何数据库。
admin是MongoDB的内置数据库。不要忘记设置更安全的密码。您可以根据需要命名MongoDB管理用户。
mongo
use admin
db.createUser(
{
user: "mongoAdmin",
pwd: "changeMe",
roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
}
)
当创建用户完成后运行命令quit()
退出Mongo Shell。要测试更改,请以创建的管理用户访问Mongo Shell。
运行命令mongo -u mongoAdmin -p --authenticationDatabase admin
。-u
选项表示指定用户,--authenticationDatabase
选项指定要在那个数据库进行验证。
切换admin数据库,然后运行show users
,您应该看到新创建的用户的信息。
mongo -u mongoAdmin -p --authenticationDatabase admin
use admin
show users
结论
我们向您展示了如何在Ubuntu 20.04安装MongoDB。请查看MongoDB手册。获取有关此主题的更多信息。如果您遇到问题或有反馈,请在下面发表评论。