如何在CentOS 7上安装MongoDB
MongoDB是一个免费的开源文档数据库。
它被分类为NoSQL数据库,这与传统的基于表的SQL数据库(例如MySQL和PostgreSQL)不同。
在MongoDB中,数据存储在灵活的,类似于JSON的文档中,其中文档之间的字段可能会有所不同。
它不需要预定义的架构,并且数据结构可以随时间更改。
在本教程中,我们将向我们展示如何从官方MongoDB存储库在CentOS 7服务器上安装和配置MongoDB社区版。
准备工作
在继续本教程之前,请确保我们以具有sudo特权的用户身份登录。
安装MongoDB
在撰写本文时,可从官方MongoDB存储库中获得的MongoDB的最新版本是4.0版。
在继续下一步之前,请访问MongoDB文档的“在Red Hat上安装”部分,并检查是否有可用的新版本。
请按照以下步骤在CentOS服务器上安装MongoDB的最新稳定版本:
- 启用MongoDB存储库要将MongoDB存储库添加到系统中,请打开文本编辑器并在/etc/yum.repos.d/目录下创建一个新的YUM存储库配置文件,名称为
mongodb-org.repo
:/etc/yum .repos.d/mongodb-org.repo
[mongodb-org-4.0] name=MongoDB Repository baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/4.0/x86_64/ gpgcheck=1 enabled=1 gpgkey=https://www.mongodb.org/static/pgp/server-4.0.asc
如果要安装旧版本的MongoDB,请用首选版本替换每个“ 4.0”实例。
- 安装MongoDB现在启用了存储库,我们可以使用yum实用程序安装'mongodb-org'元软件包:
sudo yum install mongodb-org
在安装过程中,yum会提示我们导入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工具。
- 启动MongoDBO安装完成后,启动MongoDB守护进程并通过键入以下命令使其在启动时启动:
sudo systemctl start mongodsudo systemctl enable mongod
- 验证MongoDB安装要验证安装,我们将使用“ mongo”工具连接到MongoDB数据库服务器并打印服务器版本:
mongo
一旦进入MongoDB Shell,请输入以下命令,以显示MongoDB版本:
db.version()
输出将如下所示:
4.0.1
配置MongoDB
我们可以通过编辑用YAML编写的'/etc/mongod.conf'配置文件来配置MongoDB实例。
在大多数情况下,默认配置设置就足够了。
但是,对于生产环境,我们建议取消对安全性部分的注释并启用授权,如下所示:
/etc/mongod.conf
security: authorization: enabled
“授权”选项启用了基于角色的访问控制(RBAC),该功能可控制用户对数据库资源和操作的访问。
如果禁用此选项,则每个用户都可以访问任何数据库,并且可以执行任何操作。
对MongoDB配置文件进行更改后,重新启动mongod服务:
sudo systemctl restart mongod
要查找有关MongoDB 4.0中可用配置选项的更多信息,请访问“配置文件选项”文档页面。
创建MongoDB管理用户
如果启用了MongoDB身份验证,请创建一个管理MongoDB用户,我们将使用该用户来访问和管理MongoDB实例。
首先使用以下命令访问mongo shell:
mongo
一旦进入MongoDB Shell,请键入以下命令以连接到“ 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
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" ] }
我们还可以尝试不使用任何参数访问mongo shell(只需键入'mongo'),看看是否可以使用与上述相同的命令列出用户。