MongoDB开源文档数据库的安装

描述

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

etc/mongod.conf

完成后保存文件并退出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。

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分